Device Settings Management ⚙️
Introduction 📖
Device settings can be managed through the app's user interface or programmatically via the API. This document describes both methods.
Settings Management Methods
The primary way to manage device settings is through the Settings tab within the app. This provides a user-friendly interface for configuring various parameters.
 
 
The app also provides API endpoints for managing device settings. This allows for programmatic access to device settings, making it easier to retrieve and apply configurations across multiple devices.
Server Modes 🔄
| Mode | Storage | Scope | 
|---|---|---|
| Local | Device | Single device | 
| Cloud/Private | Server | All account devices | 
Settings Management API 🌐
The API provides the /settings endpoint for settings management:
| Method | Local mode | Cloud/Private mode | 
|---|---|---|
| GET | Returns all device settings | Returns account-wide settings | 
| PATCH | Partially updates settings | Partially updates settings | 
| PUT | Not Available | Fully replaces settings | 
Configuration Parameters ⚙️
The settings parameters are represented as a JSON object. The structure includes the following:
{
    "encryption": {
        "passphrase": null
    },
    "messages": {
        "send_interval_min": null,
        "send_interval_max": null,
        "limit_period": "Disabled",
        "limit_value": null,
        "sim_selection_mode": "OSDefault",
        "log_lifetime_days": null
    },
    "ping": {
        "interval_seconds": null
    },
    "logs": {
        "lifetime_days": 30
    },
    "webhooks": {
        "internet_required": true,
        "retry_count": 1,
        "signing_key": null
    }
}
When operating in Local mode, you can also configure the following Cloud/Private mode parameters:
Note
All settings are nullable. Passing null to any setting will reset it to its default value.
Warning
The following settings are write-only for security reasons and cannot be read via the API:
- encryption.passphrase
- webhooks.signing_key
- gateway.private_token
Push Notifications for Syncing Settings 📱
In Cloud/Private mode, when settings are changed via the API, a push notification is sent to all devices in the account to sync the settings.
sequenceDiagram
    participant API
    participant Server
    participant Device1
    participant Device2
    API->>Server: PATCH /settings
    Server->>Device1: Push Notification
    Server->>Device2: Push Notification
    Device1->>Server: GET /settings
    Device2->>Server: GET /settingsSecurity Considerations 🔐
When device settings are changed via the API, the app will display a notification to the user for security purposes, allowing the user to review the changes. Some settings will be applied immediately, while others will be applied after the app is restarted.