From 053851a52ae1a05ec921c39e71a3f06f02dae00e Mon Sep 17 00:00:00 2001 From: Andrew Millington Date: Sat, 23 Dec 2017 15:47:51 +0000 Subject: [PATCH] Create auth-server.md Initial draft of a page detailing the AuthorizationServer class for the docs --- auth-server.md | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 auth-server.md diff --git a/auth-server.md b/auth-server.md new file mode 100644 index 00000000..d4881de8 --- /dev/null +++ b/auth-server.md @@ -0,0 +1,33 @@ +--- +layout: default +title: The Authorization Server +permalink: /authorization-server/index +--- + +# The Authorization Server + +The Authorization server accepts authorization requests from a client and if validated, issues an access token and refresh tokens if applicable. + +## enableGrantType() :null|DateInterval + +By default, an instantiated AuthorizationServer will not accept any grant types. To add a grant type, call the `enableGrantType` method, passing it a `GrantTypeInterface` for the grant tht should be enabled and an optional DateInterval, specifying the default time to live for any access tokens issued by the grant type. + +## validateAuthorizationRequest() : AuthorizationRequest + +This function is used to validate an incoming authorization requests. It checks to ensure that a user has authorized a client to access their protected resources. If the authorization check passes, the server will issue an instance of `AuthorizationRequest`, which can be used with the `completeAuthorizationRequest()` method. This method is used by the Authorization Code Grant and the Implicit Grant. + +## completeAuthorizationRequest() : ResponseInterface + +To complete... + +## respondToAccessTokenRequest() : ResponseInterface + +This method is used to respond to a request for an access token. It will validate the client and authorization code received as part of the request, and if successful, issue an access token to the client. + +## getResponseType() : ResponseTypeInterface + +Used to get the response type that grants will return. The response type must be an implementation of the `ResponseTypeInterface`. If it is not, a default `BearerTokenResponse` is issued. + +## setDefaultScope() : null + +When the Authorization Server is first instantiated, it has no default scope set. If the server receieves an authorization request that does not specify any scope, it will reject the request by issuing an invalid scope response. If a default scope is set using this method, authorization requests without a scope will be assigned the default scope set for the server.