oauth2-server/examples/relational/Storage/AccessTokenStorage.php

98 lines
2.9 KiB
PHP
Raw Normal View History

2014-05-09 10:46:59 +01:00
<?php
namespace RelationalExample\Storage;
use League\OAuth2\Server\Storage\AccessTokenInterface;
use League\OAuth2\Server\Storage\Adapter;
use League\OAuth2\Server\Entity\AccessTokenEntity;
use League\OAuth2\Server\Entity\AbstractTokenEntity;
use League\OAuth2\Server\Entity\RefreshTokenEntity;
use League\OAuth2\Server\Entity\ScopeEntity;
use Illuminate\Database\Capsule\Manager as Capsule;
class AccessTokenStorage extends Adapter implements AccessTokenInterface
{
/**
* {@inheritdoc}
*/
public function get($token)
{
$result = Capsule::table('oauth_access_tokens')
->where('access_token', $token)
->where('expire_time', '>=', time())
->get();
if (count($result) === 1) {
2014-07-22 10:58:15 +01:00
$token = (new AccessTokenEntity($this->server))
->setId($result[0]['access_token'])
->setExpireTime($result[0]['expire_time']);
2014-05-09 10:46:59 +01:00
return $token;
}
return null;
}
/**
* {@inheritdoc}
*/
public function getScopes(AbstractTokenEntity $token)
{
$result = Capsule::table('oauth_access_token_scopes')
->select(['oauth_scopes.id', 'oauth_scopes.description'])
->join('oauth_scopes', 'oauth_access_token_scopes.scope', '=', 'oauth_scopes.id')
2014-07-22 10:58:15 +01:00
->where('access_token', $token->getId())
2014-05-09 10:46:59 +01:00
->get();
$response = [];
if (count($result) > 0) {
foreach ($result as $row) {
2014-07-22 10:58:15 +01:00
$scope = (new ScopeEntity($this->server))->hydrate([
'id' => $row['id'],
'description' => $row['description']
]);
2014-05-09 10:46:59 +01:00
$response[] = $scope;
}
}
return $response;
}
/**
* {@inheritdoc}
*/
public function create($token, $expireTime, $sessionId)
{
2014-07-27 17:12:03 +01:00
Capsule::table('oauth_access_tokens')
->insert([
'access_token' => $token,
'session_id' => $sessionId,
'expire_time' => $expireTime
]);
2014-05-09 10:46:59 +01:00
}
/**
* {@inheritdoc}
*/
public function associateScope(AbstractTokenEntity $token, ScopeEntity $scope)
{
2014-08-04 20:15:31 +01:00
Capsule::table('oauth_access_token_scopes')
->insert([
'access_token' => $token->getId(),
'scope' => $scope->getId()
]);
2014-05-09 10:46:59 +01:00
}
/**
* {@inheritdoc}
*/
public function delete(AbstractTokenEntity $token)
{
2014-08-06 08:42:15 +01:00
Capsule::table('oauth_access_token_scopes')
->where('access_token', $token->getId())
->delete();
2014-05-09 10:46:59 +01:00
}
}