Sha256: 2b1dda7d91d07a4c9a8de0ee6297447ec376a874805d98e4eee6dd43d1627e88

Contents?: true

Size: 845 Bytes

Versions: 3

Compression:

Stored size: 845 Bytes

Contents

require 'devise/strategies/authenticatable'

module Devise
  module Strategies
    # Default strategy for signing in a user, based on their email and password in the database.
    class DatabaseAuthenticatable < Authenticatable
      def authenticate!
        resource  = valid_password? && mapping.to.find_for_database_authentication(authentication_hash)
        encrypted = false

        if validate(resource){ encrypted = true; resource.valid_password?(password) }
          remember_me(resource)
          resource.after_database_authentication
          success!(resource)
        end

        mapping.to.new.password = password if !encrypted && Devise.paranoid
        fail(:not_found_in_database) unless resource
      end
    end
  end
end

Warden::Strategies.add(:database_authenticatable, Devise::Strategies::DatabaseAuthenticatable)

Version data entries

3 entries across 3 versions & 2 rubygems

Version Path
deviseOne-1.0.0 lib/devise/strategies/database_authenticatable.rb
devise-3.4.1 lib/devise/strategies/database_authenticatable.rb
devise-3.4.0 lib/devise/strategies/database_authenticatable.rb