2015-04-05 17:03:06 +01:00
|
|
|
<?php
|
|
|
|
namespace League\OAuth2\Server;
|
|
|
|
|
|
|
|
use DateInterval;
|
2015-04-05 21:14:22 +01:00
|
|
|
use League\OAuth2\Server\TokenTypes\BearerTokenType;
|
|
|
|
use League\OAuth2\Server\TokenTypes\TokenTypeInterface;
|
2015-04-05 17:03:06 +01:00
|
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
|
|
|
|
|
|
class Server extends AbstractServer
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var \League\OAuth2\Server\Grant\GrantTypeInterface[]
|
|
|
|
*/
|
|
|
|
protected $enabledGrantTypes = [];
|
|
|
|
|
|
|
|
/**
|
2015-04-05 21:14:22 +01:00
|
|
|
* @var TokenTypeInterface[]
|
2015-04-05 17:03:06 +01:00
|
|
|
*/
|
2015-04-05 21:14:22 +01:00
|
|
|
protected $grantTypeTokenTypes = [];
|
2015-04-05 17:03:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var DateInterval[]
|
|
|
|
*/
|
|
|
|
protected $grantTypeAccessTokenTTL = [];
|
|
|
|
|
|
|
|
/**
|
2015-04-05 21:14:22 +01:00
|
|
|
* @var TokenTypeInterface
|
2015-04-05 17:03:06 +01:00
|
|
|
*/
|
2015-04-06 08:23:18 +01:00
|
|
|
protected $defaultTokenType;
|
2015-04-05 17:03:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var DateInterval
|
|
|
|
*/
|
|
|
|
protected $defaultAccessTokenTTL;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $scopeDelimiter = ' ';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New server instance
|
|
|
|
*
|
2015-04-06 08:23:18 +01:00
|
|
|
* @param TokenTypeInterface $defaultTokenType
|
|
|
|
* @param DateInterval $defaultAccessTokenTTL
|
2015-04-05 17:03:06 +01:00
|
|
|
*/
|
|
|
|
public function __construct(
|
2015-04-06 08:23:18 +01:00
|
|
|
TokenTypeInterface $defaultTokenType = null,
|
2015-04-05 17:03:06 +01:00
|
|
|
DateInterval $defaultAccessTokenTTL = null
|
|
|
|
) {
|
2015-04-06 08:23:18 +01:00
|
|
|
$this->defaultResponseType = ($defaultTokenType instanceof TokenTypeInterface)
|
|
|
|
? $defaultTokenType
|
2015-04-05 21:14:22 +01:00
|
|
|
: new BearerTokenType();
|
2015-04-05 17:03:06 +01:00
|
|
|
|
|
|
|
$this->defaultAccessTokenTTL = ($defaultAccessTokenTTL instanceof DateInterval)
|
|
|
|
? $defaultAccessTokenTTL
|
|
|
|
: new DateInterval('PT01H'); // default of 1 hour
|
|
|
|
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-04-06 08:23:18 +01:00
|
|
|
* @param string $grantType
|
2015-04-05 21:14:22 +01:00
|
|
|
* @param TokenTypeInterface $tokenType
|
2015-04-06 08:23:18 +01:00
|
|
|
* @param DateInterval $accessTokenTTL
|
2015-04-05 17:03:06 +01:00
|
|
|
*
|
|
|
|
* @throws \Exception
|
|
|
|
*/
|
|
|
|
public function enableGrantType(
|
|
|
|
$grantType,
|
2015-04-05 21:14:22 +01:00
|
|
|
TokenTypeInterface $tokenType = null,
|
2015-04-05 17:03:06 +01:00
|
|
|
DateInterval $accessTokenTTL = null
|
|
|
|
) {
|
|
|
|
if ($this->getContainer()->isInServiceProvider($grantType)) {
|
|
|
|
$grant = $this->getContainer()->get($grantType);
|
|
|
|
$grantIdentifier = $grant->getIdentifier();
|
|
|
|
$this->enabledGrantTypes[$grantIdentifier] = $grant;
|
|
|
|
} else {
|
2015-04-06 08:23:24 +01:00
|
|
|
throw new \Exception('Unregistered grant type'); // @TODO fix
|
2015-04-05 17:03:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Set grant response type
|
2015-04-05 21:14:22 +01:00
|
|
|
if ($tokenType instanceof TokenTypeInterface) {
|
|
|
|
$this->grantTypeTokenTypes[$grantIdentifier] = $tokenType;
|
2015-04-05 17:03:06 +01:00
|
|
|
} else {
|
2015-04-05 21:14:22 +01:00
|
|
|
$this->grantTypeTokenTypes[$grantIdentifier] = $this->defaultResponseType;
|
2015-04-05 17:03:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Set grant access token TTL
|
|
|
|
if ($accessTokenTTL instanceof DateInterval) {
|
|
|
|
$this->grantTypeAccessTokenTTL[$grantIdentifier] = $accessTokenTTL;
|
|
|
|
} else {
|
|
|
|
$this->grantTypeAccessTokenTTL[$grantIdentifier] = $this->defaultAccessTokenTTL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return an access token response
|
|
|
|
*
|
|
|
|
* @param \Symfony\Component\HttpFoundation\Request $request
|
|
|
|
*
|
2015-04-05 21:14:22 +01:00
|
|
|
* @return TokenTypeInterface
|
2015-04-05 17:03:06 +01:00
|
|
|
* @throws \Exception
|
|
|
|
*/
|
|
|
|
public function getAccessTokenResponse(Request $request = null)
|
|
|
|
{
|
|
|
|
if ($request === null) {
|
|
|
|
$request = Request::createFromGlobals();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Run the requested grant type
|
|
|
|
$grantType = $request->request->get('grant_type', null);
|
|
|
|
|
|
|
|
if ($grantType === null || !isset($this->enabledGrantTypes[$grantType])) {
|
2015-04-05 21:14:22 +01:00
|
|
|
throw new Exception\InvalidGrantException($grantType);
|
2015-04-05 17:03:06 +01:00
|
|
|
}
|
|
|
|
|
2015-04-05 21:14:22 +01:00
|
|
|
$tokenType = $this->enabledGrantTypes[$grantType]->getAccessTokenAsType(
|
2015-04-05 17:03:06 +01:00
|
|
|
$request,
|
2015-04-05 21:14:22 +01:00
|
|
|
$this->grantTypeTokenTypes[$grantType],
|
2015-04-05 17:03:06 +01:00
|
|
|
$this->grantTypeAccessTokenTTL[$grantType],
|
|
|
|
$this->scopeDelimiter
|
|
|
|
);
|
|
|
|
|
2015-04-05 21:14:22 +01:00
|
|
|
return $tokenType->generateHttpResponse();
|
2015-04-05 17:03:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the delimiter used to separate scopes in a request
|
|
|
|
*
|
|
|
|
* @param string $scopeDelimiter
|
|
|
|
*/
|
|
|
|
public function setScopeDelimiter($scopeDelimiter)
|
|
|
|
{
|
|
|
|
$this->scopeDelimiter = $scopeDelimiter;
|
|
|
|
}
|
|
|
|
}
|