承接 softrobotics/passportgrant 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

softrobotics/passportgrant

Composer 安装命令:

composer require softrobotics/passportgrant

包简介

Custom grant_type for laravel passport

README 文档

README

Note: this documentation assumes Laravel Passport installation is completed.

To get started, install package via the Composer package manager :

composer require softrobotics/passportgrant 

Publish the passport_grant_type.php configuration file using vendor:publish Artisan command :

php artisan vendor:publish --provider="imrancse\passportgrant\PassportGrantServiceProvider" --tag="config" 

Configuration

In your config/passport_grant_type.php configuration file, enable any custom grant types providing user provider class.

// "grants" is an array of user provider class indexed by grant type 'grants' => [ // 'otp_grant' => 'App\Passport\OTPGrantProvider', ], 

User provider

User provider class roles are :

  • validate /oauth/token request custom parameters
  • provide user entity instance

User provider class must implements the imrancse\passportgrant\UserProviderInterface :

/** * Validate request parameters. * * @param \Psr\Http\Message\ServerRequestInterface $request * @return void * @throws \League\OAuth2\Server\Exception\OAuthServerException */ public function validate(ServerRequestInterface $request); /** * Retrieve user instance from request. * * @param \Psr\Http\Message\ServerRequestInterface $request * @return mixed|null */ public function retrieve(ServerRequestInterface $request); 

If request validation fails, the validate() method must throw a League\OAuth2\Server\Exception\OAuthServerException invalid parameter exception.

On success, the retrieve() method must return a League\OAuth2\Server\Entities\UserEntityInterface or Illuminate\Contracts\Auth\Authenticatable instance. Otherwise null on failure.

User provider example

For convenience, the UserProvider class provide methods to validate and retrieve request custom parameters.

Therefore, creating a user provider becomes simple :

<?php namespace App\Passport; use App\User; use Psr\Http\Message\ServerRequestInterface; use softrobotics\passportgrant\UserProvider; class OTPGrantProvider extends UserProvider { /** * {@inheritdoc} */ public function validate(ServerRequestInterface $request) { // It is not necessary to validate the "grant_type", "client_id", // "client_secret" and "scope" expected parameters because it is // already validated internally. $this->validateRequest($request, [ 'email' => ['required', 'email'], ]); } /** * {@inheritdoc} */ public function retrieve(ServerRequestInterface $request) { $inputs = $this->only($request, [ 'email' ]); // Here insert your logic to retrieve user entity instance // For example, let's assume that users table has "email" column $user = User::where('email', $inputs['email'])->first(); return $user; } } 

Token request example

Request an access token for "otp_grant" grant type :

// You have to import "Illuminate\Support\Facades\Http" $response = Http::asForm()->post('https://your-app.com/oauth/token', [ 'grant_type' => 'otp_grant', 'client_id' => <client-id>, 'client_secret' => <client-secret>, 'email'=>'<user-email>', 'scope' => '' ], ]); 

统计信息

  • 总下载量: 4.08k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固