Configuration
Paseo loads configuration from a single JSON file in your Paseo home directory, with optional environment variable and CLI overrides.
Where config lives
By default, Paseo uses ~/.paseo as its home directory. The configuration file is:
~/.paseo/config.json
You can change the home directory by setting PASEO_HOME or passing --home to paseo daemon start.
Precedence
Paseo merges configuration in this order:
- Defaults
config.json- Environment variables
- CLI flags
Lists append across sources (for example, hostnames and cors.allowedOrigins).
Example
Minimal example that configures listening address, hostnames, and MCP:
{
"$schema": "https://paseo.sh/schemas/paseo.config.v1.json",
"version": 1,
"daemon": {
"listen": "127.0.0.1:6767",
"hostnames": ["localhost", ".localhost"],
"mcp": { "enabled": true }
}
}
daemon.hostnames is the primary field. The old daemon.allowedHosts name still works as a deprecated alias for backward compatibility.
Agent providers
Agent providers, both the first-class ones Paseo ships with and custom entries you add under agents.providers, are documented on their own page.
See Providers for the mental model and Supported providers for the full list of agents Paseo can launch. For pointing Claude at Anthropic-compatible endpoints (Z.AI, Alibaba/Qwen), multiple profiles, custom binaries, ACP agents, and the additionalModels merge behavior, see Custom providers. The full field reference lives on GitHub at docs/custom-providers.md.
Voice
Voice is configured through features.dictation and features.voiceMode, with provider credentials under providers.
For voice philosophy, architecture, and complete local/OpenAI setup examples, see Voice docs.
Logging
Daemon logging uses separate console and file sinks by default:
- Console:
infoand above - File (
$PASEO_HOME/daemon.log):traceand above - File rotation:
10mmax file size,2retained files total (active + 1 rotated)
{
"log": {
"console": {
"level": "info",
"format": "pretty"
},
"file": {
"level": "trace",
"path": "daemon.log",
"rotate": {
"maxSize": "10m",
"maxFiles": 2
}
}
}
}
Legacy fields log.level and log.format are still supported and map to the new destination settings.
Password authentication
You can require a password to connect to the daemon. When set, all HTTP and WebSocket clients must authenticate. Only the /api/health liveness endpoint is exempt, so that process supervisors and load balancers can probe without credentials.
The easiest way to set a password is with the CLI:
paseo daemon set-password
This prompts for a password, writes the bcrypt hash to config.json, and tells you to restart the daemon.
Alternatively, set the PASEO_PASSWORD environment variable (plaintext, hashed automatically at startup):
PASEO_PASSWORD=my-secret paseo daemon start
Or write the hash directly in config.json:
{
"daemon": {
"auth": {
"password": "$2b$12$..."
}
}
}
After setting a password, restart the daemon for the change to take effect.
Connecting with a password
The CLI picks up a password from, in order:
-
The
passwordquery parameter on atcp://host URI:paseo --host "tcp://192.168.1.10:6767?password=my-secret" ls -
The
PASEO_PASSWORDenvironment variable, used as a fallback when the host carries no embedded password (works forlocalhost:6767, barehost:port, ortcp://hosts without apassword=query):PASEO_PASSWORD=my-secret paseo ls PASEO_PASSWORD=my-secret paseo --host 192.168.1.10:6767 ls
A password= in the URI always wins over the env var, so you can keep PASEO_PASSWORD set globally and still target a different daemon by spelling its password into the URI.
In the mobile app, enter the password in the direct connection setup screen.
Common env vars
PASEO_HOME, set Paseo home directoryPASEO_PASSWORD, on the daemon, the password to require (plaintext, hashed at startup); on the CLI, the password used to connect when the host URI doesn't include onePASEO_LISTEN, overridedaemon.listenPASEO_HOSTNAMES, override/extenddaemon.hostnamesPASEO_ALLOWED_HOSTS, deprecated alias forPASEO_HOSTNAMESPASEO_LOG_CONSOLE_LEVEL, overridelog.console.levelPASEO_LOG_FILE_LEVEL, overridelog.file.levelPASEO_LOG_FILE_PATH, overridelog.file.pathPASEO_LOG_FILE_ROTATE_SIZE, overridelog.file.rotate.maxSizePASEO_LOG_FILE_ROTATE_COUNT, overridelog.file.rotate.maxFilesPASEO_LOG,PASEO_LOG_FORMAT, legacy log overrides (still supported)OPENAI_API_KEY, override OpenAI provider keyPASEO_VOICE_LLM_PROVIDER, override voice LLM provider (claude,codex,opencode)PASEO_DICTATION_STT_PROVIDER,PASEO_VOICE_STT_PROVIDER,PASEO_VOICE_TTS_PROVIDER, override voice provider selection (localoropenai)PASEO_LOCAL_MODELS_DIR, control local model directoryPASEO_DICTATION_LOCAL_STT_MODEL, override local dictation STT modelPASEO_VOICE_LOCAL_STT_MODEL,PASEO_VOICE_LOCAL_TTS_MODEL, override local voice STT/TTS modelsPASEO_DICTATION_LANGUAGE,PASEO_VOICE_LANGUAGE, override dictation and voice STT languagePASEO_VOICE_LOCAL_TTS_SPEAKER_ID,PASEO_VOICE_LOCAL_TTS_SPEED, optional local voice TTS tuning
Schema
For editor autocomplete/validation, set $schema to:
https://paseo.sh/schemas/paseo.config.v1.json