class Devise::Strategies::LdapAuthenticatable
Defines an authentication strategy to be used with Warden Some more information about this here: www.rubydoc.info/github/hassox/warden/Warden/Strategies/Base
Public Instance Methods
authenticate!()
click to toggle source
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.
# File lib/devise_ldap_multiple/strategy.rb, line 16 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