module Api
- class PermissionsController < ApplicationController
- skip_before_action :verify_authenticity_token
- before_action :api_deny_access_handler
-
+ class PermissionsController < ApiController
authorize_resource :class => false
- before_action :check_api_readable
before_action :setup_user_auth
- around_action :api_call_handle_error, :api_call_timeout
+ before_action :set_request_formats
# External apps that use the api are able to query which permissions
# they have. This currently returns a list of permissions granted to the current user:
# * if authenticated via OAuth, this list will contain all permissions granted by the user to the access_token.
- # * if authenticated via basic auth all permissions are granted, so the list will contain all permissions.
# * unauthenticated users have no permissions, so the list will be empty.
def show
- @permissions = if current_token.present?
- ClientApplication.all_permissions.select { |p| current_token.read_attribute(p) }
- elsif current_user
- ClientApplication.all_permissions
+ @permissions = if doorkeeper_token.present?
+ doorkeeper_token.scopes.map { |s| :"allow_#{s}" }
else
[]
end
+
+ respond_to do |format|
+ format.xml
+ format.json
+ end
end
end
end