Admin MFA (v1)
Method & Path
POST /api/v1/admin/mfa/totp/setup
POST /api/v1/admin/mfa/totp/confirm
POST /api/v1/admin/mfa/verify
GET /api/v1/admin/mfa/status
Description
Multi-factor authentication (MFA) endpoints for admin accounts. Admins can enable TOTP (Time-based One-Time Password) authentication using authenticator apps like Google Authenticator, Authy, or Microsoft Authenticator.
Authentication
Required: Admin authentication required for setup and status endpoints. No authentication required for verify endpoint (used during login flow).
Endpoints
Setup TOTP
POST /api/v1/admin/mfa/totp/setup
Generate a TOTP secret and QR code for admin account.
Headers
Authorization: Bearer <admin_access_token>
Content-Type: application/json
Response 200 OK
{
"otpauthUri": "otpauth://totp/Placio:admin@example.com?secret=JBSWY3DPEHPK3PXP&issuer=Placio",
"qrCodeDataUrl": "..."
}
Response Fields
otpauthUri(string): URI for adding to authenticator appqrCodeDataUrl(string): Base64-encoded QR code image
Notes
- Secret is encrypted and stored securely (not returned in response)
- QR code can be scanned with any TOTP authenticator app
- Setup must be confirmed with
/totp/confirmendpoint
Confirm TOTP Enrollment
POST /api/v1/admin/mfa/totp/confirm
Confirm TOTP enrollment by verifying a code from the authenticator app.
Headers
Authorization: Bearer <admin_access_token>
Content-Type: application/json
Request Body
{
"totpCode": "123456"
}
Request Fields
totpCode(string, required): 6-digit TOTP code from authenticator app
Response 200 OK
{
"success": true,
"message": "TOTP method enrolled successfully"
}
Common Errors
- 400 Bad Request: Invalid TOTP code format or code doesn't match
- 401 Unauthorized: Admin authentication required
Verify MFA During Login
POST /api/v1/admin/mfa/verify
Verify MFA code during login flow after initial password authentication.
Headers
Content-Type: application/json
Request Body
{
"loginAttemptId": "507f1f77bcf86cd799439011",
"totpCode": "123456"
}
Request Fields
loginAttemptId(string, required): Challenge ID from login responsetotpCode(string, required): 6-digit TOTP code from authenticator app
Response 200 OK
{
"admin": {
"id": "507f1f77bcf86cd799439011",
"email": "admin@example.com",
"name": "Admin User",
"role": "super_admin",
"permissions": ["*"]
},
"meta": {
"accessTokenExpiresIn": 3600,
"refreshTokenExpiresIn": 604800
}
}
Common Errors
- 400 Bad Request:
- Challenge not found
- Challenge already verified
- Challenge expired
- Too many verification attempts (max 5)
- Invalid verification code
- 404 Not Found: Challenge not found
Notes
- Challenge expires after a set time (typically 10 minutes)
- Maximum 5 verification attempts per challenge
- Successful verification issues access and refresh tokens
Get MFA Status
GET /api/v1/admin/mfa/status
Get current MFA status for admin account.
Headers
Authorization: Bearer <admin_access_token>
Response 200 OK
{
"hasTotp": true,
"totpEnabled": true
}
Response Fields
hasTotp(boolean): Whether TOTP method is configuredtotpEnabled(boolean): Whether TOTP is currently enabled
Common Errors
- 401 Unauthorized: Admin authentication required
MFA Flow
- Setup: Admin calls
/totp/setupto get QR code - Scan QR: Admin scans QR code with authenticator app
- Confirm: Admin calls
/totp/confirmwith code from app - Login: During login, if MFA is enabled:
- Admin provides email/password
- System returns
loginAttemptIdand requires MFA - Admin calls
/verifywith TOTP code - System returns admin data and tokens
Security Notes
- TOTP secrets are encrypted at rest
- QR codes are only shown once during setup
- Challenge-based verification prevents replay attacks
- Maximum 5 attempts per challenge
- Challenges expire after set time period
Use Cases
- Enhanced Security: Add extra layer of protection to admin accounts
- Compliance: Meet security requirements for sensitive operations
- Account Protection: Prevent unauthorized access even if password is compromised