自定义 Laravel 护照 BearerTokenResponse
Custom Laravel Passport BearerTokenResponse
目前我有一个使用 Laravel Passport 的 Laravel 安装(服务器实现使用 league/oauth2-server
)。我想在授予 oauth2 令牌时 return 用户 ID,这样我就可以用它来识别我的 EmberJS 应用程序中经过身份验证的用户。
建议的方法是:
创建我自己的 class:
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()
];
}
}
正在修改 vendor/league/oauth2-server/src
中的 AuthorizationServer.getResponseType()
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 存储库中。
这对我来说似乎非常混乱和不可靠。有没有 better/cleaner 方法来实现这个?
要使用自定义响应,您可以像这样添加自定义授权服务器:
<?php
namespace App;
use League\OAuth2\Server\AuthorizationServer;
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
class TokenServer extends AuthorizationServer
{
/**
* Get the token type that grants will return in the HTTP response.
*
* @return ResponseTypeInterface
*/
protected function getResponseType()
{
if ($this->responseType instanceof ResponseTypeInterface === false) {
$this->responseType = new UserIdBearerTokenResponse();
}
$this->responseType->setPrivateKey($this->privateKey);
return $this->responseType;
}
}
还有一个像这样的自定义 PassportServiceProvider:
<?php
namespace App\Providers;
use App\TokenServer;
class PassportServiceProvider extends \Laravel\Passport\PassportServiceProvider
{
/**
* Make the authorization service instance.
*
* @return AuthorizationServer
*/
public function makeAuthorizationServer()
{
return new TokenServer(
$this->app->make(\Laravel\Passport\Bridge\ClientRepository::class),
$this->app->make(\Laravel\Passport\Bridge\AccessTokenRepository::class),
$this->app->make(\Laravel\Passport\Bridge\ScopeRepository::class),
'file://'.storage_path('oauth-private.key'),
'file://'.storage_path('oauth-public.key')
);
}
}
然后在您的 config/app.php 文件中进行以下更改:
/*
* Package Service Providers...
* We extend the packaged PassportServiceProvider with our own customization
*/
// Laravel\Passport\PassportServiceProvider::class,
App\Providers\PassportServiceProvider::class,
目前我有一个使用 Laravel Passport 的 Laravel 安装(服务器实现使用 league/oauth2-server
)。我想在授予 oauth2 令牌时 return 用户 ID,这样我就可以用它来识别我的 EmberJS 应用程序中经过身份验证的用户。
建议的方法是:
创建我自己的 class:
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()
];
}
}
正在修改 vendor/league/oauth2-server/src
AuthorizationServer.getResponseType()
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 存储库中。
这对我来说似乎非常混乱和不可靠。有没有 better/cleaner 方法来实现这个?
要使用自定义响应,您可以像这样添加自定义授权服务器:
<?php
namespace App;
use League\OAuth2\Server\AuthorizationServer;
use League\OAuth2\Server\ResponseTypes\ResponseTypeInterface;
class TokenServer extends AuthorizationServer
{
/**
* Get the token type that grants will return in the HTTP response.
*
* @return ResponseTypeInterface
*/
protected function getResponseType()
{
if ($this->responseType instanceof ResponseTypeInterface === false) {
$this->responseType = new UserIdBearerTokenResponse();
}
$this->responseType->setPrivateKey($this->privateKey);
return $this->responseType;
}
}
还有一个像这样的自定义 PassportServiceProvider:
<?php
namespace App\Providers;
use App\TokenServer;
class PassportServiceProvider extends \Laravel\Passport\PassportServiceProvider
{
/**
* Make the authorization service instance.
*
* @return AuthorizationServer
*/
public function makeAuthorizationServer()
{
return new TokenServer(
$this->app->make(\Laravel\Passport\Bridge\ClientRepository::class),
$this->app->make(\Laravel\Passport\Bridge\AccessTokenRepository::class),
$this->app->make(\Laravel\Passport\Bridge\ScopeRepository::class),
'file://'.storage_path('oauth-private.key'),
'file://'.storage_path('oauth-public.key')
);
}
}
然后在您的 config/app.php 文件中进行以下更改:
/*
* Package Service Providers...
* We extend the packaged PassportServiceProvider with our own customization
*/
// Laravel\Passport\PassportServiceProvider::class,
App\Providers\PassportServiceProvider::class,