You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
32 lines
741 B
32 lines
741 B
# frozen_string_literal: true |
|
|
|
require 'net/ldap' |
|
require 'devise/strategies/base' |
|
|
|
module Devise |
|
module Strategies |
|
class TwoFactorLdapAuthenticatable < Base |
|
def valid? |
|
valid_params? && mapping.to.respond_to?(:authenticate_with_ldap) |
|
end |
|
|
|
def authenticate! |
|
resource = mapping.to.authenticate_with_ldap(params[scope]) |
|
|
|
if resource && !resource.otp_required_for_login? |
|
success!(resource) |
|
else |
|
fail(:invalid) |
|
end |
|
end |
|
|
|
protected |
|
|
|
def valid_params? |
|
params[scope] && params[scope][:password].present? |
|
end |
|
end |
|
end |
|
end |
|
|
|
Warden::Strategies.add(:two_factor_ldap_authenticatable, Devise::Strategies::TwoFactorLdapAuthenticatable)
|
|
|