mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-30 23:39:45 +05:30
179 lines
3.5 KiB
PHP
179 lines
3.5 KiB
PHP
<?php
|
|
/**
|
|
* OAuth 2.0 Abstract token
|
|
*
|
|
* @package league/oauth2-server
|
|
* @author Alex Bilbie <hello@alexbilbie.com>
|
|
* @copyright Copyright (c) Alex Bilbie
|
|
* @license http://mit-license.org/
|
|
* @link https://github.com/thephpleague/oauth2-server
|
|
*/
|
|
|
|
namespace League\OAuth2\Server\Entity;
|
|
|
|
use League\OAuth2\Server\Util\SecureKey;
|
|
use League\OAuth2\Server\AbstractServer;
|
|
use Symfony\Component\HttpFoundation\ParameterBag;
|
|
use League\OAuth2\Server\Entity\SessionEntity;
|
|
|
|
/**
|
|
* Abstract token class
|
|
*/
|
|
abstract class AbstractTokenEntity
|
|
{
|
|
/**
|
|
* Token identifier
|
|
* @var string
|
|
*/
|
|
protected $id;
|
|
|
|
/**
|
|
* Associated session
|
|
* @var \League\OAuth2\Server\Entity\SessionEntity
|
|
*/
|
|
protected $session;
|
|
|
|
/**
|
|
* Session scopes
|
|
* @var array Array of ScopeEntity
|
|
*/
|
|
protected $scopes;
|
|
|
|
/**
|
|
* Token expire time
|
|
* @var int
|
|
*/
|
|
protected $expireTime = 0;
|
|
|
|
/**
|
|
* Authorization or resource server
|
|
* @var \League\OAuth2\Server\AbstractServer
|
|
*/
|
|
protected $server;
|
|
|
|
/**
|
|
* __construct
|
|
* @param \League\OAuth2\Server\AbstractServer $server
|
|
* @return self
|
|
*/
|
|
public function __construct(AbstractServer $server)
|
|
{
|
|
$this->server = $server;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set session
|
|
* @param \League\OAuth2\Server\Entity\SessionEntity $session
|
|
* @return self
|
|
*/
|
|
public function setSession(SessionEntity $session)
|
|
{
|
|
$this->session = $session;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set the expire time of the token
|
|
* @param integer $expireTime Unix time stamp
|
|
* @return self
|
|
*/
|
|
public function setExpireTime($expireTime)
|
|
{
|
|
$this->expireTime = $expireTime;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Return token expire time
|
|
* @return int
|
|
*/
|
|
public function getExpireTime()
|
|
{
|
|
return $this->expireTime;
|
|
}
|
|
|
|
/**
|
|
* Set token ID
|
|
* @param string $token Token ID
|
|
* @return self
|
|
*/
|
|
public function setId($id = null)
|
|
{
|
|
$this->id = ($id !== null) ? $id : SecureKey::generate();
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the token ID
|
|
* @return string
|
|
*/
|
|
public function getId()
|
|
{
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
* Associate a scope
|
|
* @param \League\OAuth2\Server\Entity\ScopeEntity $scope
|
|
* @return self
|
|
*/
|
|
public function associateScope(ScopeEntity $scope)
|
|
{
|
|
if (!isset($this->scopes[$scope->getId()])) {
|
|
$this->scopes[$scope->getId()] = $scope;
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Format the local scopes array
|
|
* @param array $unformatted Array of \League\OAuth2\Server\Entity\Scope
|
|
* @return array
|
|
*/
|
|
protected function formatScopes($unformatted = [])
|
|
{
|
|
if (is_null($unformatted)) {
|
|
return [];
|
|
}
|
|
|
|
$scopes = [];
|
|
foreach ($unformatted as $scope) {
|
|
if ($scope instanceof ScopeEntity) {
|
|
$scopes[$scope->getId()] = $scope;
|
|
}
|
|
}
|
|
|
|
return $scopes;
|
|
}
|
|
|
|
/**
|
|
* Returns the token as a string if the object is cast as a string
|
|
* @return string
|
|
*/
|
|
public function __toString()
|
|
{
|
|
if ($this->id === null) {
|
|
return '';
|
|
}
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
* Expire the token
|
|
* @return void
|
|
*/
|
|
abstract public function expire();
|
|
|
|
/**
|
|
* Save the token
|
|
* @return void
|
|
*/
|
|
abstract public function save();
|
|
}
|