module Doorkeeper::Helpers::Controller
def authenticate_admin!
def authenticate_admin! instance_eval(&Doorkeeper.config.authenticate_admin) end
def authenticate_resource_owner!
def authenticate_resource_owner! current_resource_owner end
def config_methods
def config_methods @config_methods ||= Doorkeeper.config.access_token_methods end
def current_resource_owner
def current_resource_owner return @current_resource_owner if defined?(@current_resource_owner) @current_resource_owner ||= begin instance_eval(&Doorkeeper.config.authenticate_resource_owner) end end
def doorkeeper_token
def doorkeeper_token return @doorkeeper_token if defined?(@doorkeeper_token) @doorkeeper_token ||= OAuth::Token.authenticate(request, *config_methods) end
def enforce_content_type
def enforce_content_type if (request.put? || request.post? || request.patch?) && !x_www_form_urlencoded? render json: {}, status: :unsupported_media_type end end
def get_error_response_from_exception(exception)
def get_error_response_from_exception(exception) if exception.respond_to?(:response) exception.response elsif exception.type == :invalid_request OAuth::InvalidRequestResponse.new( name: exception.type, state: params[:state], missing_param: exception.missing_param, ) else OAuth::ErrorResponse.new(name: exception.type, state: params[:state]) end end
def handle_token_exception(exception)
def handle_token_exception(exception) error = get_error_response_from_exception(exception) headers.merge!(error.headers) self.response_body = error.body.to_json self.status = error.status end
def resource_owner_from_credentials
def resource_owner_from_credentials instance_eval(&Doorkeeper.config.resource_owner_from_credentials) end
def server
def server @server ||= Server.new(self) end
def skip_authorization?
def skip_authorization? !!instance_exec( [server.current_resource_owner, @pre_auth.client], &Doorkeeper.config.skip_authorization ) end
def x_www_form_urlencoded?
def x_www_form_urlencoded? request.media_type == "application/x-www-form-urlencoded" end