2017 © Pedro Peláez
 

library passport-custom-request-grant

Custom Request Grant for Laravel Passport

image

mikemclin/passport-custom-request-grant

Custom Request Grant for Laravel Passport

  • Monday, November 27, 2017
  • by mikemclin
  • Repository
  • 2 Watchers
  • 25 Stars
  • 2,647 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 13 Forks
  • 1 Open issues
  • 5 Versions
  • 1 % Grown

The README.md

Install

Install with composer... composer require mikemclin/passport-custom-request-grant, (*1)

Versions

  • Laravel 5.4 - Use version ^1.0
  • Laravel 5.3 - Use version ^0.1

Setup

  • Add MikeMcLin\Passport\CustomRequestGrantProvider to your list of providers after Laravel\Passport\PassportServiceProvider.
  • Add byPassportCustomRequest($request) method to your User model (or whatever model you have configured to work with Passport).
    • The method should accept an Illuminate\Http\Request object.
    • You should authorize and retrieve user based on this request
    • If you find that the request met your requirement, return the User model.
    • If the request did not satisfy your requirement, return null

How to use

  • Make a POST request to https://your-site.com/oauth/token, just like you would a Password or Refresh grant.
  • The POST body should contain grant_type = custom_request.
  • The request will get routed to your User::byPassportCustomRequest() function, where you will determine if access should be granted or not.
  • An access_token and refresh_token will be returned if successful.

Example

Here is what a User::byPassportCustomRequest() method might look like..., (*2)

/**
 * Verify and retrieve user by custom token request.
 *
 * @param \Illuminate\Http\Request $request
 *
 * @return \Illuminate\Database\Eloquent\Model|null
 * @throws \League\OAuth2\Server\Exception\OAuthServerException
 */
public function byPassportCustomRequest(Request $request)
{
    try {
        if ($request->get('sso_token')) {
            return $this->bySsoToken($request->get('sso_token'));
        }
    } catch (\Exception $e) {
        throw OAuthServerException::accessDenied($e->getMessage());
    }
    return null;
}

In this example, the app is able to authenticate a user based on an sso_token property from a submitted JSON payload. The bySsoToken is this app's way of doing that. It will return null or a user object. It also might throw exceptions explaining why the token is invalid. The byPassportCustomRequest catches any of those exceptions and converts them to appropriate OAuth exception type. If an ssoToken is not present on the request payload, then we return null which returns an invalid_credentials error response:, (*3)

{
  "error": "invalid_credentials",
  "message": "The user credentials were incorrect."
}

The Versions

27/11 2017

dev-master

9999999-dev

Custom Request Grant for Laravel Passport

  Sources   Download

MIT

The Requires

 

laravel lumen oauth passport grant

27/11 2017

1.0.1

1.0.1.0

Custom Request Grant for Laravel Passport

  Sources   Download

MIT

The Requires

 

laravel lumen oauth passport grant

09/02 2017

1.0.0

1.0.0.0

Custom Request Grant for Laravel Passport

  Sources   Download

MIT

The Requires

 

laravel lumen oauth passport grant

11/09 2016

0.1.1

0.1.1.0

Custom Request Grant for Laravel Passport

  Sources   Download

MIT

The Requires

 

laravel lumen oauth passport grant

11/09 2016

0.1.0

0.1.0.0

Custom Request Grant for Laravel Passport

  Sources   Download

MIT

The Requires

 

laravel lumen oauth passport grant