2016-04-17 12:33:29 +01:00
|
|
|
<?php
|
2016-04-17 13:06:05 +01:00
|
|
|
/**
|
|
|
|
* @author Alex Bilbie <hello@alexbilbie.com>
|
|
|
|
* @copyright Copyright (c) Alex Bilbie
|
|
|
|
* @license http://mit-license.org/
|
|
|
|
*
|
|
|
|
* @link https://github.com/thephpleague/oauth2-server
|
|
|
|
*/
|
2016-07-09 01:00:44 +02:00
|
|
|
|
2016-04-17 12:33:29 +01:00
|
|
|
namespace League\OAuth2\Server;
|
|
|
|
|
|
|
|
use League\OAuth2\Server\AuthorizationValidators\AuthorizationValidatorInterface;
|
|
|
|
use League\OAuth2\Server\AuthorizationValidators\BearerTokenValidator;
|
2016-07-09 01:00:44 +02:00
|
|
|
use League\OAuth2\Server\Exception\OAuthServerException;
|
2016-04-17 12:33:29 +01:00
|
|
|
use League\OAuth2\Server\Repositories\AccessTokenRepositoryInterface;
|
|
|
|
use Psr\Http\Message\ServerRequestInterface;
|
|
|
|
|
|
|
|
class ResourceServer
|
|
|
|
{
|
|
|
|
/**
|
2016-07-09 01:00:44 +02:00
|
|
|
* @var AccessTokenRepositoryInterface
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
private $accessTokenRepository;
|
2016-07-09 01:00:44 +02:00
|
|
|
|
2016-04-17 12:33:29 +01:00
|
|
|
/**
|
2016-07-09 01:00:44 +02:00
|
|
|
* @var CryptKey
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
private $publicKey;
|
2016-07-09 01:00:44 +02:00
|
|
|
|
2016-04-17 12:33:29 +01:00
|
|
|
/**
|
2016-07-09 01:00:44 +02:00
|
|
|
* @var null|AuthorizationValidatorInterface
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
private $authorizationValidator;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* New server instance.
|
|
|
|
*
|
2016-07-09 01:00:44 +02:00
|
|
|
* @param AccessTokenRepositoryInterface $accessTokenRepository
|
|
|
|
* @param CryptKey|string $publicKey
|
|
|
|
* @param null|AuthorizationValidatorInterface $authorizationValidator
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
public function __construct(
|
|
|
|
AccessTokenRepositoryInterface $accessTokenRepository,
|
|
|
|
$publicKey,
|
|
|
|
AuthorizationValidatorInterface $authorizationValidator = null
|
|
|
|
) {
|
|
|
|
$this->accessTokenRepository = $accessTokenRepository;
|
|
|
|
|
2016-07-09 12:09:21 +02:00
|
|
|
if ($publicKey instanceof CryptKey === false) {
|
2016-04-17 12:33:29 +01:00
|
|
|
$publicKey = new CryptKey($publicKey);
|
|
|
|
}
|
|
|
|
$this->publicKey = $publicKey;
|
|
|
|
|
|
|
|
$this->authorizationValidator = $authorizationValidator;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-07-09 01:00:44 +02:00
|
|
|
* @return AuthorizationValidatorInterface
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
protected function getAuthorizationValidator()
|
|
|
|
{
|
2016-07-09 12:09:21 +02:00
|
|
|
if ($this->authorizationValidator instanceof AuthorizationValidatorInterface === false) {
|
2016-04-17 12:33:29 +01:00
|
|
|
$this->authorizationValidator = new BearerTokenValidator($this->accessTokenRepository);
|
|
|
|
}
|
|
|
|
|
2018-02-11 21:51:47 +01:00
|
|
|
if ($this->authorizationValidator instanceof BearerTokenValidator === true) {
|
|
|
|
$this->authorizationValidator->setPublicKey($this->publicKey);
|
|
|
|
}
|
2016-04-17 12:33:29 +01:00
|
|
|
|
|
|
|
return $this->authorizationValidator;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine the access token validity.
|
|
|
|
*
|
2016-07-09 01:00:44 +02:00
|
|
|
* @param ServerRequestInterface $request
|
2016-04-17 12:33:29 +01:00
|
|
|
*
|
2016-07-09 01:00:44 +02:00
|
|
|
* @throws OAuthServerException
|
2016-04-17 12:33:29 +01:00
|
|
|
*
|
2016-07-09 01:00:44 +02:00
|
|
|
* @return ServerRequestInterface
|
2016-04-17 12:33:29 +01:00
|
|
|
*/
|
|
|
|
public function validateAuthenticatedRequest(ServerRequestInterface $request)
|
|
|
|
{
|
|
|
|
return $this->getAuthorizationValidator()->validateAuthorization($request);
|
|
|
|
}
|
|
|
|
}
|