Environment variables
Pllan 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~/.pllan/.env(aka$PLLAN_STATE_DIR/.env; does not override). - Config
envblock in~/.pllan/pllan.json(applied only if missing). - Optional login-shell import (
env.shellEnv.enabledorPLLAN_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:
PLLAN_LOAD_SHELL_ENV=1PLLAN_SHELL_ENV_TIMEOUT_MS=15000
Runtime-injected env vars
Pllan also injects context markers into spawned child processes:PLLAN_SHELL=exec: set for commands run through theexectool.PLLAN_SHELL=acp: set for ACP runtime backend process spawns (for exampleacpx).PLLAN_SHELL=acp-client: set forpllan acp clientwhen it spawns the ACP bridge process.PLLAN_SHELL=tui-local: set for local TUI!shell commands.
UI env vars
PLLAN_THEME=light: force the light TUI palette when your terminal has a light background.PLLAN_THEME=dark: force the dark TUI palette.COLORFGBG: if your terminal exports it, Pllan uses the background color hint to auto-pick the TUI palette.
Env var substitution in config
You can reference env vars directly in config string values using${VAR_NAME} syntax:
Secret refs vs ${ENV} strings
Pllan supports two env-driven patterns:
${VAR}string substitution in config values.- SecretRef objects (
{ source: "env", provider: "default", id: "VAR" }) for fields that support secrets references.
Path-related env vars
| Variable | Purpose |
|---|---|
PLLAN_HOME | Override the home directory used for all internal path resolution (~/.pllan/, agent dirs, sessions, credentials). Useful when running Pllan as a dedicated service user. |
PLLAN_STATE_DIR | Override the state directory (default ~/.pllan). |
PLLAN_CONFIG_PATH | Override the config file path (default ~/.pllan/pllan.json). |
Logging
| Variable | Purpose |
|---|---|
PLLAN_LOG_LEVEL | Override log level for both file and console (e.g. debug, trace). Takes precedence over logging.level and logging.consoleLevel in config. Invalid values are ignored with a warning. |
PLLAN_HOME
When set, PLLAN_HOME replaces the system home directory ($HOME / os.homedir()) for all internal path resolution. This enables full filesystem isolation for headless service accounts.
Precedence: PLLAN_HOME > $HOME > USERPROFILE > os.homedir()
Example (macOS LaunchDaemon):
PLLAN_HOME can also be set to a tilde path (e.g. ~/svc), which gets expanded using $HOME before use.