Configurar 2FA
Endpoint para generar el secreto y el código QR necesarios para iniciar la configuración de autenticación de dos factores (2FA) en la cuenta del usuario.
🔐 Seguridad Mejorada con 2FA
La autenticación de dos factores añade una capa adicional de seguridad.
Tras configurarla, además de tu contraseña necesitarás un código temporal (TOTP) generado por una app autenticadora.
POST
/auth/account/2fa/setupGenera secreto y código QR para iniciar la configuración de 2FA
📤 Respuesta
{
"code": 2003,
"message": "Two-factor authentication generated successfully.",
"data": {
"status": "pending",
"base32": "JBSWY3DPEHPK3PXP",
"qrcode": "...",
"token": "setup-token"
}
}Autenticación
JWT Requerido
Este endpoint requiere un JWT válido:
Authorization: Bearer <access_token>
Flujo recomendado
1) Generar secreto y QR (este endpoint)
- Obtendrás
qrcodepara que el usuario lo escanee con su app autenticadora. - Guarda temporalmente el
tokendevuelto para el siguiente paso.
2) Verificar y activar 2FA
-
Usa el endpoint de verificación (ej:
/auth/account/2fa/verify) enviando:token(del setup)code(TOTP de 6 dígitos de la app)
Respuesta exitosa
Secreto generado
Código 2003 - Se generó el secreto y el QR.
{
"code": 2003,
"message": "Two-factor authentication generated successfully.",
"data": {
"status": "pending",
"base32": "JBSWY3DPEHPK3PXP",
"qrcode": "...",
"token": "setup-token"
}
}
Campos:
base32: secreto en base32 (para apps TOTP)qrcode: QR en base64 para mostrar en UItoken: token temporal para completar la configuración en el paso de verificaciónstatus:"pending"
Validez del token
⏱️ Expiración
- El
tokende configuración expira en 1 minuto. - Si expira, debes llamar nuevamente a este endpoint para generar uno nuevo.
Errores
No autenticado
Si el JWT es inválido o no se envía, el servidor responderá con 401 Unauthorized.
Apps autenticadoras compatibles
📱 Apps recomendadas
- Google Authenticator
- Authy
- Microsoft Authenticator
- FreeOTP
Todas soportan TOTP (RFC 6238).
Ejemplo JavaScript/TypeScript
async function setup2FA(accessToken) {
const res = await fetch('https://api.swapbits.co/auth/account/2fa/setup', {
method: 'POST',
headers: {
'Authorization': `Bearer ${accessToken}`,
'Content-Type': 'application/json'
}
});
const result = await res.json();
if (result.code === 2003) {
// Mostrar QR en UI
// result.data.qrcode
// Guardar token para verify
// result.data.token
return result.data;
}
return result;
}
cURL
curl -X POST 'https://api.swapbits.co/auth/account/2fa/setup' \
-H 'Authorization: Bearer YOUR_JWT_TOKEN' \
-H 'Content-Type: application/json'