Sha256: 6406c11590d9f8588288ae189466f6fa5eb6e717e55f19de11a27c4a76e3ed28

Contents?: true

Size: 1.11 KB

Versions: 9

Compression:

Stored size: 1.11 KB

Contents

module Devise
  module Strategies
    class TwoFactorAuthenticatable < Devise::Strategies::DatabaseAuthenticatable

      def authenticate!
        resource = mapping.to.find_for_database_authentication(authentication_hash)
        # We authenticate in two cases:
        # 1. The password and the OTP are correct
        # 2. The password is correct, and OTP is not required for login
        # We check the OTP, then defer to DatabaseAuthenticatable
        if validate(resource) { validate_otp(resource) }
          super
        end

        fail(:not_found_in_database) unless resource

        # We want to cascade to the next strategy if this one fails,
        # but database authenticatable automatically halts on a bad password
        @halted = false if @result == :failure
      end

      def validate_otp(resource)
        return true unless resource.otp_required_for_login
        return if params[scope]['otp_attempt'].nil?
        resource.validate_and_consume_otp!(params[scope]['otp_attempt'])
      end
    end
  end
end

Warden::Strategies.add(:two_factor_authenticatable, Devise::Strategies::TwoFactorAuthenticatable)

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
devise-two-factor-3.0.3 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-3.0.2 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-3.0.1 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-3.0.0 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-2.2.1 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-2.2.0 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-2.1.0 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-2.0.1 lib/devise_two_factor/strategies/two_factor_authenticatable.rb
devise-two-factor-2.0.0 lib/devise_two_factor/strategies/two_factor_authenticatable.rb