jhaoda / socialite-odnoklassniki by jhaoda

Odnoklassniki OAuth2 Provider for Laravel Socialite
90,727
42
6
Package Data
Maintainer Username: jhaoda
Maintainer Contact: jhaoda@gmail.com (JhaoDa)
Package Create Date: 2015-04-26
Package Last Update: 2021-03-19
Home Page:
Language: PHP
License: MIT
Last Refreshed: 2024-04-26 03:13:39
Package Statistics
Total Downloads: 90,727
Monthly Downloads: 281
Daily Downloads: 17
Total Stars: 42
Total Watchers: 6
Total Forks: 15
Total Open Issues: 1

Odnoklassniki OAuth2 Provider for Laravel Socialite

1. Installation

composer require jhaoda/socialite-odnoklassniki

2. Service Provider

  • Remove Laravel\Socialite\SocialiteServiceProvider from your providers[] array in config\app.php if you have added it already.
  • Add SocialiteProviders\Manager\ServiceProvider to your providers[] array in config\app.php.

For example:

'providers' => [
    // a whole bunch of providers
    // remove 'Laravel\Socialite\SocialiteServiceProvider',
    SocialiteProviders\Manager\ServiceProvider::class, // add
];
  • Note: If you would like to use the Socialite Facade, you need to install it.

3. Add the Event and Listeners

  • Add SocialiteProviders\Manager\SocialiteWasCalled::class event to your listen[] array in <app_name>/Providers/EventServiceProvider.

  • Add your listeners (i.e. the ones from the providers) to the SocialiteProviders\Manager\SocialiteWasCalled[] that you just created.

  • The listener that you add for this provider is JhaoDa\SocialiteProviders\Odnoklassniki\OdnoklassnikiExtendSocialite::class.

  • Note: You do not need to add anything for the built-in socialite providers unless you override them with your own providers.

For example:

/**
 * The event handler mappings for the application.
 *
 * @var array
 */
protected $listen = [
    \SocialiteProviders\Manager\SocialiteWasCalled::class => [
        \JhaoDa\SocialiteProviders\Odnoklassniki\OdnoklassnikiExtendSocialite::class
    ],
];

4. Services Array and .env

Add to config/services.php:

'odnoklassniki' => [
    'client_id' => env('ODNOKLASSNIKI_ID'),
    'client_secret' => env('ODNOKLASSNIKI_SECRET'),
    'client_public' => env('ODNOKLASSNIKI_PUBLIC'),
    'redirect' => env('ODNOKLASSNIKI_REDIRECT'),  
],

Append provider values to your .env file: Note: Add both public and secret keys!

// other values above
ODNOKLASSNIKI_ID=your_app_id_for_the_service
ODNOKLASSNIKI_PUBLIC=your_app_public_for_the_service
ODNOKLASSNIKI_SECRET=your_app_secret_for_the_service
ODNOKLASSNIKI_REDIRECT=https://example.com/login