league/oauth2-server
現在、Laravel Passport(サーバーの実装に使用)を使用してLaravelをインストールしています。oauth2 トークンが付与されたときにユーザー ID を返したいので、それを使用して EmberJS アプリで認証されたユーザーを識別できます。
これを行うための推奨される方法は次のとおりです。
自分のクラスを作成します。
use League\OAuth2\Server\ResponseTypes\BearerTokenResponse;
use League\OAuth2\Server\Entities\AccessTokenEntityInterface;
class UserIdBearerTokenResponse extends BearerTokenResponse
{
protected function getExtraParams(AccessTokenEntityInterface $accessToken)
{
return [
'user_id' => $this->accessToken->getUserIdentifier()
];
}
}
AuthorizationServer.getResponseType()
での変更vendor/league/oauth2-server/src
protected function getResponseType()
{
if ($this->responseType instanceof ResponseTypeInterface === false) {
// Return my own class instead of provided one
$this->responseType = new UserIdBearerTokenResponse();
}
$this->responseType->setPrivateKey($this->privateKey);
return $this->responseType;
}
vendor/league/oauth2-server/src/AuthorizationServer.php
しかし、このアプローチでは、ファイルを git リポジトリに追加する必要があります。
これは私には非常に面倒で信頼できないようです。これを達成するためのより良い/よりクリーンな方法はありますか?