
committed by
GitHub

2 changed files with 43 additions and 36 deletions
@ -1,49 +1,53 @@ |
|||
# frozen_string_literal: true |
|||
|
|||
if ENV['LDAP_ENABLED'] == 'true' |
|||
require 'net/ldap' |
|||
require 'devise/strategies/authenticatable' |
|||
require 'net/ldap' |
|||
require 'devise/strategies/authenticatable' |
|||
|
|||
module Devise |
|||
module Strategies |
|||
class LdapAuthenticatable < Authenticatable |
|||
def authenticate! |
|||
if params[:user] |
|||
ldap = Net::LDAP.new( |
|||
host: Devise.ldap_host, |
|||
port: Devise.ldap_port, |
|||
base: Devise.ldap_base, |
|||
encryption: { |
|||
method: Devise.ldap_method, |
|||
tls_options: OpenSSL::SSL::SSLContext::DEFAULT_PARAMS, |
|||
}, |
|||
auth: { |
|||
method: :simple, |
|||
username: Devise.ldap_bind_dn, |
|||
password: Devise.ldap_password, |
|||
}, |
|||
connect_timeout: 10 |
|||
) |
|||
module Devise |
|||
module Strategies |
|||
class LdapAuthenticatable < Authenticatable |
|||
def authenticate! |
|||
if params[:user] |
|||
ldap = Net::LDAP.new( |
|||
host: Devise.ldap_host, |
|||
port: Devise.ldap_port, |
|||
base: Devise.ldap_base, |
|||
encryption: { |
|||
method: Devise.ldap_method, |
|||
tls_options: tls_options, |
|||
}, |
|||
auth: { |
|||
method: :simple, |
|||
username: Devise.ldap_bind_dn, |
|||
password: Devise.ldap_password, |
|||
}, |
|||
connect_timeout: 10 |
|||
) |
|||
|
|||
if (user_info = ldap.bind_as(base: Devise.ldap_base, filter: "(#{Devise.ldap_uid}=#{email})", password: password)) |
|||
user = User.ldap_get_user(user_info.first) |
|||
success!(user) |
|||
else |
|||
return fail(:invalid_login) |
|||
end |
|||
if (user_info = ldap.bind_as(base: Devise.ldap_base, filter: "(#{Devise.ldap_uid}=#{email})", password: password)) |
|||
user = User.ldap_get_user(user_info.first) |
|||
success!(user) |
|||
else |
|||
return fail(:invalid_login) |
|||
end |
|||
end |
|||
end |
|||
|
|||
def email |
|||
params[:user][:email] |
|||
end |
|||
def email |
|||
params[:user][:email] |
|||
end |
|||
|
|||
def password |
|||
params[:user][:password] |
|||
def password |
|||
params[:user][:password] |
|||
end |
|||
|
|||
def tls_options |
|||
OpenSSL::SSL::SSLContext::DEFAULT_PARAMS.tap do |options| |
|||
options[:verify_mode] = OpenSSL::SSL::VERIFY_NONE if Devise.ldap_tls_no_verify |
|||
end |
|||
end |
|||
end |
|||
end |
|||
|
|||
Warden::Strategies.add(:ldap_authenticatable, Devise::Strategies::LdapAuthenticatable) |
|||
end |
|||
|
|||
Warden::Strategies.add(:ldap_authenticatable, Devise::Strategies::LdapAuthenticatable) |
|||
|
Loading…
Reference in new issue