Sha256: 013ad76af4b664638807a79105d8af54f10d3f95d2c60c7ea32cb134d565b74e
Contents?: true
Size: 1.35 KB
Versions: 3
Compression:
Stored size: 1.35 KB
Contents
require 'devise/strategies/authenticatable' module Devise module Strategies class LdapAuthenticatable < Authenticatable # Tests whether the returned resource exists in the database and the # credentials are valid. If the resource is in the database and the credentials # are valid, the user is authenticated. Otherwise failure messages are returned # indicating whether the resource is not found in the database or the credentials # are invalid. def authenticate! resource = mapping.to.find_for_ldap_authentication(authentication_hash.merge(password: password)) return fail(:invalid) unless resource if resource.persisted? if validate(resource) { resource.valid_ldap_authentication?(password) } remember_me(resource) resource.after_ldap_authentication success!(resource) else return fail(:invalid) # Invalid credentials end end if resource.new_record? if validate(resource) { resource.valid_ldap_authentication?(password) } return fail(:not_found_in_database) # Valid credentials else return fail(:invalid) # Invalid credentials end end end end end end Warden::Strategies.add(:ldap_authenticatable, Devise::Strategies::LdapAuthenticatable)
Version data entries
3 entries across 3 versions & 2 rubygems