listradigital/laravel-auth-api-sanctum

SPA-ready authentication API for Laravel with Sanctum (register, login, logout, email verification, password reset)

Maintainers

Package info

bitbucket.org/listra_web/laravel-auth-api-sanctum

pkg:composer/listradigital/laravel-auth-api-sanctum

Statistics

Installs: 1

Dependents: 0

Suggesters: 0

0.0.1 2026-03-18 20:40 UTC

This package is not auto-updated.

Last update: 2026-03-18 20:59:45 UTC


README

Latest Version on Packagist Total Downloads

SPA-ready authentication API for Laravel with Sanctum. Provides register, login, logout, email verification, password reset, and a protected /me endpoint—all configurable and using httpOnly cookies for security.

Installation

composer require auth-api-sanctum/laravel-auth-api-sanctum

Publish the config file:

php artisan vendor:publish --tag="laravel-auth-api-sanctum-config"

Publish and run Sanctum migrations:

php artisan vendor:publish --provider="Laravel\Sanctum\SanctumServiceProvider"
php artisan migrate

User Model Setup

Your User model must implement MustVerifyEmail and use HasApiTokens, Notifiable. Override the notification methods to use the package's queued notifications:

use AuthApiSanctum\Concerns\HasAuthApiSanctumNotifications;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Laravel\Sanctum\HasApiTokens;

class User extends Authenticatable implements MustVerifyEmail
{
    use HasApiTokens, HasAuthApiSanctumNotifications, HasFactory, Notifiable;
    // ...
}

Or manually override:

public function sendEmailVerificationNotification(): void
{
    $this->notify(new \AuthApiSanctum\Notifications\VerifyEmailQueued);
}

public function sendPasswordResetNotification($token): void
{
    $this->notify(new \AuthApiSanctum\Notifications\ResetPasswordQueued($token));
}

Bootstrap Configuration (Laravel 11+)

In bootstrap/app.php, ensure stateful API and throttle are enabled:

->withMiddleware(function (Middleware $middleware): void {
    $middleware->statefulApi();
    $middleware->throttleApi();
    $middleware->alias([
        'verified.email' => \AuthApiSanctum\Http\Middleware\EnsureEmailIsVerifiedConfigurable::class,
    ]);
})

Auth Config Integration

In config/auth.php, use the package values for password reset and email verification expiry:

'passwords' => [
    'users' => [
        'provider' => 'users',
        'table' => 'password_reset_tokens',
        'expire' => config('auth_api_sanctum.password_reset_token_expiration_minutes', 60),
        'throttle' => 60,
    ],
],
'verification' => [
    'expire' => config('auth_api_sanctum.email_verification_expire_minutes', 60),
],

CORS

Ensure config/cors.php allows credentials for your SPA origin:

'supports_credentials' => true,
'allowed_origins' => [env('FRONTEND_URL', 'http://localhost:3000')],

Configuration

Published config (config/auth_api_sanctum.php):

KeyEnvDefaultDescription
require_email_verificationAUTH_REQUIRE_EMAIL_VERIFICATIONtrueBlock protected routes until email verified
remember_me_expiration_daysAUTH_REMEMBER_ME_EXPIRATION_DAYS5Session duration when "remember me" checked
password_reset_token_expiration_minutesAUTH_PASSWORD_RESET_EXPIRATION_MINUTES60Password reset link validity
email_verification_expire_minutesAUTH_EMAIL_VERIFICATION_EXPIRE_MINUTES60Verification link validity
frontend_reset_password_urlFRONTEND_RESET_PASSWORD_URLAPP_URLBase URL for reset link
route_prefixAUTH_API_SANCTUM_ROUTE_PREFIX''Prefix for auth routes
api_rate_limitAUTH_API_RATE_LIMIT60Requests per minute for API

API Endpoints

MethodRouteAuthDescription
POST/sanctum/csrf-cookieNoGet CSRF cookie (call before login)
POST/registerNoCreate user, optional verification email
POST/loginNoAuthenticate, returns user
POST/logoutYesInvalidate session
GET/meYesCurrent user (requires verified email if enabled)
POST/forgot-passwordNoSend reset email
POST/reset-passwordNoReset password with token
GET/email/verify/{id}/{hash}NoVerify email via signed link

Testing

composer test

Changelog

See CHANGELOG for recent changes.

License

MIT. See LICENSE.