This is the canonical list of every ROBOCO_* setting. They are all read by a single Pydantic-Settings class (roboco/config.py), loaded from the process environment and .env, prefixed with ROBOCO_, and case-insensitive. Most have a working default; the few that don't, and the ones the orchestrator refuses to start without, are flagged below.

You rarely set most of these

For a working deploy you set the two required secrets, the host paths, and maybe a feature flag or two. The long tables here exist so that when you do need to tune a timeout or a window, you can find it. The defaults shown are RoboCo's config defaults; a few compose-only defaults differ and are called out.

A feature flag set in .env takes effect on the next backend restart. The env-gated subsystems can also be toggled from the panel's Settings → Feature Flags card, which persists to the settings store and overrides the env default; an unset toggle falls back to the env/config default. See the Optional capabilities section for what each subsystem does.

Required secrets

VariableDefaultPurpose
ROBOCO_ENCRYPTION_KEY(empty — required)Fernet key encrypting every per-project git token at rest. The orchestrator refuses to start without it (compose :? guard). Generate with python -c 'from cryptography.fernet import Fernet; print(Fernet.generate_key().decode())'. Keep it stable — losing it makes stored tokens undecryptable.
ROBOCO_AGENT_AUTH_SECRET(empty — required for compose)HMAC secret signing the per-agent X-Agent-Token. Generate with python -c 'import secrets; print(secrets.token_hex(32))'.

Security & auth

VariableDefaultPurpose
ROBOCO_AGENT_AUTH_REQUIREDfalseFail-closed secure mode. When true, every API call must carry a valid token. Requires ROBOCO_PANEL_AGENT_TOKEN to keep the panel working. On a trusted LAN, leave false (header-trust mode).
ROBOCO_PANEL_AGENT_TOKEN(empty)The CEO token nginx injects as X-Agent-Token on /api and /ws in secure mode, so the panel works without the browser holding the signing secret. Generate with make panel-token.

Application & API server

