2017 © Pedro Peláez
 

library manager

Easily add new or override built-in providers in Laravel Socialite.

image

zhulei-nj/manager

Easily add new or override built-in providers in Laravel Socialite.

  • Tuesday, December 20, 2016
  • by zhulei-nj
  • Repository
  • 1 Watchers
  • 0 Stars
  • 1 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

manager

Easily add new or override built-in providers in Laravel Socialite, (*1)

A package for Laravel Socialite that allows you to easily add new providers or override current providers., (*2)

Benefits, (*3)

You will have access to all of the providers that you load in using the manager. Instantiation is deferred until Socialite is called You can override current providers You can create new providers Lumen usage is easy stateless() can be set to true or false You can override a config dynamically It retrieves environment variables directly from the .env file instead of also having to configure the services array. Available Providers, (*4)

See the zhulei-nj list You can also make your own or modify someone else's Reference, (*5)

Laravel docs about events Laracasts video on events in Laravel 5 Laravel Socialite Docs Laracasts Socialite video Creating a Handler, (*6)

Below is an example handler. You need to add this full class name to the listen[] in the EventServiceProvider., (*7)

See also the Laravel docs about events. providername is the name of the provider such as meetup. You will need to change your the namespacing and class names of course. namespace Your\Name\Space;, (*8)

use zhulei\Manager\SocialiteWasCalled;, (*9)

class ProviderNameExtendSocialite { public function handle(SocialiteWasCalled $socialiteWasCalled) { $socialiteWasCalled->extendSocialite('providername', \Your\Name\Space\Provider::class); } } Creating a Provider, (*10)

Look at the already created providers for inspiration. See this article on Medium Overriding a Built-in Provider, (*11)

You can easily override a built-in laravel/socialite provider by creating a new one with exactly the same name (i.e. 'facebook')., (*12)

Dynamically Passing a Config, (*13)

You can dynamically pass a config by using:, (*14)

$clientId = "secret"; $clientSecret = "secret"; $redirectUrl = "http://yourdomain.com/api/redirect"; $additionalProviderConfig = ['site' => 'meta.stackoverflow.com']; $config = new \zhulei\Manager\Config($clientId, $clientSecret, $redirectUrl, $additionalProviderConfig); return Socialite::with('provider-name')->setConfig($config)->redirect(); You must call this before you run any Socialite methods., (*15)

Creating an OAuth1 Server Class, (*16)

Take a look at the other OAuth1 providers for inspiration., (*17)

Getting the Access Token Response Body, (*18)

Laravel Socialite by default only allows access to the access_token. Which can be accessed via the \Laravel\Socialite\User->token public property. Sometimes you need access to the whole response body which may contain items such as a refresh_token., (*19)

To make this possible, the OAuth2 provider class needs to extend \zhulei\Manager\OAuth2\AbstractProvider and OAuth1 providers need to utilize the \zhulei\Manager\OAuth1\AbstractProvider and \zhulei\Manager\OAuth1\Server., (*20)

You can access it from the user object like so: $user->accessTokenResponseBody, (*21)

The Versions

20/12 2016

dev-master

9999999-dev

Easily add new or override built-in providers in Laravel Socialite.

  Sources   Download

MIT

The Requires

 

The Development Requires

by zhulei

20/12 2016

V1.0.1

1.0.1.0

Easily add new or override built-in providers in Laravel Socialite.

  Sources   Download

MIT

The Requires

 

The Development Requires

by zhulei