Skip to content

Feature Flags

github-actions[bot] edited this page Jun 16, 2026 · 1 revision

🌍 View in other languages

Feature Flags

Runtime toggles that change OmniRoute's behavior without a redeploy. Every flag listed here is defined in src/shared/constants/featureFlagDefinitions.ts — the single source of truth. The dashboard and the REST API both read from that file, so the table below is generated to match it 1:1.


What Feature Flags Are

A feature flag is a named toggle (boolean or enum) whose value can be changed at runtime and persisted in the database, with no process redeploy required. Each flag is described by a FeatureFlagDefinition with a key, label, description, category, defaultValue, type, and a requiresRestart hint.

Resolution Order

The effective value of a flag is resolved by resolveFeatureFlag() with this precedence (highest wins):

  1. DB override — a value stored in the key_value table under the feature_flags namespace (set via the dashboard or the REST API).
  2. Environment variableprocess.env[<KEY>], if set and non-empty.
  3. Definition default — the defaultValue from featureFlagDefinitions.ts.

A boolean flag is considered enabled when its effective value is "true", "1", or "yes" (see isFeatureFlagEnabled()).

Note

Most flags also have a matching environment variable of the same name documented in ENVIRONMENT.md. The flag's DB override takes precedence over that environment variable. A flag with requiresRestart: true is persisted immediately but only re-read at process startup — toggling it surfaces a "Restart Server" banner in the dashboard.


Flag Catalog

31 flags across 6 categories. Default is the definition default — the value used when neither a DB override nor an environment variable is present.

Security (7)

Key Type Default Description
REQUIRE_API_KEY boolean false Require an API key for all incoming requests.
INPUT_SANITIZER_ENABLED boolean true Enable input sanitization for all requests.
INJECTION_GUARD_MODE enum off Prompt injection guard mode. Values: off, warn, block, redact.
PII_REDACTION_ENABLED boolean false Redact personally identifiable information from requests.
PII_RESPONSE_SANITIZATION boolean false Sanitize PII from provider responses.
PII_RESPONSE_SANITIZATION_MODE enum redact Mode for PII response sanitization. Values: redact, warn, block, off.
OUTBOUND_SSRF_GUARD_ENABLED boolean true Block outbound requests to private/internal IP ranges.

Network (6)

