laravel-passport-phone-verification-code-grant
laravel-passport-phone-verification-code-grant copied to clipboard
Resource owner phone verification code credentials grant for Laravel Passport
Laravel Passport Phone Verification Code Grant
Introduction
Resource owner phone verification code credentials grant for Laravel Passport
中文文档 / Chinese document
Install
Under your working folder and run the command in terminal:
composer require qiutuleng/laravel-passport-phone-verification-code-grant
Setup
Laravel
If your laravel version is greater or equal to 5.5, the service provider will be attached automatically.
Other versions, you must needs add \QiuTuleng\PhoneVerificationCodeGrant\PhoneVerificationCodeGrantServiceProvider::class to the providers array in config/app.php:
'providers' => [
/*
* Package Service Providers...
*/
...
\QiuTuleng\PhoneVerificationCodeGrant\PhoneVerificationCodeGrantServiceProvider::class,
]
Lumen
$app->register(\QiuTuleng\PhoneVerificationCodeGrant\PhoneVerificationCodeGrantServiceProvider::class);
How to use?
Configure
-
You must needs implement
\QiuTuleng\PhoneVerificationCodeGrant\Interfaces\PhoneVerificationCodeGrantUserInterfaceinterface in yourUsermodel.<?php namespace App; use Laravel\Passport\HasApiTokens; use Illuminate\Notifications\Notifiable; use Illuminate\Foundation\Auth\User as Authenticatable; use QiuTuleng\PhoneVerificationCodeGrant\Interfaces\PhoneVerificationCodeGrantUserInterface; class User extends Authenticatable implements PhoneVerificationCodeGrantUserInterface { use HasApiTokens, Notifiable; } -
Add
findOrNewForPassportVerifyCodeGrantandvalidateForPassportVerifyCodeGrantmethods to yourUsermodel./** * Find or create a user by phone number * * @param $phoneNumber * @return \Illuminate\Database\Eloquent\Model|null */ public function findOrCreateForPassportVerifyCodeGrant($phoneNumber) { // If you need to automatically register the user. return static::firstOrCreate(['mobile' => $phoneNumber]); // If the phone number is not exists in users table, will be fail to authenticate. // return static::where('mobile', '=', $phoneNumber)->first(); } /** * Check the verification code is valid. * * @param $verificationCode * @return boolean */ public function validateForPassportVerifyCodeGrant($verificationCode) { // Check verification code is valid. // return \App\Code::where('mobile', $this->mobile)->where('code', '=', $verificationCode)->where('expired_at', '>', now()->toDatetimeString())->exists(); return true; } -
(Optional) Also you can rename
phone_numberandverification_codefields in config file:To do this, add keys in
config/passport.php, example://... 'phone_verification' => [ 'phone_number_request_key' => 'phone', 'verification_code_request_key' => 'verification_code', ], //...
Request Tokens
You may request an access token by issuing a POST request to the /oauth/token route with the user's phone number and verification code.
$http = new GuzzleHttp\Client;
$response = $http->post('http://your-app.com/oauth/token', [
'form_params' => [
'grant_type' => 'phone_verification_code',
'client_id' => 'client-id',
'client_secret' => 'client-secret',
'phone_number' => '+8613416292625',
'verification_code' => 927068,
'scope' => '',
],
]);
return json_decode((string) $response->getBody(), true);
More
You can check out the Laravel/Passport official documentation to learn more
Contributing
You can create a pull requests to this repository.
Welcome your ideas or code.
Issues
If you have any questions, please ask your question in the Issues and I will try my best to help you.