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