Environment variables
Clawdia 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~/.clawdia/.env(aka$CLAWDIA_STATE_DIR/.env; does not override). - Config
envblock in~/.nelsonmuntz-c/clawdia.json(applied only if missing). - Optional login-shell import (
env.shellEnv.enabledorCLAWDIA_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:
CLAWDIA_LOAD_SHELL_ENV=1CLAWDIA_SHELL_ENV_TIMEOUT_MS=15000
Env var substitution in config
You can reference env vars directly in config string values using${VAR_NAME} syntax:
