Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

Environment Variables

The config file is the recommended way to configure agsh. Environment variables are useful as overrides – for example, in CI pipelines, containers, or when you want to temporarily switch providers without editing your config.

Environment variables override config file values but are overridden by CLI flags.

agsh-Specific Variables

VariableDescriptionExample
AGSH_PROVIDERLLM provider nameopenai, claude
AGSH_MODELModel identifiergpt-4o, claude-sonnet-4-20250514
AGSH_PERMISSIONDefault permission modenone, read, write
AGSH_CONFIG_DIROverride the default config directory. Points at the agsh directory itself (contains config.toml and skills/). The only isolation knob that works on every platform — dirs::config_dir() ignores $XDG_CONFIG_HOME on macOS/Windows./tmp/agsh-test/agsh

MCP Variables

VariableDescriptionDefault
AGSH_MCP_TOOL_TIMEOUTPer-call timeout for MCP tools, in milliseconds. Applies to every remote tool invocation; on timeout agsh cancels the request and returns an error to the model.600000 (600s)

Provider API Keys

VariableUsed When
OPENAI_API_KEYProvider is openai
CLAUDE_API_KEYProvider is claude

OAuth Authentication

VariableDescription
CLAUDE_OAUTH_TOKENOAuth access token for the Claude provider

OAuth tokens (with sk-ant-oat01- prefix) are also auto-detected when passed via CLAUDE_API_KEY.

On first use, the OAuth token is saved to the database and loaded automatically on subsequent launches. Setting the env var again replaces the stored token.

Provider Base URL

VariableDescription
OPENAI_BASE_URLCustom base URL for the OpenAI-compatible endpoint

Logging

agsh uses the tracing framework. The log level can be controlled with:

VariableDescriptionExample
RUST_LOGStandard Rust log filteragsh=debug, agsh=trace

If RUST_LOG is not set, the verbosity flag (-v, -vv, -vvv) controls the level:

FlagLevel
(none)warn
-vinfo
-vvdebug
-vvvtrace

Logs are written to stderr so they do not interfere with agent output.