sh4msi / filament-otp
Filament OTP is a package for Filament that allows users to login with a One-Time Password. (OTP and Passwordless are similar, but they differ in some aspects!)
Fund package maintenance!
sh4msi
Requires
- php: ^8.1
- filament/filament: ^3.0
- illuminate/contracts: ^10.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^8.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- spatie/laravel-ray: ^1.26
This package is auto-updated.
Last update: 2024-12-08 20:51:20 UTC
README
Filament OTP is a package for Filament 3 that allows users to login with a One-Time Password. (OTP and Passwordless are similar, but they differ in some aspects!)
Installation
You can install the package via composer:
composer require sh4msi/filament-otp
You can publish the config file with:
php artisan vendor:publish --tag="filament-otp-config"
Optionally, you can publish the views using
php artisan vendor:publish --tag="filament-otp-views"
This is the contents of the published config file:
return [ /** * The authentication model to use. */ 'user_model' => \App\Models\User::class, /** * login columns */ 'login_key' => 'email', 'login_key_rule' => ['email', 'required'], /** * token resend countdown time */ 'resent_token_countdown_time' => 60, /** * token count */ 'token_count' => 5, /** * token type * number, string, etc */ 'token_type' => 'number', /** * token expiry (minutes) */ 'token_expiry' => 15, /** * Rate limit count */ 'rate_limit_count' => 3, /** * Rate limit decay seconds */ 'rate_limit_decay_seconds' => 30, /** * Token generator class must implement TokenGeneratorInterface */ 'token_generator' => \Sh4msi\FilamentOtp\Utility\TokenGenerator::class, /** * Token notification class */ 'token_notification' => \Sh4msi\FilamentOtp\Notifications\NotificationOTP::class, /** * Login confirmation page component * * If you want to change something, place your component here. */ 'confirm_token_component' => \Sh4msi\FilamentOtp\Http\Livewire\Auth\ConfirmOTP::class, 'login_otp_component' => \Sh4msi\FilamentOtp\Http\Livewire\Auth\LoginOTP::class, ];
Usage
Add the Sh4msi\FilamentOtp\Traits\OtpLogin trait to your User model(s):
use Illuminate\Foundation\Auth\User as Authenticatable; use Sh4msi\FilamentOtp\Traits\OtpLogin; class User extends Authenticatable { use OtpLogin; // ... }
You can use the renderHook() method in the panel configuration object to display the "login with one-time password" button on the login page.
use Filament\Panel; use Illuminate\Contracts\View\View; public function panel(Panel $panel): Panel { return $panel // ... ->renderHook( 'panels::auth.login.form.after', fn (): View => View('filament-otp::livewire.login-otp-btn'), ) }
OR call by route
route('filament-otp.login')
Changelog
Please see CHANGELOG for more information on what has changed recently.
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.