--- title: CLI Reference description: Complete reference for all Unraid API CLI commands sidebar_position: 4 --- # CLI Commands :::info[Command Structure] All commands follow the pattern: `unraid-api [options]` ::: ## 🚀 Service Management ### Start ```bash unraid-api start [--log-level ] ``` Starts the Unraid API service. Options: - `--log-level`: Set logging level (trace|debug|info|warn|error|fatal) Alternative: You can also set the log level using the `LOG_LEVEL` environment variable: ```bash LOG_LEVEL=trace unraid-api start ``` ### Stop ```bash unraid-api stop [--delete] ``` Stops the Unraid API service. - `--delete`: Optional. Delete the PM2 home directory ### Restart ```bash unraid-api restart [--log-level ] ``` Restarts the Unraid API service. Options: - `--log-level`: Set logging level (trace|debug|info|warn|error|fatal) Alternative: You can also set the log level using the `LOG_LEVEL` environment variable: ```bash LOG_LEVEL=trace unraid-api restart ``` ### Logs ```bash unraid-api logs [-l ] ``` View the API logs. - `-l, --lines`: Optional. Number of lines to tail (default: 100) ## ⚙️ Configuration Commands ### Config ```bash unraid-api config ``` Displays current configuration values. ### Switch Environment ```bash unraid-api switch-env [-e ] ``` Switch between production and staging environments. - `-e, --environment`: Optional. Target environment (production|staging) ### Developer Mode :::tip Web GUI Management You can also manage developer options through the web interface at **Settings** → **Management Access** → **Developer Options** ::: ```bash unraid-api developer # Interactive prompt for tools unraid-api developer --sandbox true # Enable GraphQL sandbox unraid-api developer --sandbox false # Disable GraphQL sandbox unraid-api developer --enable-modal # Enable modal testing tool unraid-api developer --disable-modal # Disable modal testing tool ``` Configure developer features for the API: - **GraphQL Sandbox**: Enable/disable Apollo GraphQL sandbox at `/graphql` - **Modal Testing Tool**: Enable/disable UI modal testing in the Unraid menu ## API Key Management :::tip Web GUI Management You can also manage API keys through the web interface at **Settings** → **Management Access** → **API Keys** ::: ### API Key Commands ```bash unraid-api apikey [options] ``` Create and manage API keys via CLI. Options: - `--name `: Name of the key - `--create`: Create a new key - `-r, --roles `: Comma-separated list of roles - `-p, --permissions `: Comma-separated list of permissions - `-d, --description `: Description for the key ## SSO (Single Sign-On) Management :::info OIDC Configuration For OIDC/SSO provider configuration, see the web interface at **Settings** → **Management Access** → **API** → **OIDC** or refer to the [OIDC Provider Setup](./oidc-provider-setup.md) guide. ::: ### SSO Base Command ```bash unraid-api sso ``` #### Add SSO User ```bash unraid-api sso add-user # or unraid-api sso add # or unraid-api sso a ``` Add a new user for SSO authentication. #### Remove SSO User ```bash unraid-api sso remove-user # or unraid-api sso remove # or unraid-api sso r ``` Remove a user (or all users) from SSO. #### List SSO Users ```bash unraid-api sso list-users # or unraid-api sso list # or unraid-api sso l ``` List all configured SSO users. #### Validate SSO Token ```bash unraid-api sso validate-token # or unraid-api sso validate # or unraid-api sso v ``` Validates an SSO token and returns its status. ## Report Generation ### Generate Report ```bash unraid-api report [-r] [-j] ``` Generate a system report. - `-r, --raw`: Display raw command output - `-j, --json`: Display output in JSON format ## Notes 1. Most commands require appropriate permissions to modify system state 2. Some commands require the API to be running or stopped 3. Store API keys securely as they provide system access 4. SSO configuration changes may require a service restart