- PHP >= 7.2
(& One of the below packages:) in order of prefrence for easy plug and play...
- joelbutcher/socialstream Documentation: Here
- socialiteproviders/manager Documentation: Here
- laravel/socialite Documentation: Here
If you are looking to implement Login with Amazon into Laravel and you are unsure of which requirement to choose, then if you are using JetStream we recommend social stream. Otherwise with breeze or custom applications use Social Providers.
Please see the Base Installation Guide, then follow the provider specific instructions below.
Please see "Socialite Standalone Usage" below after following the rest of this installation.
composer require n30/socialiteproviders-amazon
The package for flexibility of proficient socialite developers who wish to use their own custom methods, does not require additional packages, if you are not sure make sure to next run the commands, otherwise the package will not work and following the instruction will through an error, so...
composer require socialiteproviders/manager
'amazon' => [
'client_id' => env('AMAZON_CLIENT_ID'),
'client_secret' => env('AMAZON_CLIENT_SECRET'),
'redirect' => env('AMAZON_REDIRECT_URI'), //recommended: /oauth/amazon/callback
],
Configure the package's listener to listen for SocialiteWasCalled
events.
Add the event to your listen[]
array in app/Providers/EventServiceProvider
. See the Base Installation Guide for detailed instructions.
protected $listen = [
\SocialiteProviders\Manager\SocialiteWasCalled::class => [
// ... other providers
\SocialiteProviders\Amazon\AmazonExtendSocialite::class.'@handle',
],
];
AMAZON_CLIENT_ID=amzn1.application-oa2-client.xxxxxxxxxxxxxxxxxxxx
AMAZON_CLIENT_SECRET=xxxxxxxxxxxxxxxxxxxxxxxx
AMAZON_REDIRECT_URI="${APP_URL}/oauth/amazon/callback"
If using on Social Stream, edit your config/socialstream.php file to add:
'providers' => [
Providers::google(),
Providers::facebook(),
Providers::twitter(),
Providers::linkedin(),
'amazon' //<--Add Amazon at the end of your list of providers
],
You can skip this part if you are using Social Stream or the socialite providers base package.
routes/web.php
Route::get('/', 'AmazonController@index');
Route::get('callback', 'AmazonController@callback');
Create controller in desired location and name, example:
php artisan make:controll AmazonController
AmazonController
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Laravel\Socialite\Facades\Socialite;
class AmazonController extends Controller
{
public function index()
{
return Socialite::driver('amazon')->redirect();
}
public function callback()
{
$user = Socialite::driver('amazon')->user();
dd($user);
}
}
And last you will need an Amazon API key:
Amazon Login Documentaiton explains all the details for creating a security profile and then enabling Amazon Login for it.
Create API keys here
For more design integrations please see Official Documentation of Social Stream for Socialite Providers based on your Livewire or Intertia implementation. An example of socialstream.blade.php button would be:
<a href="{{ route('oauth.redirect', ['provider' => 'amazon' ]) }}">
{{-- Place your Amazon SVG Icon here... I recommend Blade-ui-icons backage for easy icons: @svg('jam-amazon', "h-6 w-6") --}}
<span class="sr-only">Amazon</span>
</a>
You should now be able to use the provider like you would regularly use Socialite (assuming you have the facade installed):
return Socialite::driver('amazon')->redirect();
name
email
user_id
See Amazon Documentation for details.
MIT Copyright (c) 2023 n30