Authentication APIΒΆ
Complete API reference for authentication and authorization in Nexus.
π― OverviewΒΆ
The Authentication API provides comprehensive user authentication, authorization, and session management capabilities. It supports multiple authentication methods including JWT tokens, API keys, and OAuth2 integrations.
ποΈ Authentication FlowΒΆ
sequenceDiagram
participant C as Client
participant A as Auth API
participant D as Database
participant T as Token Service
participant S as Session Store
C->>A: POST /auth/login
A->>D: Validate credentials
D-->>A: User data
A->>T: Generate JWT token
T-->>A: JWT token
A->>S: Create session
S-->>A: Session ID
A-->>C: Login response with token
π Authentication EndpointsΒΆ
LoginΒΆ
Authenticate user with credentials and receive access token.
POST /api/v1/auth/login
Content-Type: application/json
{
"username": "john_doe",
"password": "secure_password",
"remember_me": false
}
Response:
{
"success": true,
"data": {
"user": {
"id": "123",
"username": "john_doe",
"email": "john@example.com",
"roles": ["user"],
"permissions": ["read:own", "write:own"]
},
"tokens": {
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"token_type": "Bearer",
"expires_in": 3600
},
"session": {
"session_id": "sess_abc123",
"expires_at": "2024-01-02T12:00:00Z"
}
}
}
Error Response:
{
"success": false,
"error": {
"code": "INVALID_CREDENTIALS",
"message": "Invalid username or password",
"details": {
"field": "credentials",
"attempts_remaining": 2
}
}
}
LogoutΒΆ
Invalidate current session and tokens.
Response:
Token RefreshΒΆ
Refresh an expired access token using refresh token.
POST /api/v1/auth/refresh
Content-Type: application/json
{
"refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}
Response:
{
"success": true,
"data": {
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"token_type": "Bearer",
"expires_in": 3600
}
}
Verify TokenΒΆ
Verify and decode an access token.
Response:
{
"success": true,
"data": {
"valid": true,
"user": {
"id": "123",
"username": "john_doe",
"roles": ["user"],
"permissions": ["read:own", "write:own"]
},
"token_info": {
"issued_at": "2024-01-01T12:00:00Z",
"expires_at": "2024-01-01T13:00:00Z",
"remaining_seconds": 2400
}
}
}
π€ User ManagementΒΆ
Get Current UserΒΆ
Get current authenticated user information.
Response:
{
"success": true,
"data": {
"user": {
"id": "123",
"username": "john_doe",
"email": "john@example.com",
"full_name": "John Doe",
"roles": ["user"],
"permissions": ["read:own", "write:own"],
"profile": {
"avatar_url": "https://example.com/avatars/john.jpg",
"bio": "Software developer",
"location": "San Francisco, CA"
},
"preferences": {
"theme": "dark",
"language": "en",
"notifications": true
},
"metadata": {
"last_login": "2024-01-01T12:00:00Z",
"login_count": 42,
"created_at": "2023-01-01T00:00:00Z",
"updated_at": "2024-01-01T11:30:00Z"
}
}
}
}
Update ProfileΒΆ
Update current user's profile information.
PUT /api/v1/auth/profile
Authorization: Bearer <access_token>
Content-Type: application/json
{
"full_name": "John Smith",
"bio": "Senior Software Developer",
"location": "New York, NY",
"preferences": {
"theme": "light",
"notifications": false
}
}
Response:
{
"success": true,
"data": {
"user": {
"id": "123",
"username": "john_doe",
"email": "john@example.com",
"full_name": "John Smith",
"profile": {
"bio": "Senior Software Developer",
"location": "New York, NY"
},
"preferences": {
"theme": "light",
"language": "en",
"notifications": false
},
"updated_at": "2024-01-01T12:30:00Z"
}
}
}
Change PasswordΒΆ
Change current user's password.
PUT /api/v1/auth/password
Authorization: Bearer <access_token>
Content-Type: application/json
{
"current_password": "old_password",
"new_password": "new_secure_password",
"confirm_password": "new_secure_password"
}
Response:
π API Key ManagementΒΆ
List API KeysΒΆ
Get list of API keys for current user.
Response:
{
"success": true,
"data": {
"api_keys": [
{
"id": "key_123",
"name": "Production API Key",
"key_preview": "nx_************************************abcd",
"permissions": ["read:data", "write:data"],
"last_used": "2024-01-01T11:30:00Z",
"created_at": "2023-12-01T10:00:00Z",
"expires_at": "2024-12-01T10:00:00Z",
"is_active": true
},
{
"id": "key_456",
"name": "Development Key",
"key_preview": "nx_************************************efgh",
"permissions": ["read:data"],
"last_used": "2023-12-15T14:20:00Z",
"created_at": "2023-11-01T09:00:00Z",
"expires_at": "2024-11-01T09:00:00Z",
"is_active": true
}
]
}
}
Create API KeyΒΆ
Create a new API key.
POST /api/v1/auth/api-keys
Authorization: Bearer <access_token>
Content-Type: application/json
{
"name": "New API Key",
"permissions": ["read:data", "write:data"],
"expires_in_days": 365,
"description": "API key for production integration"
}
Response:
{
"success": true,
"data": {
"api_key": {
"id": "key_789",
"name": "New API Key",
"key": "nx_1234567890abcdef1234567890abcdef12345678",
"permissions": ["read:data", "write:data"],
"created_at": "2024-01-01T12:00:00Z",
"expires_at": "2025-01-01T12:00:00Z",
"is_active": true
},
"warning": "This is the only time you'll see the full API key. Store it securely."
}
}
Revoke API KeyΒΆ
Revoke an existing API key.
Response:
π OAuth2 IntegrationΒΆ
OAuth2 AuthorizationΒΆ
Initiate OAuth2 authorization flow.
Supported Providers:
- google
- github
- microsoft
- linkedin
Response: Redirects to OAuth2 provider authorization URL.
OAuth2 CallbackΒΆ
Handle OAuth2 callback and exchange code for tokens.
POST /api/v1/auth/oauth2/{provider}/callback
Content-Type: application/json
{
"code": "authorization_code",
"state": "csrf_token",
"redirect_uri": "https://yourdomain.com/callback"
}
Response:
{
"success": true,
"data": {
"user": {
"id": "456",
"username": "jane_doe",
"email": "jane@example.com",
"provider": "google",
"provider_id": "google_123456789"
},
"tokens": {
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"token_type": "Bearer",
"expires_in": 3600
},
"is_new_user": false
}
}
π₯ User RegistrationΒΆ
Register UserΒΆ
Register a new user account.
POST /api/v1/auth/register
Content-Type: application/json
{
"username": "new_user",
"email": "newuser@example.com",
"password": "secure_password",
"full_name": "New User",
"terms_accepted": true,
"newsletter_opt_in": false
}
Response:
{
"success": true,
"data": {
"user": {
"id": "789",
"username": "new_user",
"email": "newuser@example.com",
"full_name": "New User",
"roles": ["user"],
"email_verified": false,
"created_at": "2024-01-01T12:00:00Z"
},
"message": "Registration successful. Please check your email for verification."
}
}
Verify EmailΒΆ
Verify user email address.
POST /api/v1/auth/verify-email
Content-Type: application/json
{
"token": "email_verification_token"
}
Response:
Resend VerificationΒΆ
Resend email verification token.
POST /api/v1/auth/resend-verification
Content-Type: application/json
{
"email": "user@example.com"
}
Response:
π Password ResetΒΆ
Request Password ResetΒΆ
Request password reset email.
Response:
Reset PasswordΒΆ
Reset password using reset token.
POST /api/v1/auth/reset-password
Content-Type: application/json
{
"token": "password_reset_token",
"new_password": "new_secure_password",
"confirm_password": "new_secure_password"
}
Response:
π‘οΈ Two-Factor AuthenticationΒΆ
Enable 2FAΒΆ
Enable two-factor authentication.
Response:
{
"success": true,
"data": {
"qr_code": "...",
"secret": "JBSWY3DPEHPK3PXP",
"backup_codes": [
"12345678",
"23456789",
"34567890",
"45678901",
"56789012"
]
}
}
Verify 2FA SetupΒΆ
Verify 2FA setup with TOTP code.
POST /api/v1/auth/2fa/verify
Authorization: Bearer <access_token>
Content-Type: application/json
{
"totp_code": "123456"
}
Response:
Disable 2FAΒΆ
Disable two-factor authentication.
DELETE /api/v1/auth/2fa
Authorization: Bearer <access_token>
Content-Type: application/json
{
"password": "current_password",
"totp_code": "123456"
}
Response:
π± Session ManagementΒΆ
List Active SessionsΒΆ
Get list of active user sessions.
Response:
{
"success": true,
"data": {
"sessions": [
{
"id": "sess_123",
"device": "Chrome on Windows",
"ip_address": "192.168.1.100",
"location": "San Francisco, CA",
"last_activity": "2024-01-01T12:00:00Z",
"created_at": "2024-01-01T10:00:00Z",
"is_current": true
},
{
"id": "sess_456",
"device": "Safari on iPhone",
"ip_address": "192.168.1.101",
"location": "San Francisco, CA",
"last_activity": "2024-01-01T11:30:00Z",
"created_at": "2024-01-01T09:00:00Z",
"is_current": false
}
]
}
}
Revoke SessionΒΆ
Revoke a specific session.
Response:
Revoke All SessionsΒΆ
Revoke all sessions except current.
Response:
π AuthorizationΒΆ
Check PermissionsΒΆ
Check if current user has specific permissions.
POST /api/v1/auth/check-permissions
Authorization: Bearer <access_token>
Content-Type: application/json
{
"permissions": ["read:users", "write:posts", "admin:system"]
}
Response:
{
"success": true,
"data": {
"permissions": {
"read:users": true,
"write:posts": true,
"admin:system": false
},
"has_all": false
}
}
Get User RolesΒΆ
Get current user's roles and permissions.
Response:
{
"success": true,
"data": {
"roles": [
{
"name": "user",
"description": "Standard user role",
"permissions": ["read:own", "write:own"]
},
{
"name": "moderator",
"description": "Content moderator role",
"permissions": ["read:all", "write:all", "moderate:content"]
}
],
"all_permissions": [
"read:own",
"write:own",
"read:all",
"write:all",
"moderate:content"
]
}
}
π¨ Error CodesΒΆ
Authentication ErrorsΒΆ
Code | HTTP Status | Description |
---|---|---|
INVALID_CREDENTIALS |
401 | Invalid username or password |
ACCOUNT_LOCKED |
423 | Account is locked due to too many failed attempts |
ACCOUNT_DISABLED |
403 | Account has been disabled |
EMAIL_NOT_VERIFIED |
403 | Email address not verified |
TOKEN_EXPIRED |
401 | Access token has expired |
TOKEN_INVALID |
401 | Invalid or malformed token |
REFRESH_TOKEN_EXPIRED |
401 | Refresh token has expired |
SESSION_EXPIRED |
401 | Session has expired |
TWO_FACTOR_REQUIRED |
401 | Two-factor authentication required |
INVALID_2FA_CODE |
401 | Invalid 2FA code |
Registration ErrorsΒΆ
Code | HTTP Status | Description |
---|---|---|
USERNAME_TAKEN |
409 | Username already exists |
EMAIL_TAKEN |
409 | Email already registered |
WEAK_PASSWORD |
400 | Password doesn't meet requirements |
INVALID_EMAIL |
400 | Invalid email format |
TERMS_NOT_ACCEPTED |
400 | Terms and conditions not accepted |
Authorization ErrorsΒΆ
Code | HTTP Status | Description |
---|---|---|
INSUFFICIENT_PERMISSIONS |
403 | User lacks required permissions |
ROLE_NOT_FOUND |
404 | Specified role does not exist |
PERMISSION_DENIED |
403 | Access denied for this resource |
π Request/Response ExamplesΒΆ
Complete Login FlowΒΆ
# 1. Login
curl -X POST "https://api.nexus.dev/v1/auth/login" \
-H "Content-Type: application/json" \
-d '{
"username": "john_doe",
"password": "secure_password"
}'
# Response includes access_token and refresh_token
# 2. Use access token for API calls
curl -X GET "https://api.nexus.dev/v1/auth/me" \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
# 3. Refresh token when expired
curl -X POST "https://api.nexus.dev/v1/auth/refresh" \
-H "Content-Type: application/json" \
-d '{
"refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}'
# 4. Logout
curl -X POST "https://api.nexus.dev/v1/auth/logout" \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
OAuth2 FlowΒΆ
# 1. Get authorization URL
curl -X GET "https://api.nexus.dev/v1/auth/oauth2/google/authorize?redirect_uri=https://yourdomain.com/callback&state=random_state"
# 2. User authorizes on Google and returns with code
# 3. Exchange code for tokens
curl -X POST "https://api.nexus.dev/v1/auth/oauth2/google/callback" \
-H "Content-Type: application/json" \
-d '{
"code": "authorization_code_from_google",
"state": "random_state",
"redirect_uri": "https://yourdomain.com/callback"
}'
π― Best PracticesΒΆ
Security GuidelinesΒΆ
- Always use HTTPS in production
- Store tokens securely (httpOnly cookies or secure storage)
- Implement token refresh before expiration
- Use appropriate token lifetimes (short access tokens, longer refresh tokens)
- Validate tokens on every request
- Implement rate limiting on authentication endpoints
- Use strong password policies
- Enable 2FA for sensitive accounts
Error HandlingΒΆ
- Don't expose sensitive information in error messages
- Use consistent error formats
- Log authentication events for security monitoring
- Implement account lockout after failed attempts
- Provide clear user feedback for authentication issues
π Related APIsΒΆ
- User Management API - User CRUD operations
- Admin API - Administrative functions
- Core API - System information and health checks
The Authentication API is the foundation of secure access to Nexus. Implement proper authentication flows and security measures to protect your application and users.