amreljako/laravel-otp 问题修复 & 功能扩展

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

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

amreljako/laravel-otp

最新稳定版本:v0.1.0

Composer 安装命令:

composer require amreljako/laravel-otp

包简介

Advanced, secure OTP (Email/SMS/WhatsApp) package for Laravel with hashed codes, TTL, rate limiting, one-time use, events, and drivers.

README 文档

README

Advanced, secure OTP (Email/SMS/WhatsApp) for Laravel. Hashed codes, TTL, one-time use, rate limiting, drivers, rules, and clean API.

License

Features

  • Random OTP with configurable digits and TTL
  • Store only hashed codes
  • One-time use via consumed_at
  • Rate limit sending/verification
  • Attempts counter & lockout pattern
  • HMAC signature binding (purpose + destination)
  • Channels (Mail by default) + extend SMS/WhatsApp
  • Migration, Config publish, Facade, Rule
  • Framework-agnostic tests via Testbench + Pest

Install

composer require amreljako/laravel-otp
php artisan vendor:publish --tag=otp-config
php artisan migrate

Quick Start

use Otp;

Otp::send([
  'destination' => 'user@example.com',
  'purpose' => 'login',
  'channel' => 'mail', // or your sms/whatsapp driver
  // 'ttl' => 300, 'digits' => 6, 'max_attempts' => 5,
]);

Verify:

$ok = Otp::verify('user@example.com', 'login', $request->code);
if ($ok) { /* grant access */ } else { /* error */ }

Validation Rule

$request->validate([
  'email' => ['required','email'],
  'code'  => ['required', new \Amreljako\Otp\Rules\ValidOtp('email','login')],
]);

Create your own SMS/WhatsApp channel

class MySmsChannel implements \Amreljako\Otp\Contracts\OtpChannel {
  public function send(\Amreljako\Otp\DTO\OtpPayload $p): bool {
    // call provider API using $p->destination and $p->message()
    return true;
  }
}

Then register in config/otp.php:

'channels' => [
  'mail' => \Amreljako\Otp\Channels\MailChannel::class,
  'sms'  => \App\Otp\Channels\MySmsChannel::class,
],

Security

  • No plaintext codes stored
  • Expires with expires_at
  • One-time consumption
  • Throttle abuse with RateLimiter
  • Optional HMAC signature

See SECURITY.md to report vulnerabilities.

Testing

composer install
vendor/bin/pest

License

MIT © 2025 Amr Elsayed

统计信息

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

GitHub 信息

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

其他信息

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