umii/login-alert 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

  1. 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}"
  2. (Optional) Track new devices
    Add the provided trait to your User model 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;
    }
  3. (Optional) SMS support

    • Install Vonage/Nexmo or Twilio driver
    • Implement routeNotificationForVonage() or routeNotificationForTwilio() on your User model.

⚙️ 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 in login_alerts table

📨 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 TracksLoginAlerts trait → every login triggers an alert.
  • With the trait → alerts trigger only on new device/IP (depending on config).
  • Supports Laravel’s native ShouldQueue for async notifications.

📝 License

MIT © Muhammad

统计信息

  • 总下载量: 1
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-22