Environment variables
Clawdbot pulls environment variables from multiple sources. The rule is never override existing values.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~/.clawdbot/.env(aka$CLAWDBOT_STATE_DIR/.env; does not override). - Config
envblock in~/.clawdbot/clawdbot.json(applied only if missing). - Optional login-shell import (
env.shellEnv.enabledorCLAWDBOT_LOAD_SHELL_ENV=1), applied only for missing expected keys.
Config env block
Two equivalent ways to set inline env vars (both are non-overriding):
Shell env import
env.shellEnv runs your login shell and imports only missing expected keys:
CLAWDBOT_LOAD_SHELL_ENV=1CLAWDBOT_SHELL_ENV_TIMEOUT_MS=15000