Laravel Auth Checker allows you to log users authentication, devices authenticated from and lock intrusions.
lab404/laravel-auth-checker is a Laravel package for laravel auth checker allows you to log users authentication, devices authenticated from and lock intrusions..
It currently has 223 GitHub stars and 167.160 downloads on Packagist (latest version 3.0.0).
Install it with composer require lab404/laravel-auth-checker.
Discover more Laravel packages by lab404
or browse all Laravel packages to compare alternatives.
Last updated
Laravel Auth Checker is a plugin to collect login info and devices used when a user authenticates. It makes it easy to catch user authentication attempts and lockouts from new IP address or new devices.

| Version | Release | |:--------:|:------------------------------------------------------------------:| | 11 | 3.0 | | 9, 10 | 2.0 | | 8, 9 | 1.7 | | 6, 7 | 1.6 |
composer require lab404/laravel-auth-checkerphp artisan vendor:publish --tag=auth-checkerphp artisan migrateAuthenticatable model (see below)This library collects login data and devices data about your users.
Your Authenticatable model (usually User) must implement the HasLoginsAndDevicesInterface interface.
The trait HasLoginsAndDevices is provided with for a working default implementation.
use Lab404\AuthChecker\Models\HasLoginsAndDevices;
use Lab404\AuthChecker\Interfaces\HasLoginsAndDevicesInterface;
class User extends Authenticatable implements HasLoginsAndDevicesInterface
{
// ...
use HasLoginsAndDevices;
}
Once configured, you can access the following methods
logins() returns all loginsauths() returns all successful login attempsfails() returns all failed login attemptslockouts() returns all lockoutsEach login returned is associated with the Device model used
devices() returns all devices used by the user to authenticate.Calling $user->logins outputs:
[
[
'ip_address' => '1.2.3.4',
'device_id' => 1, // ID of the used device
'type' => 'auth',
'device' => [
// See Devices
],
'created_at' => '2017-03-25 11:42:00',
],
// ...
]
Also, you can directly access logins by their type
$user->auths, returns successful logins (via Login::TYPE_LOGIN)$user->fails, returns failed logins (via Login::TYPE_FAILED)$user->lockouts, returns locked out logins (via Login::TYPE_LOCKOUT)Calling $user->devices outputs:
[
[
'platform' => 'OS X',
'platform_version' => '10_12_2',
'browser' => 'Chrome',
'browser_version' => '54',
'is_desktop' => true,
'is_mobile' => false,
'language' => 'fr-fr',
'login' => [
// See logins
],
],
// ...
]
There are many events available that can be used to add features to your app
LoginCreated is fired when a user authenticates.DeviceCreated is fired when a new device is created for a user.FailedAuth is fired when a user fails to log in.LockoutAuth is fired when authentication is locked for a user (too many attempts).Each event passes a Login model and a Device model to your listeners.
vendor/bin/phpunit
MIT