brians84 / two-factor-auth-laravel
A package to handle 2FA authentication
Installs: 24
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 1
pkg:composer/brians84/two-factor-auth-laravel
Requires
- php: ^8.0
- bacon/bacon-qr-code: ^2.0.0
- laravel/framework: ^8.0.0|^9.0.0|^10.0.0
- pragmarx/google2fa-laravel: ^2.0
- pragmarx/google2fa-qrcode: ^3.0
This package is auto-updated.
Last update: 2025-10-22 17:50:01 UTC
README
A simple 2FA that uses Google Authenticator.
About The Project
This project uses the following three packages:
You can obviously install those three packages and do it yourself, but this is a quick and easy implementation.
In short, this package requests users to validate their credentials with Google Authenticator right after they logged in.
- If the user never registered 2FA, it displays the setup page to do it.
- If the user already did it, it displays the validation form.
Also, if you have a "remember" input in your login form, we pick up on that and add a cookie after successful validation. So the next time the user visits the site, we don't ask again for 2FA validation. Once the user logs out, we removed the cookie.
Installation
- 
Use composer to require this project composer require maurohmartinez/two-factor-auth-laravel 
- 
Run migrations php artisan migrate 
- 
Publish config, views, and public files and customize them as (and if) you need php artisan vendor:publish --provider="MHMartinez\TwoFactorAuth\app\Providers\TwoFactorAuthServiceProvider"
- 
[optional] Adjust middleware group name This package automatically applies a middleware to route "admin", but you can adjust that by updating the config file: 'middleware_route' => 'admin' You can also manually add the middleware MHMartinez\TwoFactorAuth\app\Http\Middleware\TwoFactorAuthMiddlewarewhere you need it.
- 
[optional] If you only want to ask certain users to validate 2FA, your Usermodel should implement interfaceMHMartinez\TwoFactorAuth\app\Interfaces\TwoFactorAuthInterface. That will require you to add a new methodshouldValidateWithTwoFactorAuthwhich should return a boolean indicating whether the middleware should skip that given user.Sample of your UserModel Class:use MHMartinez\TwoFactorAuth\app\Interfaces\TwoFactorAuthInterface; class User extends Authenticate implements TwoFactorAuthInterface Sample of method shouldValidateWithTwoFactorAuth():public function shouldValidateWithTwoFactorAuth(): bool { // do your logic here return true; // or false :) } 
- 
[optional] Disable this package in local environments by adding TWO_FACTOR_AUTH_ENABLED=falsein your.env
- 
[optional] Set in days when the one-time-password expires in the config file. FYI, 0 means it never expires '2fa_expires' => 0,
Contact
Project Link: https://github.com/maurohmartinez/two-factor-auth-laravel

