2015-04-05 18:18:28 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
use League\OAuth2\Server\Exception\OAuthException;
|
|
|
|
use League\OAuth2\Server\Server;
|
|
|
|
use OAuth2ServerExamples\Repositories\AccessTokenRepository;
|
|
|
|
use OAuth2ServerExamples\Repositories\ClientRepository;
|
|
|
|
use OAuth2ServerExamples\Repositories\ScopeRepository;
|
|
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
|
|
|
|
|
|
include(__DIR__ . '/../vendor/autoload.php');
|
|
|
|
|
|
|
|
// Setup the authorization server
|
|
|
|
$server = new Server();
|
|
|
|
$server->addRepository(new ClientRepository());
|
|
|
|
$server->addRepository(new ScopeRepository());
|
|
|
|
$server->addRepository(new AccessTokenRepository());
|
|
|
|
|
|
|
|
// Enable the client credentials grant which will return access tokens that last for 24 hours
|
|
|
|
$server->enableGrantType('ClientCredentialsGrant', null, new \DateInterval('PT24H'));
|
|
|
|
|
2015-04-05 18:42:24 +01:00
|
|
|
// Setup app + routing
|
2015-04-05 18:18:28 +01:00
|
|
|
$application = new \Proton\Application();
|
|
|
|
$application->post('/access_token', function (Request $request) use ($server) {
|
|
|
|
try {
|
|
|
|
return $server->getAccessTokenResponse($request);
|
|
|
|
} catch (OAuthException $e) {
|
|
|
|
return $e->generateHttpResponse();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Run the app
|
|
|
|
$application->run();
|