2019-09-23 22:35:36 -04:00
|
|
|
# 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
|
2024-04-29 08:32:06 -04:00
|
|
|
fail(:invalid) # rubocop:disable Style/SignalException -- method is from Warden::Strategies::Base
|
2019-09-23 22:35:36 -04:00
|
|
|
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)
|