Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

User Security API

BotServer provides RESTful endpoints for user management, authentication, authorization, and security features.

Overview

The User Security API enables:

  • User authentication and sessions
  • Role-based access control
  • Security settings management
  • Audit logging
  • Password policies
  • Two-factor authentication

Base URL

http://localhost:8080/api/v1/security

Authentication

Most security endpoints require authentication:

Authorization: Bearer <token>

User Management

Create User

POST /users

Create a new user account.

Request Body:

{
  "username": "johndoe",
  "email": "john@example.com",
  "full_name": "John Doe",
  "role": "user",
  "groups": ["support_team"],
  "metadata": {
    "department": "Customer Service",
    "employee_id": "EMP001"
  }
}

Response:

{
  "user_id": "usr_abc123",
  "username": "johndoe",
  "email": "john@example.com",
  "created_at": "2024-01-15T10:00:00Z",
  "status": "pending_activation"
}

Get User

GET /users/{user_id}

Retrieve user information.

Response:

{
  "user_id": "usr_abc123",
  "username": "johndoe",
  "email": "john@example.com",
  "full_name": "John Doe",
  "role": "user",
  "groups": ["support_team"],
  "status": "active",
  "created_at": "2024-01-15T10:00:00Z",
  "last_login": "2024-01-15T14:30:00Z",
  "email_verified": true,
  "two_factor_enabled": false
}

Update User

PATCH /users/{user_id}

Update user information.

Request Body:

{
  "full_name": "John Smith",
  "role": "admin",
  "groups": ["support_team", "admin_team"]
}

Delete User

DELETE /users/{user_id}

Delete or deactivate a user account.

Response:

{
  "user_id": "usr_abc123",
  "status": "deactivated",
  "deactivated_at": "2024-01-15T15:00:00Z"
}

List Users

GET /users

List all users with pagination and filters.

Query Parameters:

  • page - Page number (default: 1)
  • limit - Items per page (default: 20)
  • role - Filter by role
  • group - Filter by group
  • status - Filter by status: active, inactive, pending
  • search - Search in username, email, full name

Response:

{
  "users": [
    {
      "user_id": "usr_abc123",
      "username": "johndoe",
      "email": "john@example.com",
      "full_name": "John Doe",
      "role": "user",
      "status": "active"
    }
  ],
  "total": 150,
  "page": 1,
  "limit": 20
}

Authentication

Login

POST /auth/login

Authenticate user via directory service.

Request Body:

{
  "username": "johndoe",
  "password": "secure_password",
  "two_factor_code": "123456"
}

Response:

{
  "access_token": "eyJhbGciOiJIUzI1NiIs...",
  "refresh_token": "eyJhbGciOiJIUzI1NiIs...",
  "token_type": "Bearer",
  "expires_in": 3600,
  "user": {
    "user_id": "usr_abc123",
    "username": "johndoe",
    "role": "user"
  }
}

Refresh Token

POST /auth/refresh

Refresh an expired access token.

Request Body:

{
  "refresh_token": "eyJhbGciOiJIUzI1NiIs..."
}

Logout

POST /auth/logout

Invalidate current session.

Request Body:

{
  "refresh_token": "eyJhbGciOiJIUzI1NiIs..."
}

Verify Token

GET /auth/verify

Verify if a token is valid.

Headers:

Authorization: Bearer <token>

Response:

{
  "valid": true,
  "user_id": "usr_abc123",
  "expires_at": "2024-01-15T15:00:00Z"
}

Roles and Permissions

List Roles

GET /roles

Get all available roles.

Response:

{
  "roles": [
    {
      "role_id": "admin",
      "name": "Administrator",
      "permissions": ["users.manage", "bots.manage", "system.configure"]
    },
    {
      "role_id": "user",
      "name": "User",
      "permissions": ["bots.use", "profile.edit"]
    }
  ]
}

Assign Role

POST /users/{user_id}/roles

Assign a role to a user.

Request Body:

{
  "role_id": "admin"
}

Check Permission

GET /users/{user_id}/permissions/{permission}

Check if user has a specific permission.

Response:

{
  "user_id": "usr_abc123",
  "permission": "bots.manage",
  "granted": true,
  "source": "role:admin"
}

Groups

Create Group

POST /groups

Create a user group.

Request Body:

{
  "name": "support_team",
  "description": "Customer support team",
  "permissions": ["tickets.manage", "kb.edit"]
}

Add User to Group

POST /groups/{group_id}/members

Add a user to a group.

Request Body:

{
  "user_id": "usr_abc123"
}

Remove User from Group

DELETE /groups/{group_id}/members/{user_id}

Remove a user from a group.

Security Settings

Get Security Settings

GET /settings/security

Get current security configuration.

Response:

