2016-02-14 20:50:10 +03:00
|
|
|
<?php
|
2016-11-27 00:43:42 +03:00
|
|
|
namespace api\components\OAuth2\Storage;
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2016-11-27 00:43:42 +03:00
|
|
|
use api\components\OAuth2\Entities\AccessTokenEntity;
|
2016-11-30 02:19:14 +03:00
|
|
|
use common\components\Redis\Key;
|
|
|
|
use common\components\Redis\Set;
|
2016-02-14 20:50:10 +03:00
|
|
|
use League\OAuth2\Server\Entity\AccessTokenEntity as OriginalAccessTokenEntity;
|
|
|
|
use League\OAuth2\Server\Entity\ScopeEntity;
|
|
|
|
use League\OAuth2\Server\Storage\AbstractStorage;
|
|
|
|
use League\OAuth2\Server\Storage\AccessTokenInterface;
|
2016-11-30 02:19:14 +03:00
|
|
|
use yii\helpers\Json;
|
2016-02-14 20:50:10 +03:00
|
|
|
|
|
|
|
class AccessTokenStorage extends AbstractStorage implements AccessTokenInterface {
|
|
|
|
|
2016-11-30 02:19:14 +03:00
|
|
|
public $dataTable = 'oauth_access_tokens';
|
2016-02-14 20:50:10 +03:00
|
|
|
|
|
|
|
public function get($token) {
|
2016-11-30 02:19:14 +03:00
|
|
|
$result = Json::decode((new Key($this->dataTable, $token))->getValue());
|
2017-08-07 14:05:42 +03:00
|
|
|
if ($result === null) {
|
|
|
|
return null;
|
|
|
|
}
|
2016-11-27 00:43:42 +03:00
|
|
|
|
|
|
|
$token = new AccessTokenEntity($this->server);
|
2016-11-30 02:19:14 +03:00
|
|
|
$token->setId($result['id']);
|
|
|
|
$token->setExpireTime($result['expire_time']);
|
|
|
|
$token->setSessionId($result['session_id']);
|
2016-11-27 00:43:42 +03:00
|
|
|
|
|
|
|
return $token;
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getScopes(OriginalAccessTokenEntity $token) {
|
2016-11-30 02:19:14 +03:00
|
|
|
$scopes = $this->scopes($token->getId());
|
2016-02-14 20:50:10 +03:00
|
|
|
$entities = [];
|
2018-04-17 23:47:25 +03:00
|
|
|
foreach ($scopes as $scope) {
|
2016-11-30 02:19:14 +03:00
|
|
|
if ($this->server->getScopeStorage()->get($scope) !== null) {
|
|
|
|
$entities[] = (new ScopeEntity($this->server))->hydrate(['id' => $scope]);
|
|
|
|
}
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return $entities;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function create($token, $expireTime, $sessionId) {
|
2016-11-30 02:19:14 +03:00
|
|
|
$payload = Json::encode([
|
|
|
|
'id' => $token,
|
|
|
|
'expire_time' => $expireTime,
|
|
|
|
'session_id' => $sessionId,
|
|
|
|
]);
|
2016-02-14 20:50:10 +03:00
|
|
|
|
2016-11-30 02:19:14 +03:00
|
|
|
$this->key($token)->setValue($payload)->expireAt($expireTime);
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function associateScope(OriginalAccessTokenEntity $token, ScopeEntity $scope) {
|
2016-11-30 02:19:14 +03:00
|
|
|
$this->scopes($token->getId())->add($scope->getId())->expireAt($token->getExpireTime());
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function delete(OriginalAccessTokenEntity $token) {
|
2016-11-30 02:19:14 +03:00
|
|
|
$this->key($token->getId())->delete();
|
|
|
|
$this->scopes($token->getId())->delete();
|
|
|
|
}
|
|
|
|
|
2018-04-17 23:47:25 +03:00
|
|
|
private function key(string $token): Key {
|
2016-11-30 02:19:14 +03:00
|
|
|
return new Key($this->dataTable, $token);
|
|
|
|
}
|
|
|
|
|
2018-04-17 23:47:25 +03:00
|
|
|
private function scopes(string $token): Set {
|
2016-11-30 02:19:14 +03:00
|
|
|
return new Set($this->dataTable, $token, 'scopes');
|
2016-02-14 20:50:10 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|