X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/951564eed1c82ec1a435f4e4636db86d1b7604fc..7f619c6484ae92d6ea12f1c3a9f67c3d421ae06a:/app/controllers/api/permissions_controller.rb diff --git a/app/controllers/api/permissions_controller.rb b/app/controllers/api/permissions_controller.rb index 9b168e04b..8c0c949dc 100644 --- a/app/controllers/api/permissions_controller.rb +++ b/app/controllers/api/permissions_controller.rb @@ -1,9 +1,11 @@ module Api class PermissionsController < ApiController + before_action :check_api_readable + authorize_resource :class => false - before_action :check_api_readable before_action :setup_user_auth + before_action :set_request_formats around_action :api_call_handle_error, :api_call_timeout # External apps that use the api are able to query which permissions @@ -12,13 +14,20 @@ module Api # * 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? + @permissions = if doorkeeper_token.present? + doorkeeper_token.scopes.map { |s| :"allow_#{s}" } + elsif current_token.present? ClientApplication.all_permissions.select { |p| current_token.read_attribute(p) } elsif current_user ClientApplication.all_permissions else [] end + + respond_to do |format| + format.xml + format.json + end end end end