m1guelpf/laravel-apple-login

Plug-and-play Sign in with Apple for Laravel

v1.0.1 2021-02-02 09:12 UTC

This package is auto-updated.

Last update: 2024-03-29 03:59:38 UTC


README

Latest Version on Packagist Total Downloads

Installation

You can install the package via composer:

composer require m1guelpf/laravel-apple-login

You'll first need to create an App ID for your website, by setting an explicit Bundle ID and enabling Sign In With Apple.

You'll then need to create a Service ID for your web app, and checking and configuring Sign in with Apple using the App ID created earlier and /apple/login as your return URL. The identifier from your Service ID will be your client id.

Finally, you'll need to create a Private Key for Sign in with Apple and your App ID. Once downloaded, use the php artisan apple:secret path/to/key.p8 to generate a client secret.

Once you have your client id and secret, you should add them to the config/services.php file as follows:

'apple' => [
  'client_id' => env('APPLE_ID'),
  'client_secret' => env('APPLE_SECRET'),
],

Usage

To initiate the login procedure, just add a link to /login/apple somewhere on your login page. By default, this package will only login the user if they already had an account with the same email, but this can be customized by providing a retrieveUser callback on your AuthServiceProvider, where you can create a new user if needed:

use M1guelpf\LoginWithApple\LoginWithApple;

class AuthServiceProvider extends ServiceProvider
{
    public function boot()
    {
        // ...

        LoginWithApple::retrieveUserWith(function (\Laravel\Socialite\Two\User $appleUser) {
            if ($user = User::where('apple_id', $appleUser->getId())->first() || ! $appleUser->getEmail()) {
                return $user;
            }

            return User::create(['name' => $appleUser->getName(), 'email' => $appleUser->getEmail()]);
        });
    }
}

Note: Due to Apple's implementation, you'll only have access to the user's name and email on their first login, and will only be able to reference them by their ID afterwards. You should structure your user retrieval code to take this limitation into account.

Usage with Inertia.js

By default, the /login/apple route returns a RedirectResponse. If you want to customize this behaviour (to return an Inertia redirect, for example), you can use the redirectUsing method on your AuthServiceProvider.

use Inertia\Inertia;
use M1guelpf\LoginWithApple\LoginWithApple;

class AuthServiceProvider extends ServiceProvider
{
    public function boot()
    {
        // ...

        LoginWithApple::redirectUsing(fn (string $url) => Inertia::location($url));
    }
}

Manually configuring routing or migrations

By default, this package will add a nullable apple_id column to your users table and register its own routes (GET and POST /login/apple). If you wish to opt out of any of these, you can do so by calling ignoreMigrations or ignoreRoutes on your AuthServiceProvider.

use M1guelpf\LoginWithApple\LoginWithApple;

class AuthServiceProvider extends ServiceProvider
{
    public function boot()
    {
        // ...

        LoginWithApple::ignoreMigrations();
        LoginWithApple::ignoreRoutes();
    }
}

You can publish the migrations to your app by running php artisan vendor:publish --tag=apple-migrations. You can also register your own routes pointing to this package's LoginWithAppleController (GET redirect() and POST login()) to avoid re-implementing the backend logic.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.