mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-15 16:22:09 +05:30
First commit of AccessToken
This commit is contained in:
parent
449ba5005c
commit
427ae50704
118
src/League/OAuth2/Server/AccessToken.php
Normal file
118
src/League/OAuth2/Server/AccessToken.php
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace League\OAuth2\Server;
|
||||||
|
|
||||||
|
use OutOfBoundsException;
|
||||||
|
use League\OAuth2\Server\Storage\SessionStorageInterface;
|
||||||
|
use League\OAuth2\Server\Storage\AccessTokenStorageInterface;
|
||||||
|
use Symfony\Component\HttpFoundation\ParameterBag;
|
||||||
|
use League\OAuth2\Server\Util\SecureKey;
|
||||||
|
use League\OAuth2\Server\Exception\InvalidAccessTokenException;
|
||||||
|
|
||||||
|
class AccessToken
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Access token ID
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $id = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Access token storage
|
||||||
|
* @var \League\OAuth2\Server\Storage\AccessTokenStorageInterface
|
||||||
|
*/
|
||||||
|
protected $storage = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Session storage
|
||||||
|
* @var \League\OAuth2\Server\Storage\SessionStorageInterface
|
||||||
|
*/
|
||||||
|
protected $sessionStorage = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Associated session
|
||||||
|
* @var \League\OAuth2\Server\Session
|
||||||
|
*/
|
||||||
|
protected $session = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Session scopes
|
||||||
|
* @var \Symfony\Component\HttpFoundation\ParameterBag
|
||||||
|
*/
|
||||||
|
protected $scopes = null;
|
||||||
|
|
||||||
|
public function __construct(AccessTokenStorageInterface $storage)
|
||||||
|
{
|
||||||
|
$this->storage = $storage;
|
||||||
|
$this->scopes = new ParameterBag();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setSession(Session $session)
|
||||||
|
{
|
||||||
|
$this->session = $session;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getSession()
|
||||||
|
{
|
||||||
|
return $this->session;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setSessionStorage(SessionStorageInterface $sessionStorage)
|
||||||
|
{
|
||||||
|
$this->sessionStorage = $sessionStorage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getSessionStorage()
|
||||||
|
{
|
||||||
|
return $this->sessionStorage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setTTL($ttl = 0)
|
||||||
|
{
|
||||||
|
$this->ttl = $ttl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTTL()
|
||||||
|
{
|
||||||
|
return $this->ttl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setTimestamp($timestamp = 0)
|
||||||
|
{
|
||||||
|
$this->timestamp = $timestamp;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTimestamp()
|
||||||
|
{
|
||||||
|
return $this->timestamp;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setId($id = null)
|
||||||
|
{
|
||||||
|
$this->id = ($id !== null) ? $id : SecureKey::make();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getId()
|
||||||
|
{
|
||||||
|
return $this->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function associateScope($scope, $details = [])
|
||||||
|
{
|
||||||
|
if (!$this->scopes->has($scope)) {
|
||||||
|
$this->scopes->set($scope, []);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function hasScope($scope)
|
||||||
|
{
|
||||||
|
return $this->scopes->has($scope);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getScopes()
|
||||||
|
{
|
||||||
|
return $this->scopes->all();
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user