{
  "password_policy": {
    "min_length": 12,
    "require_uppercase": true,
    "require_lowercase": true,
    "require_numbers": true,
    "require_special": true,
    "expiry_days": 90,
    "history_count": 5
  },
  "session_policy": {
    "timeout_minutes": 30,
    "max_sessions": 5,
    "remember_me_days": 30
  },
  "two_factor": {
    "enabled": false,
    "required_for_roles": ["admin"],
    "methods": ["totp", "sms"]
  },
  "lockout_policy": {
    "max_attempts": 5,
    "lockout_duration_minutes": 30,
    "reset_window_minutes": 15
  }
}

Update Security Settings

PATCH /settings/security

Update security configuration.

Request Body:

{
  "password_policy": {
    "min_length": 14,
    "expiry_days": 60
  },
  "two_factor": {
    "enabled": true
  }
}

Two-Factor Authentication

Enable 2FA

POST /users/{user_id}/2fa/enable

Enable two-factor authentication.

Response:

{
  "secret": "JBSWY3DPEHPK3PXP",
  "qr_code": "...",
  "backup_codes": [
    "12345678",
    "87654321",
    "11223344"
  ]
}

Verify 2FA

POST /users/{user_id}/2fa/verify

Verify 2FA setup.

Request Body:

{
  "code": "123456"
}

Disable 2FA

POST /users/{user_id}/2fa/disable

Disable two-factor authentication.

Audit Logs

Get Audit Logs

GET /audit/logs

Retrieve security audit logs.

Query Parameters:

  • user_id - Filter by user
  • action - Filter by action type
  • start_date - Start of date range
  • end_date - End of date range
  • page - Page number
  • limit - Items per page

Response:

{
  "logs": [
    {
      "log_id": "log_123",
      "timestamp": "2024-01-15T14:30:00Z",
      "user_id": "usr_abc123",
      "action": "login",
      "ip_address": "192.168.1.100",
      "user_agent": "Mozilla/5.0...",
      "success": true,
      "details": {
        "method": "password",
        "session_id": "sess_xyz"
      }
    }
  ],
  "total": 500,
  "page": 1
}

Export Audit Logs

POST /audit/export

Export audit logs for compliance.

Request Body:

{
  "format": "csv",
  "date_range": {
    "start": "2024-01-01",
    "end": "2024-01-31"
  },
  "filters": {
    "actions": ["login", "permission_change", "data_access"]
  }
}

Session Management

List Sessions

GET /users/{user_id}/sessions

List active sessions for a user.

Response:

{
  "sessions": [
    {
      "session_id": "sess_xyz",
      "created_at": "2024-01-15T10:00:00Z",
      "last_activity": "2024-01-15T14:30:00Z",
      "ip_address": "192.168.1.100",
      "user_agent": "Mozilla/5.0...",
      "location": "New York, US"
    }
  ],
  "total": 2
}

Revoke Session

DELETE /sessions/{session_id}

Revoke a specific session.

Revoke All Sessions

POST /users/{user_id}/sessions/revoke-all

Revoke all sessions for a user.

Password Management

Change Password

POST /users/{user_id}/password

Change user password (handled by directory service).

Request Body:

{
  "current_password": "old_password",
  "new_password": "new_secure_password"
}

Reset Password Request

POST /auth/password/reset-request

Request password reset.

Request Body:

{
  "email": "john@example.com"
}

Reset Password

POST /auth/password/reset

Reset password with token.

Request Body:

{
  "token": "reset_token_123",
  "new_password": "new_secure_password"
}

API Keys

Generate API Key

POST /users/{user_id}/api-keys

Generate an API key for programmatic access.

Request Body:

{
  "name": "Integration Key",
  "permissions": ["bots.use"],
  "expires_at": "2024-12-31T23:59:59Z"
}

Response:

{
  "key_id": "key_123",
  "api_key": "sk_live_abcdef123456...",
  "created_at": "2024-01-15T10:00:00Z",
  "expires_at": "2024-12-31T23:59:59Z"
}

List API Keys

GET /users/{user_id}/api-keys

List user’s API keys.

Revoke API Key

DELETE /api-keys/{key_id}

Revoke an API key.

Error Responses

401 Unauthorized

{
  "error": "unauthorized",
  "message": "Invalid credentials"
}

403 Forbidden

{
  "error": "forbidden",
  "message": "Insufficient permissions"
}

423 Locked

{
  "error": "account_locked",
  "message": "Account locked due to too many failed attempts",
  "locked_until": "2024-01-15T15:00:00Z"
}

Security Best Practices

  1. Use Strong Passwords: Enforce complex password requirements
  2. Enable 2FA: Require for administrative accounts
  3. Regular Audits: Review audit logs regularly
  4. Session Limits: Limit concurrent sessions
  5. API Key Rotation: Rotate keys periodically
  6. Least Privilege: Grant minimal necessary permissions
  7. Monitor Failed Logins: Track and alert on suspicious activity

Rate Limits

OperationLimitWindow
Login5/minutePer IP
Password Reset3/hourPer email
API Key Generation10/dayPer user