2018-02-28 19:04:53 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-20 19:41:51 +01:00
|
|
|
require 'net/ldap'
|
|
|
|
require 'devise/strategies/authenticatable'
|
2018-02-28 19:04:53 +01:00
|
|
|
|
2018-03-20 19:41:51 +01:00
|
|
|
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
|
|
|
|
)
|
2018-02-28 19:04:53 +01:00
|
|
|
|
2018-08-15 18:12:44 +02:00
|
|
|
filter = format(Devise.ldap_search_filter, uid: Devise.ldap_uid, email: email)
|
2018-09-01 03:35:37 +02:00
|
|
|
|
2018-08-15 18:12:44 +02:00
|
|
|
if (user_info = ldap.bind_as(base: Devise.ldap_base, filter: filter, password: password))
|
2018-03-20 19:41:51 +01:00
|
|
|
user = User.ldap_get_user(user_info.first)
|
|
|
|
success!(user)
|
|
|
|
else
|
2018-09-01 03:35:37 +02:00
|
|
|
return fail(:invalid)
|
2018-02-28 19:04:53 +01:00
|
|
|
end
|
|
|
|
end
|
2018-03-20 19:41:51 +01:00
|
|
|
end
|
2018-02-28 19:04:53 +01:00
|
|
|
|
2018-03-20 19:41:51 +01:00
|
|
|
def email
|
|
|
|
params[:user][:email]
|
|
|
|
end
|
2018-02-28 19:04:53 +01:00
|
|
|
|
2018-03-20 19:41:51 +01:00
|
|
|
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
|
2018-02-28 19:04:53 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-20 19:41:51 +01:00
|
|
|
|
|
|
|
Warden::Strategies.add(:ldap_authenticatable, Devise::Strategies::LdapAuthenticatable)
|