Authentication API
Common Information
Base URL
/api/v1/authAuthentication Header
Authorization: Bearer <access_token>Response Envelope
All responses follow the standard format:
// Success response
interface SuccessResponse<T> {
success: true;
data: T;
meta?: {
[key: string]: unknown;
};
}
// Error response
interface ErrorResponse {
success: false;
error: {
code: string;
message: string;
details?: Record<string, string[]>;
};
}Rate Limits
| Endpoint | Limit |
|---|---|
| POST /register | 5/min |
| POST /login | 5/min |
| POST /forgot-password | 3/hour |
| POST /reset-password | 3/hour |
| Other auth endpoints | 100/min |
Rate Limit Headers
X-RateLimit-Limit: 5
X-RateLimit-Remaining: 4
X-RateLimit-Reset: 1705329600Endpoints
POST /api/v1/auth/register
Register a new user account.
Authentication: Public
Rate Limit: 5 requests per minute
Request Body
interface RegisterRequest {
email: string; // Valid email address
password: string; // Min 8 chars, 1 uppercase, 1 lowercase, 1 number
firstName: string; // 2-100 characters
lastName: string; // 2-100 characters
phone?: string; // Optional, E.164 format
referralCode?: string; // Optional, sponsor's referral code
acceptTerms: boolean; // Must be true
acceptPrivacy: boolean; // Must be true
}Query Parameters
None
Response (201 Created)
interface RegisterResponse {
id: string; // UUID
email: string;
status: 'PENDING_VERIFICATION';
profile: {
firstName: string;
lastName: string;
};
createdAt: string; // ISO 8601
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid input data |
| 409 | EMAIL_ALREADY_EXISTS | Email is already registered |
| 409 | PHONE_ALREADY_EXISTS | Phone number is already registered |
| 404 | INVALID_REFERRAL_CODE | Referral code does not exist |
| 429 | RATE_LIMIT_EXCEEDED | Too many registration attempts |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/register \
-H "Content-Type: application/json" \
-d '{
"email": "user@example.com",
"password": "SecurePass123",
"firstName": "John",
"lastName": "Doe",
"referralCode": "ABC123XY",
"acceptTerms": true,
"acceptPrivacy": true
}'Response:
{
"success": true,
"data": {
"id": "550e8400-e29b-41d4-a716-446655440000",
"email": "user@example.com",
"status": "PENDING_VERIFICATION",
"profile": {
"firstName": "John",
"lastName": "Doe"
},
"createdAt": "2024-01-15T10:30:00Z"
}
}POST /api/v1/auth/login
Authenticate user and receive access tokens.
Authentication: Public
Rate Limit: 5 requests per minute
Request Body
interface LoginRequest {
email: string;
password: string;
deviceFingerprint?: string; // For session tracking
twoFactorCode?: string; // Required if 2FA is enabled
}Query Parameters
None
Response (200 OK)
interface LoginResponse {
accessToken: string; // JWT, expires in 15 minutes
refreshToken: string; // Opaque token, expires in 7 days
expiresIn: number; // Seconds until access token expires
tokenType: 'Bearer';
user: {
id: string;
email: string;
status: string;
profile: {
firstName: string;
lastName: string;
avatarUrl: string | null;
};
roles: string[];
requiresTwoFactor: boolean;
};
}Response (200 OK - 2FA Required)
interface TwoFactorRequiredResponse {
requiresTwoFactor: true;
tempToken: string; // Temporary token for 2FA verification
methods: ('TOTP' | 'SMS' | 'EMAIL')[];
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid input data |
| 401 | INVALID_CREDENTIALS | Email or password is incorrect |
| 401 | TWO_FACTOR_REQUIRED | 2FA code is required |
| 401 | INVALID_TWO_FACTOR_CODE | 2FA code is incorrect |
| 403 | ACCOUNT_NOT_VERIFIED | Email has not been verified |
| 403 | ACCOUNT_SUSPENDED | Account is suspended |
| 403 | ACCOUNT_BANNED | Account is banned |
| 429 | RATE_LIMIT_EXCEEDED | Too many login attempts |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/login \
-H "Content-Type: application/json" \
-d '{
"email": "user@example.com",
"password": "SecurePass123"
}'Response:
{
"success": true,
"data": {
"accessToken": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9...",
"refreshToken": "dGhpcyBpcyBhIHJlZnJlc2ggdG9rZW4...",
"expiresIn": 900,
"tokenType": "Bearer",
"user": {
"id": "550e8400-e29b-41d4-a716-446655440000",
"email": "user@example.com",
"status": "ACTIVE",
"profile": {
"firstName": "John",
"lastName": "Doe",
"avatarUrl": "https://cdn.iwm-platform.com/avatars/550e8400.jpg"
},
"roles": ["USER"],
"requiresTwoFactor": false
}
}
}POST /api/v1/auth/logout
Invalidate the current session and refresh token.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Request Body
interface LogoutRequest {
refreshToken: string; // The refresh token to invalidate
allDevices?: boolean; // If true, logout from all devices
}Query Parameters
None
Response (200 OK)
interface LogoutResponse {
message: string;
sessionsRevoked: number;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 401 | UNAUTHORIZED | Invalid or expired access token |
| 400 | INVALID_REFRESH_TOKEN | Refresh token is invalid or already revoked |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/logout \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..." \
-H "Content-Type: application/json" \
-d '{
"refreshToken": "dGhpcyBpcyBhIHJlZnJlc2ggdG9rZW4...",
"allDevices": false
}'Response:
{
"success": true,
"data": {
"message": "Successfully logged out",
"sessionsRevoked": 1
}
}POST /api/v1/auth/refresh
Refresh the access token using a valid refresh token.
Authentication: Public (uses refresh token)
Rate Limit: 100 requests per minute
Request Body
interface RefreshTokenRequest {
refreshToken: string;
}Query Parameters
None
Response (200 OK)
interface RefreshTokenResponse {
accessToken: string;
refreshToken: string; // New refresh token (rotation)
expiresIn: number;
tokenType: 'Bearer';
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Refresh token not provided |
| 401 | INVALID_REFRESH_TOKEN | Refresh token is invalid |
| 401 | REFRESH_TOKEN_EXPIRED | Refresh token has expired |
| 401 | SESSION_REVOKED | Session has been revoked |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/refresh \
-H "Content-Type: application/json" \
-d '{
"refreshToken": "dGhpcyBpcyBhIHJlZnJlc2ggdG9rZW4..."
}'Response:
{
"success": true,
"data": {
"accessToken": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9...",
"refreshToken": "bmV3IHJlZnJlc2ggdG9rZW4...",
"expiresIn": 900,
"tokenType": "Bearer"
}
}POST /api/v1/auth/verify-email
Verify user email address with the verification token.
Authentication: Public
Rate Limit: 100 requests per minute
Request Body
interface VerifyEmailRequest {
token: string; // Email verification token from email link
}Query Parameters
None
Response (200 OK)
interface VerifyEmailResponse {
message: string;
user: {
id: string;
email: string;
status: 'ACTIVE';
emailVerifiedAt: string;
};
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Token not provided |
| 400 | INVALID_TOKEN | Verification token is invalid |
| 400 | TOKEN_EXPIRED | Verification token has expired |
| 409 | ALREADY_VERIFIED | Email is already verified |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/verify-email \
-H "Content-Type: application/json" \
-d '{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}'Response:
{
"success": true,
"data": {
"message": "Email successfully verified",
"user": {
"id": "550e8400-e29b-41d4-a716-446655440000",
"email": "user@example.com",
"status": "ACTIVE",
"emailVerifiedAt": "2024-01-15T10:35:00Z"
}
}
}POST /api/v1/auth/resend-verification
Resend email verification link.
Authentication: Public
Rate Limit: 3 requests per hour
Request Body
interface ResendVerificationRequest {
email: string;
}Query Parameters
None
Response (200 OK)
interface ResendVerificationResponse {
message: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid email format |
| 404 | USER_NOT_FOUND | No account with this email |
| 409 | ALREADY_VERIFIED | Email is already verified |
| 429 | RATE_LIMIT_EXCEEDED | Too many resend attempts |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/resend-verification \
-H "Content-Type: application/json" \
-d '{
"email": "user@example.com"
}'Response:
{
"success": true,
"data": {
"message": "Verification email sent if account exists"
}
}POST /api/v1/auth/forgot-password
Request a password reset link.
Authentication: Public
Rate Limit: 3 requests per hour
Request Body
interface ForgotPasswordRequest {
email: string;
}Query Parameters
None
Response (200 OK)
interface ForgotPasswordResponse {
message: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid email format |
| 429 | RATE_LIMIT_EXCEEDED | Too many reset attempts |
Note: For security reasons, this endpoint always returns success even if the email doesn't exist.
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/forgot-password \
-H "Content-Type: application/json" \
-d '{
"email": "user@example.com"
}'Response:
{
"success": true,
"data": {
"message": "Password reset email sent if account exists"
}
}POST /api/v1/auth/reset-password
Reset password using the reset token.
Authentication: Public
Rate Limit: 3 requests per hour
Request Body
interface ResetPasswordRequest {
token: string; // Password reset token from email link
password: string; // New password (same requirements as registration)
confirmPassword: string; // Must match password
}Query Parameters
None
Response (200 OK)
interface ResetPasswordResponse {
message: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid input data |
| 400 | PASSWORD_MISMATCH | Passwords do not match |
| 400 | INVALID_TOKEN | Reset token is invalid |
| 400 | TOKEN_EXPIRED | Reset token has expired |
| 400 | PASSWORD_TOO_WEAK | Password does not meet requirements |
| 400 | PASSWORD_RECENTLY_USED | Cannot use a recently used password |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/reset-password \
-H "Content-Type: application/json" \
-d '{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"password": "NewSecurePass456",
"confirmPassword": "NewSecurePass456"
}'Response:
{
"success": true,
"data": {
"message": "Password successfully reset"
}
}POST /api/v1/auth/2fa/setup
Initialize two-factor authentication setup.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Request Body
interface TwoFactorSetupRequest {
method: 'TOTP' | 'SMS' | 'EMAIL';
}Query Parameters
None
Response (200 OK)
interface TwoFactorSetupResponse {
method: 'TOTP' | 'SMS' | 'EMAIL';
// For TOTP method
secret?: string; // Base32 encoded secret
qrCode?: string; // Data URL for QR code image
manualEntryKey?: string; // For manual entry in authenticator app
// For SMS/EMAIL methods
maskedDestination?: string; // e.g., "+7***1234" or "u***@example.com"
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid method |
| 401 | UNAUTHORIZED | Invalid or expired access token |
| 409 | TWO_FACTOR_ALREADY_ENABLED | 2FA is already enabled |
| 400 | PHONE_NOT_VERIFIED | Phone must be verified for SMS method |
| 400 | EMAIL_NOT_VERIFIED | Email must be verified for EMAIL method |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/2fa/setup \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..." \
-H "Content-Type: application/json" \
-d '{
"method": "TOTP"
}'Response:
{
"success": true,
"data": {
"method": "TOTP",
"secret": "JBSWY3DPEHPK3PXP",
"qrCode": "...",
"manualEntryKey": "JBSWY3DPEHPK3PXP"
}
}POST /api/v1/auth/2fa/verify
Verify and enable two-factor authentication.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Request Body
interface TwoFactorVerifyRequest {
code: string; // 6-digit verification code
}Query Parameters
None
Response (200 OK)
interface TwoFactorVerifyResponse {
enabled: true;
method: 'TOTP' | 'SMS' | 'EMAIL';
backupCodes: string[]; // One-time recovery codes
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid code format |
| 400 | INVALID_CODE | Verification code is incorrect |
| 400 | CODE_EXPIRED | Verification code has expired |
| 401 | UNAUTHORIZED | Invalid or expired access token |
| 400 | SETUP_NOT_INITIATED | Must call /2fa/setup first |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/2fa/verify \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..." \
-H "Content-Type: application/json" \
-d '{
"code": "123456"
}'Response:
{
"success": true,
"data": {
"enabled": true,
"method": "TOTP",
"backupCodes": [
"ABCD-1234-EFGH",
"IJKL-5678-MNOP",
"QRST-9012-UVWX",
"YZAB-3456-CDEF",
"GHIJ-7890-KLMN",
"OPQR-1234-STUV",
"WXYZ-5678-ABCD",
"EFGH-9012-IJKL"
]
}
}POST /api/v1/auth/2fa/disable
Disable two-factor authentication.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Request Body
interface TwoFactorDisableRequest {
password: string; // Current account password
code: string; // Current 2FA code or backup code
}Query Parameters
None
Response (200 OK)
interface TwoFactorDisableResponse {
disabled: true;
message: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 400 | VALIDATION_ERROR | Invalid input |
| 401 | UNAUTHORIZED | Invalid or expired access token |
| 401 | INVALID_PASSWORD | Password is incorrect |
| 401 | INVALID_CODE | 2FA code is incorrect |
| 400 | TWO_FACTOR_NOT_ENABLED | 2FA is not currently enabled |
Example
Request:
curl -X POST https://api.iwm-platform.com/api/v1/auth/2fa/disable \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..." \
-H "Content-Type: application/json" \
-d '{
"password": "SecurePass123",
"code": "123456"
}'Response:
{
"success": true,
"data": {
"disabled": true,
"message": "Two-factor authentication has been disabled"
}
}GET /api/v1/auth/sessions
List all active sessions for the current user.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Request Body
None
Query Parameters
| Parameter | Type | Description |
|---|---|---|
| page | number | Page number (optional) |
| pageSize | number | Items per page, max 50 (optional) |
Response (200 OK)
interface SessionsResponse {
sessions: Session[];
}
interface Session {
id: string;
deviceFingerprint: string | null;
ipAddress: string;
userAgent: string;
location: {
country: string | null;
city: string | null;
};
isCurrent: boolean;
createdAt: string;
lastActiveAt: string;
expiresAt: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 401 | UNAUTHORIZED | Invalid or expired access token |
Example
Request:
curl -X GET "https://api.iwm-platform.com/api/v1/auth/sessions?page=1&pageSize=10" \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..."Response:
{
"success": true,
"data": {
"sessions": [
{
"id": "660e8400-e29b-41d4-a716-446655440001",
"deviceFingerprint": "abc123def456",
"ipAddress": "192.168.1.1",
"userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7)...",
"location": {
"country": "Russia",
"city": "Moscow"
},
"isCurrent": true,
"createdAt": "2024-01-15T10:30:00Z",
"lastActiveAt": "2024-01-15T14:45:00Z",
"expiresAt": "2024-01-22T10:30:00Z"
},
{
"id": "660e8400-e29b-41d4-a716-446655440002",
"deviceFingerprint": "xyz789ghi012",
"ipAddress": "192.168.1.2",
"userAgent": "Mozilla/5.0 (iPhone; CPU iPhone OS 17_0)...",
"location": {
"country": "Russia",
"city": "Saint Petersburg"
},
"isCurrent": false,
"createdAt": "2024-01-14T08:00:00Z",
"lastActiveAt": "2024-01-14T12:30:00Z",
"expiresAt": "2024-01-21T08:00:00Z"
}
]
},
"meta": {
"pagination": {
"total": 2,
"page": 1,
"pageSize": 10,
"totalPages": 1,
"hasNext": false,
"hasPrevious": false
}
}
}DELETE /api/v1/auth/sessions/:id
Revoke a specific session.
Authentication: Required
Rate Limit: 100 requests per minute
Request Headers
Authorization: Bearer <access_token>Path Parameters
| Parameter | Type | Description |
|---|---|---|
| id | string (UUID) | Session ID to revoke |
Request Body
None
Query Parameters
None
Response (200 OK)
interface RevokeSessionResponse {
message: string;
sessionId: string;
}Error Responses
| Status | Code | Description |
|---|---|---|
| 401 | UNAUTHORIZED | Invalid or expired access token |
| 404 | SESSION_NOT_FOUND | Session not found or belongs to another user |
| 400 | CANNOT_REVOKE_CURRENT | Cannot revoke current session (use /logout instead) |
Example
Request:
curl -X DELETE https://api.iwm-platform.com/api/v1/auth/sessions/660e8400-e29b-41d4-a716-446655440002 \
-H "Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9..."Response:
{
"success": true,
"data": {
"message": "Session revoked successfully",
"sessionId": "660e8400-e29b-41d4-a716-446655440002"
}
}