mirror of
https://github.com/elyby/oauth2-server.git
synced 2025-01-24 20:42:05 +05:30
72 lines
2.1 KiB
PHP
72 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace RelationalExample\Storage;
|
|
|
|
use League\OAuth2\Server\Storage\ClientInterface;
|
|
use League\OAuth2\Server\Storage\Adapter;
|
|
use League\OAuth2\Server\Entity\ClientEntity;
|
|
use League\OAuth2\Server\Entity\SessionEntity;
|
|
|
|
use Illuminate\Database\Capsule\Manager as Capsule;
|
|
|
|
class ClientStorage extends Adapter implements ClientInterface
|
|
{
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function get($clientId, $clientSecret = null, $redirectUri = null, $grantType = null)
|
|
{
|
|
$query = Capsule::table('oauth_clients')
|
|
->select('oauth_clients.*')
|
|
->where('oauth_clients.id', $clientId);
|
|
|
|
if ($clientSecret !== null) {
|
|
$query->where('oauth_clients.secret', $clientSecret);
|
|
}
|
|
|
|
if ($redirectUri) {
|
|
$query->join('oauth_client_redirect_uris', 'oauth_clients.id', '=', 'oauth_client_redirect_uris.client_id')
|
|
->select(['oauth_clients.*', 'oauth_client_redirect_uris.*'])
|
|
->where('oauth_client_redirect_uris.redirect_uri', $redirectUri);
|
|
}
|
|
|
|
$result = $query->get();
|
|
|
|
if (count($result) === 1) {
|
|
$client = new ClientEntity($this->server);
|
|
$client->hydrate([
|
|
'id' => $result[0]['id'],
|
|
'name' => $result[0]['name']
|
|
]);
|
|
|
|
return $client;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getBySession(SessionEntity $session)
|
|
{
|
|
$result = Capsule::table('oauth_clients')
|
|
->select(['oauth_clients.id', 'oauth_clients.name'])
|
|
->join('oauth_sessions', 'oauth_clients.id', '=', 'oauth_sessions.client_id')
|
|
->where('oauth_sessions.id', $session->getId())
|
|
->get();
|
|
|
|
if (count($result) === 1) {
|
|
$client = new ClientEntity($this->server);
|
|
$client->hydrate([
|
|
'id' => $result[0]['id'],
|
|
'name' => $result[0]['name']
|
|
]);
|
|
|
|
return $client;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}
|