elsayed85 / nova-two-factor
Nova Two Factor Authentication
dev-main
2022-10-08 18:49 UTC
Requires
- php: >=7.1.0
- bacon/bacon-qr-code: ^2.0
- pragmarx/google2fa-laravel: ^2.0
This package is not auto-updated.
Last update: 2024-11-04 02:37:14 UTC
README
Nova-Two-Factor
Laravel nova in-dashboard 2FA security feature
Versions
Use v2.0.0 for Laravel Nova 4
Use ^v1.0.0 for Laravel Nova 3
\\ Nova 4
composer require visanduma/nova-two-factor:~2
\\ Nova 3
composer require visanduma/nova-two-factor:~1
Look
Setup 2FA
Enable/Disable feature
Nova login screen with 2FA security
- Pubish config & migration
php artisan vendor:publish --provider="Visanduma\NovaTwoFactor\ToolServiceProvider"
Change configs as your needs
return [
// enable or disale 2FA feature. default is enabled
'enabled' => env('NOVA_TWO_FA_ENABLE',true),
// name of authenticatable entity table. usually - users
'user_table' => 'users',
// Entity primary key
'user_id_column' => 'id',
// authenticatable model class
'user_model' => \App\Models\User::class
];
- Use ProtectWith2FA trait in configured model
<?php
namespace App\Models;
use Visanduma\NovaTwoFactor\ProtectWith2FA;
class User extends Authenticatable{
use ProtectWith2FA;
}
- Add TwoFa middleware to nova config file
/*
|--------------------------------------------------------------------------
| Nova Route Middleware
|--------------------------------------------------------------------------
|
| These middleware will be assigned to every Nova route, giving you the
| chance to add your own middleware to this stack or override any of
| the existing middleware. Or, you can just stick with this stack.
|
*/
'middleware' => [
...
\Visanduma\NovaTwoFactor\Http\Middleware\TwoFa::class
],
- Register NovaTwoFactor tool in Nova Service Provider
<?php
class NovaServiceProvider extends NovaApplicationServiceProvider{
public function tools()
{
return [
...
new \Visanduma\NovaTwoFactor\NovaTwoFactor()
];
}
}
- Run
php artisan migrate
- You are done !