lab404 / laravel-auth-checker
Laravel Auth Checker allows you to log users authentication, devices authenticated from and lock intrusions.
Installs: 159 040
Dependents: 2
Suggesters: 0
Security: 0
Stars: 225
Watchers: 12
Forks: 35
Open Issues: 7
pkg:composer/lab404/laravel-auth-checker
Requires
- php: ^8.2
- jenssegers/agent: ^2.6
- laravel/framework: ^11.0
Requires (Dev)
- orchestra/testbench: ^9.0
- phpunit/phpunit: ^11.0
README
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.
Requirements
| Version | Release |
|---|---|
| 11 | 3.0 |
| 9, 10 | 2.0 |
| 8, 9 | 1.7 |
| 6, 7 | 1.6 |
Installation
- Require the package:
composer require lab404/laravel-auth-checker - Publish migration files:
php artisan vendor:publish --tag=auth-checker - Migrate your database:
php artisan migrate - Configure your
Authenticatablemodel (see below)
Usage
This library collects login data and devices data about your users.
Authenticatable model
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 lockouts
Each login returned is associated with the Device model used
devices()returns all devices used by the user to authenticate.
Logins
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 (viaLogin::TYPE_LOGIN)$user->fails, returns failed logins (viaLogin::TYPE_FAILED)$user->lockouts, returns locked out logins (viaLogin::TYPE_LOCKOUT)
Devices
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
],
],
// ...
]
Events
There are many events available that can be used to add features to your app
LoginCreatedis fired when a user authenticates.DeviceCreatedis fired when a new device is created for a user.FailedAuthis fired when a user fails to log in.LockoutAuthis fired when authentication is locked for a user (too many attempts).
Each event passes a Login model and a Device model to your listeners.
Tests
vendor/bin/phpunit
Contributors
- MarceauKa
- and all others contributors
Licence
MIT
