mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-18 17:42:54 +05:30
60 lines
1.5 KiB
Markdown
Executable File
60 lines
1.5 KiB
Markdown
Executable File
---
|
|
layout: default
|
|
title: Authorization server with client credentials grant
|
|
permalink: /authorization-server/client-credentials-grant/
|
|
---
|
|
|
|
# Authorization server with client credentials grant
|
|
|
|
## Setup
|
|
|
|
Wherever you intialise your objects, initialize a new instance of the authorization server and bind the storage interfaces and authorization code grant:
|
|
|
|
~~~ php
|
|
$server = new \League\OAuth2\Server\AuthorizationServer;
|
|
|
|
$server->setSessionStorage(new Storage\SessionStorage);
|
|
$server->setAccessTokenStorage(new Storage\AccessTokenStorage);
|
|
$server->setClientStorage(new Storage\ClientStorage);
|
|
$server->setScopeStorage(new Storage\ScopeStorage);
|
|
|
|
$clientCredentials = new \League\OAuth2\Server\Grant\ClientCredentialsGrant();
|
|
$server->addGrantType($clientCredentials);
|
|
~~~
|
|
|
|
## Implementation
|
|
|
|
The client will request an access token so create an `/access_token` endpoint.
|
|
|
|
~~~ php
|
|
$router->post('/access_token', function (Request $request) use ($server) {
|
|
|
|
try {
|
|
|
|
$response = $server->issueAccessToken();
|
|
return new Response(
|
|
json_encode($response),
|
|
200,
|
|
[
|
|
'Content-type' => 'application/json',
|
|
'Cache-Control' => 'no-store',
|
|
'Pragma' => 'no-store'
|
|
]
|
|
);
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
return new Response(
|
|
json_encode([
|
|
'error' => $e->errorType,
|
|
'message' => $e->getMessage()
|
|
]),
|
|
$e->httpStatusCode,
|
|
$e->getHttpHeaders()
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
~~~
|