2 class PermissionsController < ApplicationController
3 skip_before_action :verify_authenticity_token
4 before_action :api_deny_access_handler
6 authorize_resource :class => false
8 before_action :check_api_readable
9 before_action :setup_user_auth
10 around_action :api_call_handle_error, :api_call_timeout
12 # External apps that use the api are able to query which permissions
13 # they have. This currently returns a list of permissions granted to the current user:
14 # * if authenticated via OAuth, this list will contain all permissions granted by the user to the access_token.
15 # * if authenticated via basic auth all permissions are granted, so the list will contain all permissions.
16 # * unauthenticated users have no permissions, so the list will be empty.
18 @permissions = if current_token.present?
19 ClientApplication.all_permissions.select { |p| current_token.read_attribute(p) }
21 ClientApplication.all_permissions