Add an optional, local-first `vestige.toml` config file (loaded from the active data directory alongside vestige.db) that lets users control the default shape and size of high-traffic MCP responses without recompiling and without a cloud service. - New `vestige-core::config` module: `VestigeConfig` / `OutputConfig` / `OutputProfile` with a dependency-free, lenient minimal-TOML parser for the `[defaults]` table (detail_level, limit, profile). - Output profiles: lean | default | audit | research. `default` reproduces pre-2.1.24 behavior byte-for-byte so existing users see no change. - Precedence (per call): explicit MCP param > config file > built-in default. - Wired into search, memory_timeline, codebase (get_context), session_context. Each echoes the active `profile`; `lean` masks scores/timestamps via a shared `apply_output_masks` helper. - McpServer loads config once at construction from storage.data_dir(). - Tests: config precedence/profile unit tests in core (10) + per-tool precedence and lean-masking tests. Full workspace suite green, clippy -D warnings clean, dashboard check + build green. - Docs: new "Output Configuration (vestige.toml)" section in docs/CONFIGURATION.md and CHANGELOG 2.1.24 entry. Version bumped 2.1.23 -> 2.1.24. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
9.3 KiB
Configuration Reference
Environment variables, CLI commands, and setup options
First-Run Network Requirement
Vestige downloads the Nomic Embed Text v1.5 model (~130MB) from Hugging Face on first use. Qwen3 embeddings are opt-in and download their own Hugging Face model when selected.
All subsequent runs are fully offline.
Model Cache Location
The embedding model is cached in platform-specific directories:
| Platform | Cache Location |
|---|---|
| macOS | ~/Library/Caches/vestige/fastembed |
| Linux | ~/.cache/vestige/fastembed |
| Windows | %LOCALAPPDATA%\vestige\cache\fastembed |
Override with environment variable:
export FASTEMBED_CACHE_PATH="/custom/path"
Qwen3 currently uses Hugging Face Hub's Candle loader directly, so use the standard Hugging Face cache environment such as HF_HOME if you need to relocate that larger model cache.
Environment Variables
| Variable | Default | Description |
|---|---|---|
VESTIGE_DATA_DIR |
OS per-user data directory | Storage directory fallback; overridden by --data-dir; database lives at <dir>/vestige.db |
VESTIGE_EMBEDDING_MODEL |
nomic-v1.5 |
Embedding backend selector. Use qwen3-0.6b with a build that enables qwen3-embeddings |
RUST_LOG |
info (via tracing-subscriber) |
Log verbosity + per-module filtering |
FASTEMBED_CACHE_PATH |
Platform cache directory; ./.fastembed_cache fallback |
Embedding model cache location |
VESTIGE_DASHBOARD_PORT |
3927 |
Dashboard HTTP + WebSocket port |
VESTIGE_HTTP_ENABLED |
false |
Set true or 1 to enable optional MCP-over-HTTP |
VESTIGE_HTTP_PORT |
3928 |
Optional MCP-over-HTTP port; --http-port also enables HTTP |
VESTIGE_HTTP_BIND |
127.0.0.1 |
HTTP bind address |
VESTIGE_HTTP_ALLOWED_ORIGINS |
localhost origins for the HTTP port | Comma-separated browser origins allowed to call MCP-over-HTTP |
VESTIGE_AUTH_TOKEN |
auto-generated | Dashboard + MCP HTTP bearer auth |
VESTIGE_DASHBOARD_ENABLED |
false |
Set true or 1 to enable the web dashboard |
VESTIGE_CONSOLIDATION_INTERVAL_HOURS |
6 |
FSRS-6 decay cycle cadence |
Storage location precedence:
--data-dir <path>wins overVESTIGE_DATA_DIR; if neither is set, Vestige uses your OS's per-user data directory:~/Library/Application Support/com.vestige.core/on macOS,~/.local/share/vestige/core/on Linux,%APPDATA%\vestige\core\on Windows. Custom paths are directories, are created if missing, expand a leading~, and store the database at<dir>/vestige.db.
Output Configuration (vestige.toml)
Added in v2.1.24 (Roadmap Phase 2: Configurable Output).
You can control the default shape and size of high-traffic MCP responses with an optional config file. It is local-first — no cloud service is involved — and fully backward-compatible: with no file present, Vestige behaves exactly as it did before.
Location
The config file lives in the active Vestige data directory, alongside the database:
<data_dir>/vestige.toml # e.g. ~/Library/Application Support/com.vestige.core/vestige.toml
The data directory is resolved with the same precedence as storage
(--data-dir > VESTIGE_DATA_DIR > OS per-user data dir). A missing file, or a
file with no recognized keys, falls back to built-in defaults. The parser is
lenient: unknown keys and unknown sections are ignored, so the file can grow in
future releases without breaking older binaries.
[defaults] table
[defaults]
# Detail level for high-traffic tools: "brief" | "summary" | "full"
detail_level = "summary"
# Default result count for high-traffic tools (positive integer)
limit = 10
# Output profile: "lean" | "default" | "audit" | "research"
profile = "default"
All three keys are optional. detail_level and limit, when set, override the
selected profile's presets.
Output profiles
A profile presets a coherent bundle of detail level, default limit, and whether scores and timestamps are included:
| Profile | Detail | Default limit | Scores | Timestamps | Use when |
|---|---|---|---|---|---|
lean |
brief |
5 | dropped | dropped | Context budget matters most |
default |
summary |
tool default | shown | shown | Historical behavior (unchanged) |
audit |
full |
tool default | shown | shown | Reviewing or debugging memory state |
research |
full |
25 | shown | shown | Wide, detailed result sets |
Precedence
Resolved per call, highest to lowest:
- Explicit MCP parameter (e.g.
detail_level/limiton asearchcall) — always wins. vestige.toml— the[defaults]keys and the selected profile.- Built-in default — the
defaultprofile, identical to pre-v2.1.24 behavior.
Affected tools
search, memory_timeline, codebase (get_context), and session_context
resolve their default detail level and result limit through this config. Each of
these tools also echoes the active profile in its response so you can confirm
what was applied. Tools that take no detail_level/limit are unaffected.
Example: minimize context cost
[defaults]
profile = "lean"
Example: detailed audits without changing the profile
[defaults]
detail_level = "full"
limit = 50
Command-Line Options
vestige-mcp --data-dir /custom/path # Custom storage location
VESTIGE_DATA_DIR=~/.vestige vestige-mcp # Env fallback storage location
VESTIGE_DATA_DIR=./.vestige vestige stats # Point the CLI at the same custom DB
vestige-mcp --help # Show all options
CLI Commands (v1.1+)
Stats and maintenance were moved from MCP to CLI to minimize context window usage:
vestige stats # Memory statistics
vestige stats --tagging # Retention distribution
vestige stats --states # Cognitive state distribution
vestige health # System health check
vestige consolidate # Run memory maintenance
vestige restore <file> # Restore from backup
vestige portable-export <file> # Exact Vestige-to-Vestige archive
vestige portable-import <file> # Import exact archive into an empty database
vestige portable-import <file> --merge # Merge exact archive into this database
vestige sync <file> # Pull/merge/push through a file backend
Client Configuration
Codex (One-liner)
codex mcp add vestige -- /usr/local/bin/vestige-mcp
Codex (Manual)
Add to ~/.codex/config.toml:
[mcp_servers.vestige]
command = "/usr/local/bin/vestige-mcp"
Claude Code (One-liner)
claude mcp add vestige vestige-mcp -s user
Claude Code (Manual)
Add to ~/.claude/settings.json:
{
"mcpServers": {
"vestige": {
"command": "vestige-mcp"
}
}
}
Claude Desktop (macOS)
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"vestige": {
"command": "vestige-mcp"
}
}
}
Claude Desktop (Windows)
Add to %APPDATA%\Claude\claude_desktop_config.json:
{
"mcpServers": {
"vestige": {
"command": "vestige-mcp"
}
}
}
OpenCode
OpenCode supports global and project-local config. For a project-local setup, add to opencode.json:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"vestige": {
"type": "local",
"command": ["vestige-mcp"],
"enabled": true,
"timeout": 10000
}
}
}
For isolated per-project memory, pass the data directory in the command array:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"vestige": {
"type": "local",
"command": ["vestige-mcp", "--data-dir", "./.vestige"],
"enabled": true,
"timeout": 10000
}
}
}
See the OpenCode integration guide for global config, verification, and troubleshooting.
Custom Data Directory
For per-project or custom storage:
{
"mcpServers": {
"vestige": {
"command": "vestige-mcp",
"args": ["--data-dir", "/path/to/custom/dir"]
}
}
}
For a shell-level default:
export VESTIGE_DATA_DIR="/path/to/custom/dir"
--data-dir takes precedence over VESTIGE_DATA_DIR, so you can keep a global env default and still isolate one client or project with an explicit CLI argument.
See Storage Modes for more options.
Updating Vestige
Latest version:
vestige update
This updates vestige, vestige-mcp, and vestige-restore. It does not mutate
Claude Code Cognitive Sandwich companion files unless you explicitly request it.
Also refresh optional Claude Code companion files:
vestige update --sandwich-companion
Pin to specific version:
vestige update --version v2.1.21
Manage the optional Cognitive Sandwich layer without updating binaries:
vestige sandwich install
vestige sandwich install --enable-preflight
vestige sandwich install --enable-sanhedrin --sanhedrin-endpoint=http://127.0.0.1:11434/v1/chat/completions
Check your version:
vestige-mcp --version
Development
# Run tests
cargo test --all-features
# Run with logging
RUST_LOG=debug cargo run --release
# Build optimized binary
cargo build --release --all-features