aboutsummaryrefslogtreecommitdiffstats
path: root/app/controllers/action_mailbox/base_controller.rb
blob: d3846b06e16a749930ac764cc4964b53bc85f7f3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
class ActionMailbox::BaseController < ActionController::Base
  skip_forgery_protection

  private
    def authenticate
      if username.present? && password.present?
        http_basic_authenticate_or_request_with username: username, password: password, realm: "Action Mailbox"
      else
        raise ArgumentError, "Missing required ingress credentials"
      end
    end

    # TODO: Extract to ActionController::HttpAuthentication
    def http_basic_authenticate_or_request_with(username:, password:, realm: nil)
      authenticate_or_request_with_http_basic(realm || "Application") do |given_username, given_password|
        ActiveSupport::SecurityUtils.secure_compare(given_username, username) &
          ActiveSupport::SecurityUtils.secure_compare(given_password, password)
      end
    end
end