You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
1.9 KiB
76 lines
1.9 KiB
# frozen_string_literal: true |
|
|
|
class OAuthMetadataPresenter < ActiveModelSerializers::Model |
|
include RoutingHelper |
|
|
|
attributes :issuer, :authorization_endpoint, :token_endpoint, |
|
:revocation_endpoint, :scopes_supported, |
|
:response_types_supported, :response_modes_supported, |
|
:grant_types_supported, :token_endpoint_auth_methods_supported, |
|
:code_challenge_methods_supported, |
|
:service_documentation, :app_registration_endpoint |
|
|
|
def issuer |
|
root_url |
|
end |
|
|
|
def service_documentation |
|
'https://docs.joinmastodon.org/' |
|
end |
|
|
|
def authorization_endpoint |
|
oauth_authorization_url |
|
end |
|
|
|
def token_endpoint |
|
oauth_token_url |
|
end |
|
|
|
def userinfo_endpoint |
|
oauth_userinfo_url |
|
end |
|
|
|
# As the api_v1_apps route doesn't technically conform to the specification |
|
# for OAuth 2.0 Dynamic Client Registration defined in RFC 7591 we use a |
|
# non-standard property for now to indicate the mastodon specific registration |
|
# endpoint. See: https://datatracker.ietf.org/doc/html/rfc7591 |
|
def app_registration_endpoint |
|
api_v1_apps_url |
|
end |
|
|
|
def revocation_endpoint |
|
oauth_revoke_url |
|
end |
|
|
|
def scopes_supported |
|
doorkeeper.scopes |
|
end |
|
|
|
def response_types_supported |
|
doorkeeper.authorization_response_types |
|
end |
|
|
|
def response_modes_supported |
|
doorkeeper.authorization_response_flows.flat_map(&:response_mode_matches).uniq |
|
end |
|
|
|
def grant_types_supported |
|
grant_types_supported = doorkeeper.grant_flows.dup |
|
grant_types_supported << 'refresh_token' if doorkeeper.refresh_token_enabled? |
|
grant_types_supported |
|
end |
|
|
|
def token_endpoint_auth_methods_supported |
|
%w(client_secret_basic client_secret_post) |
|
end |
|
|
|
def code_challenge_methods_supported |
|
doorkeeper.pkce_code_challenge_methods_supported |
|
end |
|
|
|
private |
|
|
|
def doorkeeper |
|
@doorkeeper ||= Doorkeeper.configuration |
|
end |
|
end
|
|
|