X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/8383fd0928a3a431dc58c48d42bf1d19bc43ea34..db3debdd9e5dd09717a7ed144b34158619c85e08:/app/controllers/api/permissions_controller.rb diff --git a/app/controllers/api/permissions_controller.rb b/app/controllers/api/permissions_controller.rb index b24aca776..75bfe6b10 100644 --- a/app/controllers/api/permissions_controller.rb +++ b/app/controllers/api/permissions_controller.rb @@ -1,27 +1,25 @@ 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