CoderClaw pulls environment variables from multiple sources. The rule is never override existing values.
.env in the current working directory (dotenv default; does not override)..env at ~/.coderclaw/.env (aka $CODERCLAW_STATE_DIR/.env; does not override).env block in ~/.coderclaw/coderclaw.json (applied only if missing).env.shellEnv.enabled or CODERCLAW_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.
env blockTwo equivalent ways to set inline env vars (both are non-overriding):
{
env: {
OPENROUTER_API_KEY: "sk-or-...",
vars: {
GROQ_API_KEY: "gsk-...",
},
},
}
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=15000You 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.
| 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_HOMEWhen 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.