class Devise::Strategies::LdapAuthenticatable

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_authenticatable/strategy.rb, line 12
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