devise_token_auth LDAP(活动目录)不起作用

时间:2019-05-28 17:30:13

标签: devise-token-auth

我只是无法配置用户从Active Directory登录。 我尝试了在Google中找到的几乎所有内容。 目前,得出的结论是有必要编辑控制器

File 'app/controllers/devise_token_auth/sessions_controller.rb'

能否请您告诉我如何重写代码块,以便在尝试登录失败后,能够检查Active Directory中的用户,如果该用户存在,则将其添加到数据库中并登录吗?

我使用以下功能:

class ActiveDirectoryUser
  SERVER = '192.168.xx.xx'
  PORT = 389
  BASE = 'ou=OFFICE,dc=aaa,dc=loc'
  DOMAIN = 'aaa.loc'

  def self.authenticate(login, pass)
    conn = Net::LDAP.new :host => SERVER,
                         :port => PORT,
                         :base => BASE,
                         :auth => { :username => "#{login}@#{DOMAIN}",
                                    :password => pass,
                                    :method => :simple }
    if  conn.bind
        conn.search(
        :base => BASE, :filter => Net::LDAP::Filter.eq(
"sAMAccountName", login ),
        :attributes => %w[ givenName ], :return_result => true) do
|entry|
        #puts "givenName: #{entry.givenName}"
        $username = entry.givenName.first
        end
        return true

    else
      return false
    end
  rescue Net::LDAP::LdapError => e
    return false
  end
end

0 个答案:

没有答案