umii/login-alert
最新稳定版本:v1.0.3
Composer 安装命令:
composer require umii/login-alert
包简介
Send email/SMS alerts on user login with IP, device info, and auto location (zero-config).
README 文档
README
Package: umii/login-alert
Send an email (and optionally SMS) whenever a user logs in. Includes IP address, device info, user agent, and location (auto-resolved). Supports new device/IP-only alerts.
✨ Features
- 📩 Sends login alerts via Laravel Notifications (Mail/SMS supported)
- 🌍 Auto-detects IP, device, user agent, location
- 🆕 "Only new devices" mode with fingerprint storage
- ⚡ Plug & play: auto-discovered service provider
- ⏳ Queueable notifications supported
📦 Installation
composer require umii/login-alert php artisan vendor:publish --tag=config php artisan vendor:publish --tag=migrations php artisan migrate
⚙️ Setup
-
Configure mail in
.env(required for email alerts):MAIL_MAILER=smtp MAIL_HOST=smtp.mailtrap.io MAIL_PORT=2525 MAIL_USERNAME=your-username MAIL_PASSWORD=your-password MAIL_ENCRYPTION=tls MAIL_FROM_ADDRESS=no-reply@yourapp.com MAIL_FROM_NAME="${APP_NAME}"
-
(Optional) Track new devices
Add the provided trait to yourUsermodel to enable "only new device" alerts:use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Umii\LoginAlert\Traits\TracksLoginAlerts; class User extends Authenticatable { use Notifiable, TracksLoginAlerts; }
-
(Optional) SMS support
- Install Vonage/Nexmo or Twilio driver
- Implement
routeNotificationForVonage()orrouteNotificationForTwilio()on yourUsermodel.
⚙️ Configuration
File: config/login-alert.php
return [ // Send alerts only on new devices/IPs? 'only_new_devices' => false, // Location resolver: default uses ip-api.com (free IP lookup) 'location_resolver' => Umii\LoginAlert\Support\DefaultLocationResolver::class, ];
🧠 How It Works
- Listens to
Illuminate\Auth\Events\Login - Extracts IP, User-Agent, device info
- Resolves location automatically via configured resolver
- Sends notification immediately (queued if your app uses queues)
- If
only_new_devices = true, compares with stored fingerprints inlogin_alertstable
📨 Example Email
Subject: 🔐 Login Alert - YourApp
Hello John Doe,
We noticed a new login to your account. Here are the details:
IP Address: 203.0.113.10
Location: Karachi, PK
Device: Windows - Chrome
User Agent: Mozilla/5.0 (...)
If this was you, no further action is required.
If this wasn’t you, please reset your password immediately and contact support.
Regards,
YourApp
🧩 Notes
- Without the
TracksLoginAlertstrait → every login triggers an alert. - With the trait → alerts trigger only on new device/IP (depending on config).
- Supports Laravel’s native
ShouldQueuefor async notifications.
📝 License
MIT © Muhammad
统计信息
- 总下载量: 1
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-08-22