534acfbf96
Co-authored-by: Pranav Raj S <pranav@chatwoot.com>
23 lines
734 B
Ruby
23 lines
734 B
Ruby
class Api::BaseController < ApplicationController
|
|
include AccessTokenAuthHelper
|
|
respond_to :json
|
|
before_action :authenticate_access_token!, if: :authenticate_by_access_token?
|
|
before_action :validate_bot_access_token!, if: :authenticate_by_access_token?
|
|
before_action :authenticate_user!, unless: :authenticate_by_access_token?
|
|
|
|
private
|
|
|
|
def authenticate_by_access_token?
|
|
request.headers[:api_access_token].present? || request.headers[:HTTP_API_ACCESS_TOKEN].present?
|
|
end
|
|
|
|
def check_authorization(model = nil)
|
|
model ||= controller_name.classify.constantize
|
|
|
|
authorize(model)
|
|
end
|
|
|
|
def check_admin_authorization?
|
|
raise Pundit::NotAuthorizedError unless Current.account_user.administrator?
|
|
end
|
|
end
|