Configuration

Contenox stores all configuration in a single SQLite database at ~/.contenox/local.db. There is no YAML file — register backends and set defaults using CLI commands.

Workspaces vs global

Contenox has two layers of state:

  • Global state — one shared database at ~/.contenox/local.db. Holds backends, provider configuration, sessions, MCP registrations, and defaults. Shared by every project on your machine.
  • Global runtime files~/.contenox/ also stores pulled GGUF models and the shipped default chain/HITL policy presets.
  • Workspace state — one .contenox/ directory per project, containing a workspace.id file (a UUID written on contenox init) and optional workspace chain overrides. Each workspace scopes its own messages and workspace-specific config overrides inside the single global database.

Running contenox init in a project directory creates a .contenox/ folder with a fresh workspace.id, ensures the default runtime files exist under ~/.contenox/, and registers the built-in local backend. The same project always resolves to the same workspace regardless of where you invoke contenox from, as long as you're inside the directory tree.

Backends and global defaults survive across every workspace. A workspace's sessions and workspace-scoped overrides are invisible to other workspaces.

Local-first setup

For local GGUF inference, you normally do not register a backend manually:

contenox init
contenox model pull granite-3.2-2b
contenox doctor

contenox init creates the local backend. contenox model pull stores the file under ~/.contenox/models/<name>/model.gguf and sets default-model on a fresh install.

Register cloud or external backends

# Local Ollama (base URL inferred automatically)
contenox backend add ollama --type ollama

# Ollama Cloud
contenox backend add ollama-cloud --type ollama --url https://ollama.com/api --api-key-env OLLAMA_API_KEY

# OpenAI (base URL inferred)
contenox backend add openai --type openai --api-key-env OPENAI_API_KEY

# OpenRouter (base URL inferred)
contenox backend add openrouter --type openrouter --api-key-env OPENROUTER_API_KEY

# Anthropic and Mistral (base URLs inferred)
contenox backend add anthropic --type anthropic --api-key-env ANTHROPIC_API_KEY
contenox backend add mistral --type mistral --api-key-env MISTRAL_API_KEY

# Google Gemini
contenox backend add gemini --type gemini --api-key-env GEMINI_API_KEY

# AWS Bedrock
contenox backend add bedrock --type bedrock --url https://bedrock-runtime.us-east-1.amazonaws.com

# Self-hosted vLLM or compatible endpoint
contenox backend add myvllm --type vllm --url http://gpu-host:8000

# Manual local backend repair, if it was removed
contenox backend add local --type local --url ~/.contenox/models/

# Vertex AI — --url is required (include project and region)
# Option A: service account JSON (works everywhere)
export VERTEX_SA_JSON=$(cat /path/to/service-account.json)
contenox backend add vertex --type vertex-google \
  --url "https://us-central1-aiplatform.googleapis.com/v1/projects/YOUR_PROJECT_ID/locations/us-central1" \
  --api-key-env VERTEX_SA_JSON

# Option B: Application Default Credentials (CLI only)
gcloud auth application-default login
gcloud auth application-default set-quota-project YOUR_PROJECT_ID
contenox backend add vertex --type vertex-google \
  --url "https://us-central1-aiplatform.googleapis.com/v1/projects/YOUR_PROJECT_ID/locations/us-central1"

Backends are global — they live in ~/.contenox/local.db and are visible to every workspace.

Set persistent defaults

contenox config set default-provider local
contenox config set default-model    granite-3.2-2b
contenox config set default-alt-model gemini-2.5-flash
contenox config set default-alt-provider gemini
contenox config set default-autocomplete-model qwen2.5-coder:7b
contenox config set default-autocomplete-provider ollama
contenox config set default-max-tokens 8192
contenox config set default-think high
contenox config set default-chain    .contenox/default-chain.json
contenox config set hitl-policy-name hitl-policy-strict.json

contenox config list   # review current settings and their scope
KeyScopeDescription
default-modelglobalModel name used when --model is not passed
default-providerglobalProvider type used when --provider is not passed
default-alt-modelglobalSecondary model exposed to chains through {{var:alt_model}}
default-alt-providerglobalSecondary provider exposed to chains through {{var:alt_provider}}
default-autocomplete-modelglobalOptional autocomplete model exposed to chains through {{var:autocomplete_model}}
default-autocomplete-providerglobalOptional autocomplete provider exposed to chains through {{var:autocomplete_provider}}
default-max-tokensglobalOptional response token cap exposed through {{var:max_tokens}}
default-thinkglobalDefault reasoning level for supported models (auto, off, minimal, low, medium, high, xhigh)
telemetry-enabledglobalEnable local telemetry logs (true / false)
update-checkglobalEnable automatic update checks (true / false)
default-chainworkspaceChain file used in this workspace; falls back to the global value when unset
hitl-policy-nameworkspaceActive HITL policy for this workspace; falls back to the global value when unset

contenox config list shows each key's current value and its scope (global / workspace) so you can see whether a setting is inherited or overridden locally.

Manage backends

contenox backend list
contenox backend show openai
contenox backend remove myvllm

Supported providers

--typeNotes
localEmbedded llama.cpp inference compiled into the Contenox binary. No external server. Normally created by contenox init; --url should point at the models directory, usually ~/.contenox/models/.
ollamaLocal: run ollama serve first. Hosted: use --url https://ollama.com/api --api-key-env OLLAMA_API_KEY.
openaiUse --api-key-env OPENAI_API_KEY. Base URL inferred.
openrouterUse --api-key-env OPENROUTER_API_KEY. Base URL inferred as https://openrouter.ai/api/v1.
anthropicAnthropic Claude (direct API). Use --api-key-env ANTHROPIC_API_KEY. Base URL inferred.
mistralMistral (La Plateforme). Use --api-key-env MISTRAL_API_KEY. Base URL inferred.
geminiUse --api-key-env GEMINI_API_KEY. Base URL inferred.
bedrockAmazon Bedrock (Converse API). Requires --url (carries the region). Auth: ambient AWS credential chain (env / profile / IAM role), or static keys JSON via --api-key-env.
vllmSelf-hosted OpenAI-compatible endpoint. Requires --url.
vertex-googleVertex AI — Gemini on GCP. Requires --url with project and region. Auth: service account JSON via --api-key-env, or ADC (no flag needed if gcloud auth application-default login is configured).

Database location

Contenox uses one database at ~/.contenox/local.db by default. Override with:

  • --db <path> — use a specific SQLite file (useful for isolated tests or per-environment state)
  • --data-dir <path> — point at a specific workspace directory (overrides the walk-up discovery)

The walk-up from the current directory only decides which workspace you're operating in (by finding a .contenox/workspace.id file). The database itself is always the global one unless --db is passed.