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; } /** * {@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; } }