Environment Variables
Environment variables
Section titled “Environment variables”CoderClaw pulls environment variables from multiple sources. The rule is never override existing values.
Precedence (highest → lowest)
Section titled “Precedence (highest → lowest)”- Process environment (what the Gateway process already has from the parent shell/daemon).
.envin the current working directory (dotenv default; does not override).- Global
.envat~/.coderclaw/.env(aka$CODERCLAW_STATE_DIR/.env; does not override). - Config
envblock in~/.coderclaw/coderclaw.json(applied only if missing). - Optional login-shell import (
env.shellEnv.enabledorCODERCLAW_LOAD_SHELL_ENV=1), applied only for missing expected keys.
If the config file is missing entirely, step 4 is skipped; shell import still runs if enabled.
Config env block
Section titled “Config env block”Two equivalent ways to set inline env vars (both are non-overriding):
{ env: { OPENROUTER_API_KEY: "sk-or-...", vars: { GROQ_API_KEY: "gsk-...", }, },}Shell env import
Section titled “Shell env import”env.shellEnv runs your login shell and imports only missing expected keys:
{ env: { shellEnv: { enabled: true, timeoutMs: 15000, }, },}Env var equivalents:
CODERCLAW_LOAD_SHELL_ENV=1CODERCLAW_SHELL_ENV_TIMEOUT_MS=15000
Env var substitution in config
Section titled “Env var substitution in config”You can reference env vars directly in config string values using ${VAR_NAME} syntax:
{ models: { providers: { "vercel-gateway": { apiKey: "${VERCEL_GATEWAY_API_KEY}", }, }, },}See Configuration: Env var substitution for full details.
Path-related env vars
Section titled “Path-related env vars”| Variable | Purpose |
|---|---|
CODERCLAW_HOME | Override the home directory used for all internal path resolution (~/.coderclaw/, agent dirs, sessions, credentials). Useful when running CoderClaw as a dedicated service user. |
CODERCLAW_STATE_DIR | Override the state directory (default ~/.coderclaw). |
CODERCLAW_CONFIG_PATH | Override the config file path (default ~/.coderclaw/coderclaw.json). |
CODERCLAW_HOME
Section titled “CODERCLAW_HOME”When set, CODERCLAW_HOME replaces the system home directory ($HOME / os.homedir()) for all internal path resolution. This enables full filesystem isolation for headless service accounts.
Precedence: CODERCLAW_HOME > $HOME > USERPROFILE > os.homedir()
Example (macOS LaunchDaemon):
<key>EnvironmentVariables</key><dict> <key>CODERCLAW_HOME</key> <string>/Users/kira</string></dict>CODERCLAW_HOME can also be set to a tilde path (e.g. ~/svc), which gets expanded using $HOME before use.