- Record the user login and retrieve it
- Notification via email when user login from a new device
- The notification email can be translated by set locale. And already had English and Chinese translation.
Inspired by yadahan/laravel-authentication-log.
To make package simple and clean, remove unnecessary record logout function, Slack notification, NexmoMessage notification.
Add translatable email function, and add Chinese translation. Translation of more languages is welcome to push.
Add some other code improvements.
Require: Laravel 8.x, and PHP 7.2+.
-
Use Composer to install:
composer require keyshang/laravel-authentication-log
-
Migrate your database. The Laravel Authentication Log migration will create the table your application needs to store authentication logs:
php artisan migrate
-
Add the
AuthenticationLogable
andNotifiable
traits to your authenticatable model (by default,App\User
model). These traits provides various methods to allow you to get common authentication log data, such as last login time, last login IP address, and set the channels to notify the user when login from a new device:
use Illuminate\Notifications\Notifiable;
use KeyShang\AuthenticationLog\AuthenticationLogable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable, AuthenticationLogable;
}
Run the command below, and change the generated file in config/authentication-log.php
.
php artisan vendor:publish --tag=authentication-log-config
By default email notification is enable.
You can disable email notification by set the notify
option in your config/authentication-log.php
configuration file to false
:
'notify' => env('AUTHENTICATION_LOG_NOTIFY', false),
You may clear the old authentication log records using the authentication-log:clear
Artisan command:
php artisan authentication-log:clear
Records that is older than the number of days specified in the older
option in your config/authentication-log.php
will be deleted:
'older' => 365,
php artisan vendor:publish --tag=authentication-log-views
php artisan vendor:publish --tag=authentication-log-translations
Get all authentication logs for the user:
User::find(1)->authentications;
Get the user last login info:
User::find(1)->lastLoginAt();
User::find(1)->lastLoginIp();
Get the user previous login time & ip address (ignoring the current login):
auth()->user()->previousLoginAt();
auth()->user()->previousLoginIp();
In routes file, add following code to preview your Mail template.
Route::get('/notification', function () {
$log = \KeyShang\AuthenticationLog\AuthenticationLog::first();
$user = $log->authenticatable;
return (new \KeyShang\AuthenticationLog\Notifications\NewDevice($log))
->toMail($user);
});
Thank you for considering contributing to the Laravel Authentication Log.
Laravel Authentication Log is open-sourced software licensed under the MIT license.