Sha256: 2f838a3f78ffd65a9a6e7acdf38a3893c0145abc8e044458b0d2b90d0490620c
Contents?: true
Size: 1.49 KB
Versions: 5
Compression:
Stored size: 1.49 KB
Contents
# frozen_string_literal: true module Auther # Manages account authentication. class Authenticator # rubocop:disable Metrics/ParameterLists def initialize secret, account_model, account_presenter, logger: Auther::NullLogger.new(STDOUT) @cipher = Auther::Cipher.new secret @account_model = account_model @account_presenter = account_presenter @logger = logger end def authenticated? account_model.valid? && account_presenter.valid? && authentic_name? && authentic_login? && authentic_password? end private attr_reader :cipher, :account_model, :account_presenter, :logger def log_info message id = "[#{Auther::Keymaster.namespace}]" logger.info [id, message].join(": ") end def authentic? encrypted_value, value, error_name if cipher.decrypt(encrypted_value) == value true else account_presenter.errors.add error_name, "is invalid" false end rescue ActiveSupport::MessageVerifier::InvalidSignature log_info %(Authentication failed! Invalid credential(s) for "#{account_model.name}" account.) false end def authentic_name? account_presenter.name == account_model.name end def authentic_login? authentic? account_model.encrypted_login, account_presenter.login, "login" end def authentic_password? authentic? account_model.encrypted_password, account_presenter.password, "password" end end end
Version data entries
5 entries across 5 versions & 1 rubygems