ninjaportal/portal-mfa
最新稳定版本:0.1
Composer 安装命令:
composer require ninjaportal/portal-mfa
包简介
Configurable MFA package for NinjaPortal actors (admin + consumer)
README 文档
README
Configurable multi-factor authentication package for NinjaPortal (portal + portal-api).
Features
- MFA for all actors (
consumer,admin) with per-actor config - Drivers:
- Authenticator app (TOTP)
- Email OTP
- Per-user MFA settings and factor management endpoints
- Extensible driver registry for custom MFA drivers
- Integrates with
portal-apiauth flow throughAuthFlowInterface
Installation
composer require ninjaportal/portal-mfa php artisan migrate
The package auto-discovers its service provider and overrides portal-api's AuthFlowInterface
binding to insert an MFA challenge step before token issuance.
Configuration
Publish config (optional):
php artisan vendor:publish --tag=portal-mfa-config
Main config file: config/portal-mfa.php
Key areas:
enabled: enable/disable MFA package globallyactors.*: per-actor MFA policy (enabled,required, allowed drivers)drivers.map: register built-in or custom driversdrivers.authenticator: TOTP issuer/window/period/digitsdrivers.email_otp: OTP TTL/resend/attempt/notification settingschallenge.*: challenge token length and pruning retention
Extending Drivers
Register custom driver classes in portal-mfa.drivers.map.
Each driver must implement NinjaPortal\Mfa\Contracts\Drivers\MfaDriverInterface.
Drivers that support factor setup flows should also implement
NinjaPortal\Mfa\Contracts\Drivers\EnrollsMfaFactorInterface.
Login Flow (MFA Challenge)
- Password is validated by the MFA auth-flow decorator.
- If MFA is not required/enabled for the actor/account, tokens are issued normally.
- If MFA is required/enabled, login returns HTTP
202with an MFA challenge payload. - Client verifies the challenge using the package endpoint.
- Tokens are issued after successful MFA verification.
Example 202 challenge response:
{
"success": true,
"status": 202,
"message": "MFA challenge required.",
"data": {
"mfa_required": true,
"challenge_type": "login",
"challenge_token": "<opaque-token>",
"driver": "email_otp",
"context": "consumer",
"purpose": "login",
"expires_at": "2026-02-24T20:30:00Z",
"can_resend": true,
"masked_destination": "j***e@example.com"
},
"meta": null
}
API Endpoints (provided by this package)
- Consumer login challenge verify/resend
- Admin login challenge verify/resend
- Consumer
/me/mfa/*settings and factor management - Admin
/admin/me/mfa/*settings and factor management
Commands
php artisan portal-mfa:challenges:prune
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 6
- 依赖项目数: 0
- 推荐数: 1
其他信息
- 授权协议: MIT
- 更新时间: 2026-02-28