mirror of
https://github.com/salesagility/SuiteCRM.git
synced 2024-11-24 08:36:48 +00:00
126 lines
3.5 KiB
PHP
126 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace Api\V8\OAuth2\Repository;
|
|
|
|
use Api\V8\BeanDecorator\BeanManager;
|
|
use Api\V8\OAuth2\Entity\AccessTokenEntity;
|
|
use DateTime;
|
|
use InvalidArgumentException;
|
|
use League\OAuth2\Server\Entities\AccessTokenEntityInterface;
|
|
use League\OAuth2\Server\Entities\ClientEntityInterface;
|
|
use League\OAuth2\Server\Repositories\AccessTokenRepositoryInterface;
|
|
use OAuth2Tokens;
|
|
use User;
|
|
|
|
#[\AllowDynamicProperties]
|
|
class AccessTokenRepository implements AccessTokenRepositoryInterface
|
|
{
|
|
/**
|
|
* @var AccessTokenEntity
|
|
*/
|
|
private $accessTokenEntity;
|
|
|
|
/**
|
|
* @var BeanManager
|
|
*/
|
|
private $beanManager;
|
|
|
|
/**
|
|
* @param AccessTokenEntity $accessTokenEntity
|
|
* @param BeanManager $beanManager
|
|
*/
|
|
public function __construct(AccessTokenEntity $accessTokenEntity, BeanManager $beanManager)
|
|
{
|
|
$this->accessTokenEntity = $accessTokenEntity;
|
|
$this->beanManager = $beanManager;
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function getNewToken(ClientEntityInterface $clientEntity, array $scopes, $userIdentifier = null)
|
|
{
|
|
$this->accessTokenEntity->setClient($clientEntity);
|
|
|
|
// we keep this even we don't have scopes atm
|
|
foreach ($scopes as $scope) {
|
|
$this->accessTokenEntity->addScope($scope);
|
|
}
|
|
|
|
$this->accessTokenEntity->setUserIdentifier($userIdentifier);
|
|
|
|
return $this->accessTokenEntity;
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function persistNewAccessToken(AccessTokenEntityInterface $accessTokenEntity)
|
|
{
|
|
$clientId = $accessTokenEntity->getClient()->getIdentifier();
|
|
$userId = null;
|
|
|
|
/** @var User $user */
|
|
$client = $this->beanManager->getBeanSafe('OAuth2Clients', $clientId);
|
|
|
|
switch ($client->allowed_grant_type) {
|
|
case 'password':
|
|
$userId = $accessTokenEntity->getUserIdentifier();
|
|
break;
|
|
case 'client_credentials':
|
|
$userId = $client->assigned_user_id;
|
|
break;
|
|
}
|
|
|
|
if ($userId === null) {
|
|
throw new InvalidArgumentException('No user found');
|
|
}
|
|
|
|
/** @var OAuth2Tokens $token */
|
|
$token = $this->beanManager->newBeanSafe(OAuth2Tokens::class);
|
|
|
|
$token->access_token = $accessTokenEntity->getIdentifier();
|
|
|
|
$token->access_token_expires = $accessTokenEntity->getExpiryDateTime()->format('Y-m-d H:i:s');
|
|
|
|
$token->client = $clientId;
|
|
|
|
$token->assigned_user_id = $userId;
|
|
|
|
$token->save();
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*
|
|
* @throws InvalidArgumentException When access token is not found.
|
|
*/
|
|
public function revokeAccessToken($tokenId)
|
|
{
|
|
$token = $this->beanManager->newBeanSafe(OAuth2Tokens::class);
|
|
$token->retrieve_by_string_fields(
|
|
['access_token' => $tokenId]
|
|
);
|
|
|
|
if ($token->id === null) {
|
|
throw new InvalidArgumentException('Access token is not found for this client');
|
|
}
|
|
|
|
$token->mark_deleted($token->id);
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function isAccessTokenRevoked($tokenId)
|
|
{
|
|
/** @var OAuth2Tokens $token */
|
|
$token = $this->beanManager->newBeanSafe(OAuth2Tokens::class);
|
|
$token->retrieve_by_string_fields(
|
|
['access_token' => $tokenId]
|
|
);
|
|
|
|
return $token->id === null || $token->token_is_revoked === '1' || new DateTime() > new DateTime($token->access_token_expires);
|
|
}
|
|
}
|