2014-05-09 10:46:59 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace RelationalExample\Storage;
|
|
|
|
|
2014-11-08 18:26:12 +00:00
|
|
|
use Illuminate\Database\Capsule\Manager as Capsule;
|
2014-05-09 10:46:59 +01:00
|
|
|
use League\OAuth2\Server\Entity\AccessTokenEntity;
|
|
|
|
use League\OAuth2\Server\Entity\AuthCodeEntity;
|
|
|
|
use League\OAuth2\Server\Entity\ScopeEntity;
|
2014-11-08 18:26:12 +00:00
|
|
|
use League\OAuth2\Server\Entity\SessionEntity;
|
2014-11-12 10:38:09 +00:00
|
|
|
use League\OAuth2\Server\Storage\AbstractStorage;
|
2014-11-08 18:26:12 +00:00
|
|
|
use League\OAuth2\Server\Storage\SessionInterface;
|
2014-05-09 10:46:59 +01:00
|
|
|
|
2014-11-12 10:38:09 +00:00
|
|
|
class SessionStorage extends AbstractStorage implements SessionInterface
|
2014-05-09 10:46:59 +01:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function getByAccessToken(AccessTokenEntity $accessToken)
|
|
|
|
{
|
|
|
|
$result = Capsule::table('oauth_sessions')
|
|
|
|
->select(['oauth_sessions.id', 'oauth_sessions.owner_type', 'oauth_sessions.owner_id', 'oauth_sessions.client_id', 'oauth_sessions.client_redirect_uri'])
|
|
|
|
->join('oauth_access_tokens', 'oauth_access_tokens.session_id', '=', 'oauth_sessions.id')
|
2014-07-27 17:12:03 +01:00
|
|
|
->where('oauth_access_tokens.access_token', $accessToken->getId())
|
2014-05-09 10:46:59 +01:00
|
|
|
->get();
|
|
|
|
|
|
|
|
if (count($result) === 1) {
|
|
|
|
$session = new SessionEntity($this->server);
|
|
|
|
$session->setId($result[0]['id']);
|
|
|
|
$session->setOwner($result[0]['owner_type'], $result[0]['owner_id']);
|
|
|
|
|
|
|
|
return $session;
|
|
|
|
}
|
|
|
|
|
2014-12-10 13:10:35 +00:00
|
|
|
return;
|
2014-05-09 10:46:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function getByAuthCode(AuthCodeEntity $authCode)
|
|
|
|
{
|
2014-07-27 17:12:03 +01:00
|
|
|
$result = Capsule::table('oauth_sessions')
|
|
|
|
->select(['oauth_sessions.id', 'oauth_sessions.owner_type', 'oauth_sessions.owner_id', 'oauth_sessions.client_id', 'oauth_sessions.client_redirect_uri'])
|
|
|
|
->join('oauth_auth_codes', 'oauth_auth_codes.session_id', '=', 'oauth_sessions.id')
|
|
|
|
->where('oauth_auth_codes.auth_code', $authCode->getId())
|
|
|
|
->get();
|
|
|
|
|
|
|
|
if (count($result) === 1) {
|
|
|
|
$session = new SessionEntity($this->server);
|
|
|
|
$session->setId($result[0]['id']);
|
|
|
|
$session->setOwner($result[0]['owner_type'], $result[0]['owner_id']);
|
|
|
|
|
|
|
|
return $session;
|
|
|
|
}
|
|
|
|
|
2014-12-10 13:10:35 +00:00
|
|
|
return;
|
2014-05-09 10:46:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function getScopes(SessionEntity $session)
|
|
|
|
{
|
2014-06-23 08:20:34 +01:00
|
|
|
$result = Capsule::table('oauth_sessions')
|
|
|
|
->select('oauth_scopes.*')
|
|
|
|
->join('oauth_session_scopes', 'oauth_sessions.id', '=', 'oauth_session_scopes.session_id')
|
|
|
|
->join('oauth_scopes', 'oauth_scopes.id', '=', 'oauth_session_scopes.scope')
|
|
|
|
->where('oauth_sessions.id', $session->getId())
|
|
|
|
->get();
|
|
|
|
|
|
|
|
$scopes = [];
|
|
|
|
|
|
|
|
foreach ($result as $scope) {
|
2014-07-27 17:12:03 +01:00
|
|
|
$scopes[] = (new ScopeEntity($this->server))->hydrate([
|
|
|
|
'id' => $scope['id'],
|
2014-11-08 18:26:12 +00:00
|
|
|
'description' => $scope['description'],
|
2014-07-27 17:12:03 +01:00
|
|
|
]);
|
2014-06-23 08:20:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $scopes;
|
2014-05-09 10:46:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function create($ownerType, $ownerId, $clientId, $clientRedirectUri = null)
|
|
|
|
{
|
2014-06-23 08:20:34 +01:00
|
|
|
$id = Capsule::table('oauth_sessions')
|
2014-09-06 17:53:02 +02:00
|
|
|
->insertGetId([
|
2014-06-23 08:20:34 +01:00
|
|
|
'owner_type' => $ownerType,
|
|
|
|
'owner_id' => $ownerId,
|
2014-11-08 18:26:12 +00:00
|
|
|
'client_id' => $clientId,
|
2014-06-23 08:20:34 +01:00
|
|
|
]);
|
|
|
|
|
|
|
|
return $id;
|
2014-05-09 10:46:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function associateScope(SessionEntity $session, ScopeEntity $scope)
|
|
|
|
{
|
2014-07-27 17:12:03 +01:00
|
|
|
Capsule::table('oauth_session_scopes')
|
|
|
|
->insert([
|
|
|
|
'session_id' => $session->getId(),
|
2014-11-08 18:26:12 +00:00
|
|
|
'scope' => $scope->getId(),
|
2014-07-27 17:12:03 +01:00
|
|
|
]);
|
2014-05-09 10:46:59 +01:00
|
|
|
}
|
|
|
|
}
|