VariableDefaultPurpose
ROBOCO_APP_VERSION0.9.0Reported app version.
ROBOCO_DEBUGfalseDebug mode.
ROBOCO_ENVIRONMENTdevelopmentOne of development / staging / production. Selects the JSON log renderer (prod) vs console renderer. The compose stack sets production.
ROBOCO_HOST127.0.0.1Bind address. Use 0.0.0.0 in containers.
ROBOCO_PORT8000API port.
ROBOCO_API_URL(unset)Override base URL for containerized agents (e.g. http://roboco-orchestrator:8000); otherwise built from host/port.
ROBOCO_CORS_ORIGINS["http://localhost:3000","http://localhost:5173"]Allowed CORS origins. The single-origin nginx setup means you rarely change this.
ROBOCO_CORS_ALLOW_CREDENTIALStrueWhether CORS allows credentials.
ROBOCO_PUBLIC_BASE_URLhttp://127.0.0.1:8000Reachable base URL embedded in commit-trailer links — set to your LAN IP or domain so the links resolve.

Database

VariableDefaultPurpose
ROBOCO_DATABASE_HOSTlocalhostPostgres host (roboco-postgres in compose).
ROBOCO_DATABASE_PORT5432Postgres port.
ROBOCO_DATABASE_USERrobocoPostgres user.
ROBOCO_DATABASE_PASSWORDrobocoPostgres password — change it for any real deployment.
ROBOCO_DATABASE_NAMErobocoDatabase name.
ROBOCO_DATABASE_ECHOfalseLog every SQL statement.
ROBOCO_DATABASE_POOL_SIZE10Connection pool size.
ROBOCO_DATABASE_MAX_OVERFLOW20Extra connections beyond the pool.
ROBOCO_DATABASE_POOL_TIMEOUT10Seconds to wait for a pooled connection.
ROBOCO_DATABASE_POOL_RECYCLE1800Recycle a connection after this many seconds.

Redis

VariableDefaultPurpose
ROBOCO_REDIS_HOSTlocalhostRedis host (roboco-redis in compose).
ROBOCO_REDIS_PORT6379Redis port.
ROBOCO_REDIS_DB0Redis logical DB.
ROBOCO_REDIS_PASSWORD(unset)Optional Redis password.

RAG, embeddings & Ollama

VariableDefaultPurpose
ROBOCO_RAG_PERSIST_DIR.robocoLocal RAG persistence dir.
ROBOCO_RAG_CHUNK_STRATEGYfixedOne of fixed / semantic / hierarchical / contextual. fixed recommended; semantic loads an extra model.
ROBOCO_RAG_CHUNK_SIZE512Base chunk size.
ROBOCO_RAG_CHUNK_SIZE_DOCS1536Chunk size for docs.
ROBOCO_RAG_CHUNK_SIZE_JOURNALS1024Chunk size for journals/reflections.
ROBOCO_RAG_CHUNK_OVERLAP128Chunk overlap.
ROBOCO_RAG_AUTO_UPDATE_ENABLEDtrueWhether the RAG index auto-refreshes.
ROBOCO_RAG_AUTO_UPDATE_INTERVAL300Seconds between auto-updates.
ROBOCO_ANTHROPIC_API_KEY(unset)Optional Anthropic key. Agents use the mounted Claude Code auth, not a metered key.
ROBOCO_DEFAULT_EMBEDDING_MODELqwen3-embedding:0.6bEmbedding model (1024-dim).
ROBOCO_EMBEDDING_DIMENSIONS1024Embedding dimensions — must match the model.
ROBOCO_LOCAL_LLM_MODELglm-5:cloudLocal LLM for RAG answer synthesis.
ROBOCO_LOCAL_LLM_BASE_URLhttp://roboco-ollama:11434/v1Ollama OpenAI-compatible endpoint.
ROBOCO_OLLAMA_BASE_URLhttp://roboco-ollama:11434Ollama native endpoint (embeddings, model management).

Workspaces & git timeouts

VariableDefaultPurpose
ROBOCO_WORKSPACES_ROOT/data/workspacesRoot for all agent git clones.
ROBOCO_WORKSPACE_AUTO_CLONEtrueAuto-clone a repo on first workspace access.
ROBOCO_WORKSPACE_CLONE_TIMEOUT300Seconds for a git clone.
ROBOCO_WORKSPACE_REFRESH_FETCH_TIMEOUT_SECONDS60Timeout for the best-effort git fetch on re-entry into a healthy clone.
ROBOCO_WORKSPACE_INSTALL_DEV_DEPStrueAfter cloning, install the project's dev dependencies into the workspace so make quality runs without re-downloading tooling.
ROBOCO_WORKSPACE_DEP_INSTALL_TIMEOUT_SECONDS600Timeout for that post-clone dependency install.
ROBOCO_GIT_COMMAND_TIMEOUT_SECONDS30Timeout for a single local git subprocess (status, log, checkout).
ROBOCO_GIT_COMMIT_TIMEOUT_SECONDS180Timeout for staging + committing a changeset.
ROBOCO_GIT_NETWORK_TIMEOUT_SECONDS120Timeout for git ops that talk to origin (fetch / pull / push).
ROBOCO_PROTECTED_GIT_URLS(empty)Repo URL substrings a project may not point at — blocks agent commits/merges from reaching a protected repo.
ROBOCO_SESSION_IDLE_TIMEOUT_SECONDS3600Idle seconds before a messaging session is swept closed.

Agent images (spawn source)

VariableDefaultPurpose
ROBOCO_AGENT_IMAGE_REGISTRY(empty)Registry namespace for pre-built agent images (e.g. ghcr.io/rennf93). Empty = build locally. The registry compose wires this to ROBOCO_REGISTRY.
ROBOCO_AGENT_IMAGE_TAG(empty)Tag for pre-built agent images (e.g. 0.9.0). Empty = implicit :latest. The registry compose wires this to ROBOCO_VERSION.
Deploy-time variables (compose, not config.py)

A few variables are consumed by the compose files and host-mount wiring rather than by config.py: ROBOCO_REGISTRY, ROBOCO_VERSION, ROBOCO_DATA_DIR, ROBOCO_HOST_PROJECT_DIR, ROBOCO_HOST_CLAUDE_DIR / CLAUDE_AUTH_DIR, ROBOCO_HOST_DATA_DIR, and ROBOCO_HOST_GROK_DIR. They are documented in the production deploy reference.

Transcript retention

VariableDefaultPurpose
ROBOCO_TRANSCRIPT_RETENTION_DAYS14Days to keep agent Claude Code transcripts. A stored panel setting overrides this default.
ROBOCO_TRANSCRIPT_PRUNE_ENABLEDtrueWhether the background sweep prunes old transcripts.
ROBOCO_TRANSCRIPT_PRUNE_INTERVAL_SECONDS3600Minimum seconds between prune passes.

Spawn pacing, SLAs & reaper windows

The orchestrator's dispatcher uses these to pace spawns, detect loops, and reclaim stuck work. Defaults are tuned for real LLM latency — raise the reaper windows (not lower) if long agent tasks are being reaped mid-work.

VariableDefaultPurpose
ROBOCO_AGENT_TOOL_CALL_WARN50Soft warning threshold for per-session tool calls.
ROBOCO_AGENT_TOOL_CALL_HALT150Hard cap on per-session tool calls; the orchestrator stops the container.
ROBOCO_AGENT_LOOP_THRESHOLD3Identical tool+args repeats in the window that flag a loop.
ROBOCO_AGENT_LOOP_WINDOW10How many recent tool calls to inspect for loop detection.
ROBOCO_AGENT_STOP_ATTEMPT_ALLOWANCE1Stop-without-terminal attempts before auto-substitute.
ROBOCO_AGENT_SLA_DEVELOPER_IN_PROGRESS7200SLA (s) for a developer in in_progress.
ROBOCO_AGENT_SLA_DEVELOPER_VERIFYING1800SLA (s) for a developer in verifying.
ROBOCO_AGENT_SLA_QA_CLAIMED1800SLA (s) for QA on a claimed review.
ROBOCO_AGENT_SLA_DOCUMENTER_CLAIMED3600SLA (s) for a documenter on a claimed task.
ROBOCO_AGENT_SLA_CELL_PM_CLAIMED14400SLA (s) for a cell PM on a claimed task.
ROBOCO_CLAIM_STALE_SECONDS180Claim-heartbeat staleness used by the spawn trigger filter.
ROBOCO_STALE_CLAIM_REAP_SECONDS600Reaper-only stale-claim threshold before releasing a claim back to pending.
ROBOCO_PM_CLOSURE_RECENTLY_PAUSED_SECONDS45Debounce before respawning a PM to close a recently paused parent.
ROBOCO_GROK_IDLE_KILL_SECONDS900Idle-container kill threshold for Grok agents (they emit no SDK heartbeat).
ROBOCO_GROK_MAX_COST_USD0.0Per-agent Grok cost ceiling (USD) before kill; 0 disables.
ROBOCO_INTERACTIVE_IDLE_REAP_SECONDS1800Idle-reap threshold for live intake/secretary chats; 0 disables.
ROBOCO_CLAIMED_NO_AGENT_GRACE_SECONDS120Grace window before respawning/releasing a claimed task with no running agent.
ROBOCO_PM_DECISION_WINDOW_SECONDS300Recency window for a PM journal:decision to satisfy gating verbs.
ROBOCO_SPAWN_COOLDOWN_SECONDS60Per-task spawn-rate cooldown.
ROBOCO_ROLE_SPAWN_RATE_PER_MINUTE6Per-role spawn-rate limit per minute.

Gateway: manifests & tracing-gate minimums

VariableDefaultPurpose
ROBOCO_MANIFEST_HOST_DIR/app/manifestsOrchestrator dir where per-agent tool manifests are written; must be a host-bind-mounted path so the daemon can mount each manifest into its agent.
ROBOCO_QA_NOTES_MIN_CHARS80Minimum characters for QA notes.
ROBOCO_DOCS_NOTES_MIN_CHARS20Minimum characters for docs notes.
ROBOCO_DEV_NOTES_MIN_CHARS40Minimum characters for a developer's dev_notes.
ROBOCO_PR_REVIEWER_NOTES_MIN_CHARS40Minimum characters for a PR reviewer's notes.
ROBOCO_QUICK_CONTEXT_MIN_CHARS30Minimum characters for a PM's quick_context resumption section.
ROBOCO_COMMIT_SUBJECT_MIN_CHARS20Minimum characters for a commit subject.
ROBOCO_COMMIT_BANNED_WORDSwip,tmp,asdf,oops,fix,update,change,stuff,thingsBanned single-word commit subjects.

Grok runtime

Only relevant if you run any agent on Grok. See the models section for the full runtime.

VariableDefaultPurpose
ROBOCO_HOST_GROK_DIR/home/renzof/.grok (compose)Host ~/.grok SuperGrok auth dir; mounted read-write into the orchestrator (token auto-refresh) and read-only into Grok agents. The same value is both the source and target path.
ROBOCO_GROK_AGENT_IMAGEroboco-agent-grok:latestImage the orchestrator spawns for Grok agents.
ROBOCO_GROK_CLI_MODELgrok-buildGrok CLI model id.
ROBOCO_GROK_REASONING_EFFORT(empty)low/medium/high/xhigh/max for all Grok agents; empty keeps the model default.
ROBOCO_GROK_MAX_TURNS200Hard ceiling on agentic turns per Grok run (loop guard).
ROBOCO_GROK_IDLE_KILL_SECONDS900(see reaper table) Idle-kill window for a wedged Grok container.
ROBOCO_GROK_MAX_COST_USD0.0(see reaper table) Per-agent Grok cost ceiling.

Optional subsystem flags (default-off unless noted)

These gate the env-toggled capabilities. Each is inert when off. See Optional capabilities.

Web research — default on

VariableDefaultPurpose
ROBOCO_RESEARCH_ENABLEDtrueMaster switch for web research. When false, the search MCP is not mounted into any agent.
ROBOCO_RESEARCH_PROVIDERtavilytavily / brave / exa / null.
ROBOCO_RESEARCH_API_KEY(unset)Provider key — server-side only, never reaches an agent. Unset = empty-result null provider.
ROBOCO_RESEARCH_MAX_RESULTS5Cap on results per search (1–20).
ROBOCO_RESEARCH_FETCH_MAX_CHARS20000Cap on extracted characters per fetch.
ROBOCO_RESEARCH_TIMEOUT_SECONDS15.0Per-request outbound timeout.
ROBOCO_RESEARCH_DAILY_QUOTA_PER_AGENT50Search+fetch calls per agent per UTC day.

GitHub repo provisioning — default on (inert without token/org)

VariableDefaultPurpose
ROBOCO_PROVISIONING_ENABLEDtrueMaster switch for pitch auto-provisioning. Inert with no token/org regardless.
ROBOCO_PROVISIONING_TOKEN(empty)GitHub PAT (repo + org admin) used to create repos — server-side only.
ROBOCO_PROVISIONING_ORG(empty)GitHub org where new repos are created.
ROBOCO_GITHUB_API_BASE_URLhttps://api.github.comOverride for GitHub Enterprise.
ROBOCO_PROVISIONING_TIMEOUT_SECONDS30.0Per-request provisioning timeout.
ROBOCO_PROVISIONING_REPO_PRIVATEtrueWhether provisioned repos are private.

Architectural conventions — off (config) / on (compose)

VariableDefaultPurpose
ROBOCO_CONVENTIONS_ENABLEDfalse (config) / true (compose)Master switch for the per-project conventions standard (scaffold, ambient injection, baseline constraints, gate enforcement). The compose orchestrator block defaults this on (left off in docker-compose.registry.yml); fully inert when off.

Toolchain matching — default off

VariableDefaultPurpose
ROBOCO_TOOLCHAIN_MATCH_ENABLEDfalse (config) / true (compose)Provision the agent workspace with the target project's Python and block delivery gates when the suite can't run. The compose orchestrator block defaults this on.

Provider overload break — default on

VariableDefaultPurpose
ROBOCO_OVERLOAD_BREAK_ENABLEDtruePark a provider on a persistent overload (HTTP 529/500/503) the way a 429 is parked, instead of crash-retrying.
ROBOCO_GATEWAY_HEALTH_ENABLEDtrueProbe a stale-heartbeat-but-live agent's gateway and kill + respawn it when the gateway is broken (a corrupted /app venv firing no verb), instead of the reaper protecting it forever. Off => spare live containers on verb-heartbeat liveness alone.
ROBOCO_GATEWAY_HEALTH_GRACE_SECONDS180How long an agent gateway may probe as broken before recovery — tolerates a transient probe miss.
ROBOCO_IMAGE_PRUNE_ENABLEDtrueBackground sweep prunes dangling (<none>) Docker images left by agent-image rebuilds, throttled ~6h. Only dangling images are removed — a tagged image or one backing a running container is never touched. Not a feature flag; disable to manage image cleanup yourself.

Strategy engine — default off

VariableDefaultPurpose
ROBOCO_STRATEGY_ENGINE_ENABLEDfalseMaster switch for the autonomous strategy engine (notify-only). When off the loop never runs.
ROBOCO_STRATEGY_ENGINE_INTERVAL_SECONDS1800Seconds between assessment passes.
ROBOCO_STRATEGY_STRANDED_BLOCKED_MINUTES120A task blocked longer than this is surfaced as stranded.

External / internal PR review — default off

VariableDefaultPurpose
ROBOCO_EXTERNAL_PR_ENABLEDfalse (config) / true (compose)Master switch for inbound external/fork PR review. The compose orchestrator block defaults this on.
ROBOCO_EXTERNAL_PR_POLL_INTERVAL_SECONDS300Seconds between inbound external-PR discovery passes.
ROBOCO_EXTERNAL_PR_AUTHOR_ALLOWLIST(empty)GitHub usernames auto-trusted. Empty = every external PR needs human confirmation.
ROBOCO_EXTERNAL_PR_REQUIRE_HUMAN_CONFIRMtrueRequire explicit human confirmation before any agent fetches/checks-out/executes external code.
ROBOCO_INTERNAL_PR_ENABLEDfalseAlso review org-repo (non-fork) PRs not tied to an active task.

Self-healing CI loop — default off

VariableDefaultPurpose
ROBOCO_SELF_HEAL_ENABLEDfalseMaster switch for the self-heal loop (detect + notify the CEO). When off the loop never runs.
ROBOCO_SELF_HEAL_PROJECT_SLUG(empty) / roboco-api (compose)The registered project that is RoboCo itself — the only repo the loop watches/originates into.
ROBOCO_SELF_HEAL_CI_WORKFLOWci.ymlGitHub Actions workflow file to scope the CI signal to.
ROBOCO_SELF_HEAL_ORIGINATE_ENABLEDfalseSecond opt-in: on a regression, also open a fix task and dispatch it to the Main PM automatically (no manual start). The loop never merges or deploys — the fix ships through the normal gates (QA, PR review, your merge).
ROBOCO_SELF_HEAL_INTERVAL_SECONDS1800Seconds between telemetry passes.
ROBOCO_SELF_HEAL_MAX_OPEN_TASKS3Rolling cap on concurrently-open self-heal tasks.
ROBOCO_SELF_HEAL_MAX_PER_CYCLE1Max self-heal tasks originated in one cycle.

Multi-repo CI-watch — default off

The global switch arms the engine; each project opts in via ci_watch_enabled (+ optional ci_watch_workflow) in the edit-project dialog.

VariableDefaultPurpose
ROBOCO_CI_WATCH_ENABLEDfalseMaster switch for watching opted-in projects' CI. When off the engine never runs and no CI telemetry is fetched.
ROBOCO_CI_WATCH_DEFAULT_WORKFLOWci.ymlWorkflow file to scope the CI signal to when a project sets no ci_watch_workflow of its own.
ROBOCO_CI_WATCH_INTERVAL_SECONDS1800Seconds between CI-watch passes.
ROBOCO_CI_WATCH_MAX_OPEN_TASKS3Rolling cap on concurrently-open CI-watch fix tasks per repo.
ROBOCO_CI_WATCH_MAX_PER_CYCLE1Max CI-watch fix tasks opened in one cycle.

Dependency-update bot — default off

The global switch arms the engine; each project opts in via dep_update_command (+ optional dep_update_paths) in the edit-project dialog. Detection is read-only — the command runs in a throwaway clone and only the lockfiles are diffed; the real repo is never mutated.

VariableDefaultPurpose
ROBOCO_DEP_UPDATE_ENABLEDfalseMaster switch for the dependency-update bot. When off nothing runs and no throwaway clone is made.
ROBOCO_DEP_UPDATE_INTERVAL_SECONDS604800Seconds between dependency-update passes (default weekly).
ROBOCO_DEP_UPDATE_MAX_OPEN_TASKS3Rolling cap on concurrently-open update-dependencies tasks per repo.
ROBOCO_DEP_UPDATE_MAX_PER_CYCLE1Max update-dependencies tasks opened in one cycle.

Gated release manager (default-off)

VariableDefaultPurpose
ROBOCO_RELEASE_MANAGER_ENABLEDfalseMaster switch for the gated release manager. When off the loop never runs and no release is proposed. Even on it only PROPOSES — the CEO approves before any publish.
ROBOCO_RELEASE_MIN_COMMITS8Minimum unreleased commits since the last tag before a release is proposed (a feat/security change also qualifies).
ROBOCO_RELEASE_MANAGER_INTERVAL_SECONDS3600Seconds between release-readiness assessment passes.

Organizational memory loop (default-off)

VariableDefaultPurpose
ROBOCO_ORG_MEMORY_ENABLEDfalseMaster switch for the org-memory loop. When off: legacy completion capture, no auto-inject, no playbook curation verbs.
ROBOCO_ORG_MEMORY_TOP_K3Max institutional-memory items injected into a briefing on claim.
ROBOCO_ORG_MEMORY_MIN_SCORE0.6Cosine-similarity floor for injected memory; below it, nothing is injected.

Next