Key Type Default Restart Description
ENABLE_TLS_FINGERPRINT boolean false Enable TLS fingerprint stealth mode.
ONEPROXY_ENABLED boolean true Enable 1proxy request proxying.
PROXY_AUTO_SELECT_ENABLED boolean false When no proxy is assigned to a connection, auto-select the first working proxy from the registry. Off by default (otherwise any registry proxy becomes a global fallback — #3332).
MITM_DISABLE_TLS_VERIFY boolean false Disable TLS certificate verification for the MITM proxy. Danger.
OMNIROUTE_ALLOW_PRIVATE_PROVIDER_URLS boolean false Allow provider URLs pointing to private/internal networks.
ENABLE_CC_COMPATIBLE_PROVIDER boolean false Enable Claude Code compatible provider mode.

Policies (3)

Key Type Default Restart Description
TOOL_POLICY_MODE enum disabled Tool-use policy enforcement mode. Values: disabled, warn, block.
RATE_LIMIT_AUTO_ENABLE boolean false Automatically enable rate limiting based on usage patterns.
ALLOW_MULTI_CONNECTIONS_PER_COMPAT_NODE boolean false Allow multiple connections per compatibility node.

Runtime (9)

Key Type Default Restart Description
OMNIROUTE_MCP_ENFORCE_SCOPES boolean true Enforce scope restrictions on MCP tool access.
OMNIROUTE_MCP_COMPRESS_DESCRIPTIONS boolean false Compress MCP tool descriptions to reduce token usage.
OMNIROUTE_ENABLE_RUNTIME_BACKGROUND_TASKS boolean false Enable background task processing at runtime.
OMNIROUTE_DISABLE_BACKGROUND_SERVICES boolean false Disable all background services (quota refresh, sync, etc).
OMNIROUTE_RTK_TRUST_PROJECT_FILTERS boolean false Trust project-level RTK filters without validation.
OMNIROUTE_ENABLE_LIVE_WS boolean true Start the real-time dashboard WebSocket server on import (port 20129 by default).
OMNIROUTE_CODEX_WS_ENABLED boolean true Allow Codex to use the Responses-over-WebSocket transport. When off, Codex falls back to HTTP Responses.
OMNIROUTE_EMERGENCY_FALLBACK boolean true Route budget-exhausted requests to the emergency free fallback provider/model. (See Emergency Budget Fallback below.)
MODEL_CATALOG_INCLUDE_NAMES boolean true Include display-friendly name fields in /v1/models responses. Disable for clients that expect model IDs only.

CLI (3)

Key Type Default Restart Description
CLI_COMPAT_ALL boolean false Enable compatibility mode for all CLI clients.
MODEL_ALIAS_COMPAT_ENABLED boolean false Enable model alias compatibility layer.
PRICING_SYNC_ENABLED boolean false Enable automatic pricing data synchronization (also requires the PRICING_SYNC_ENABLED environment variable).

Health (3)

Key Type Default Description
OMNIROUTE_DISABLE_LOCAL_HEALTHCHECK boolean false Disable the local instance health check endpoint.
OMNIROUTE_DISABLE_TOKEN_HEALTHCHECK boolean false Disable the token validation health check.
SKILLS_SANDBOX_NETWORK_ENABLED boolean false Enable network access in the skills sandbox environment.

Note

The Restart column marks flags with requiresRestart: true — the value is persisted instantly but only takes effect after the process reloads. Enum flags reject any value outside their allowed set (validated server-side in both setFeatureFlagOverride() and the REST PUT handler).


Toggling Flags

Dashboard

Navigate to Dashboard → Settings → Feature Flags (/dashboard/settings/feature-flags). The grid (src/app/(dashboard)/dashboard/settings/components/FeatureFlagsGrid.tsx) supports:

  • Search by key or description, and filter by category (plus a synthetic Requires Restart view).
  • A toggle for boolean flags and a dropdown for enum flags (src/app/(dashboard)/dashboard/settings/components/FeatureFlagCard.tsx).
  • A source badge per flag — DB, ENV, or DEF — showing where the effective value came from.
  • A Reset button (shown only for DB-sourced flags) to drop the override, and a Reset All Overrides button at the bottom.
  • A Restart Server banner when a requiresRestart flag is changed.

REST API

All operations go through a single route: src/app/api/settings/feature-flags/route.ts. Every method requires an authenticated dashboard session (401 otherwise).

GET /api/settings/feature-flags

Returns every flag with its effective value, source, and a summary.

{
  "flags": [
    {
      "key": "REQUIRE_API_KEY",
      "label": "Require API Key",
      "description": "Require an API key for all incoming requests",
      "category": "security",
      "type": "boolean",
      "enumValues": null,
      "defaultValue": "false",
      "effectiveValue": "false",
      "source": "default", // "db" | "env" | "default"
      "requiresRestart": false,
      "warningLevel": "caution",
    },
    // ... all 31 flags
  ],
  "summary": {
    "total": 31,
    "active": 0,
    "inactive": 0,
    "overriddenByDb": 0,
    "overriddenByEnv": 0,
  },
}

PUT /api/settings/feature-flags

Set or remove a single override. Body: { key: string; value?: string }. Omitting value removes the override (restoring env / default).

# Set a DB override
curl -X PUT http://localhost:20128/api/settings/feature-flags \
  -H "Content-Type: application/json" \
  -d '{"key":"REQUIRE_API_KEY","value":"true"}'

# Remove the override (no "value")
curl -X PUT http://localhost:20128/api/settings/feature-flags \
  -H "Content-Type: application/json" \
  -d '{"key":"REQUIRE_API_KEY"}'

The response echoes the new effectiveValue/source, the previousValue/ previousSource, and requiresRestart. Unknown keys and out-of-range enum values are rejected with 400.

DELETE /api/settings/feature-flags

Clears all DB overrides at once, restoring every flag to its env / default value. Returns { cleared: <count>, message: "..." }.

Note

Flags with requiresRestart: true only take effect after a process reload. The dashboard's restart flow calls POST /api/restart and then polls GET /api/health/ping until the server is back up.


Emergency Budget Fallback

OMNIROUTE_EMERGENCY_FALLBACK (category runtime, default true) controls the emergency free-fallback path in open-sse/services/emergencyFallback.ts. When enabled, requests that exhaust their budget are routed to a free fallback provider/model instead of failing outright. Set it to false (or 0) — via the dashboard toggle, a DB override, or the OMNIROUTE_EMERGENCY_FALLBACK environment variable — to disable the behavior and let budget-exhausted requests fail. (Surfaced as a dashboard toggle in PRs #3741 / #3752.)


See Also

Clone this wiki locally