@pellux/goodvibes-tui
v0.20.3
Published
Terminal-native GoodVibes product for coding, operations, automation, knowledge, channels, and daemon-backed control-plane workflows.
Maintainers
Readme
goodvibes-tui
A terminal-native AI coding, operations, automation, knowledge, and integration console with a typed runtime, omnichannel surfaces, structured memory/knowledge, and a raw ANSI renderer.
⚠️ Active early development — pre-1.0. This project is under active early development. CLI flags, config keys, slash commands, key bindings, daemon routes, and on-disk layouts can and do change quickly — sometimes across patch releases. There are no legacy/compat shims. Documentation always describes the current behavior, not historical behavior. When 1.0.0 ships the project freezes to enterprise-grade stability guarantees (semver, deprecation windows, migration guides). Until then: pin exact versions and read
CHANGELOG.mdbefore upgrading.
Start Here
GoodVibes is a Bun program. Install Bun first and make sure bun is on PATH, then install GoodVibes from the npm registry:
bun add -g @pellux/goodvibes-tui
bun pm trust -g @pellux/goodvibes-tui @pellux/goodvibes-sdk core-js tree-sitter-css tree-sitter-javascript tree-sitter-json tree-sitter-python tree-sitter-typescript
goodvibesBun blocks lifecycle scripts for untrusted global packages. The trust command is required after the first global install so GoodVibes can run its postinstall binary installer and every native dependency can run its install step. All packages in the trust command are required; if any remain untrusted, the install is incomplete. tree-sitter-javascript may appear more than once in the dependency tree, including under tree-sitter-typescript; trusting the package name covers those installed versions. Verify the global install with:
bun pm -g untrusted
goodvibes --version
goodvibes-daemon --versionbun pm -g untrusted must report Found 0 untrusted dependencies with scripts. If it lists any package, rerun the full trust command above. npm install -g @pellux/goodvibes-tui is also supported, but it does not install Bun for you. The package preinstall check fails with a clear message if bun is missing from PATH.
Or run from source:
git clone https://github.com/mgd34msu/goodvibes-tui.git
cd goodvibes-tui
bun install
export OPENAI_API_KEY=...
bun run devCommon entrypoints:
bun run dev— run the TUI from sourcebun run daemon— run the headless daemon/API host from sourcebun run build— compile the TUI entrypoint intodist/goodvibes./dist/goodvibes— run the compiled TUI binary
Release distribution:
- GitHub Releases are the primary distribution path for compiled binaries
bun add -g @pellux/goodvibes-tuiis the recommended global install path; the package is hosted on the npm registry and Bun installs from that registry directly- Bun global installs require trusting
@pellux/goodvibes-tuiso the package postinstall can download the matching TUI and daemon binaries; the dependency lifecycle packages currently requiring trust are@pellux/goodvibes-sdk,core-js,tree-sitter-css,tree-sitter-javascript,tree-sitter-json,tree-sitter-python, andtree-sitter-typescript npm install -g @pellux/goodvibes-tuiis supported on Linux, macOS, and WSL when Bun is already installed; the preinstall check verifies Bun, and the install script downloads the matching TUI and daemon binaries for the current platform- native Windows is not supported; use WSL on Windows
Common paths:
- global settings:
~/.goodvibes/tui/settings.json - project settings:
.goodvibes/tui/settings.json - secure secrets:
~/.goodvibes/tui/secrets.encor.goodvibes/tui/secrets.enc - compatibility secrets:
~/.goodvibes/goodvibes.secrets.json - services:
.goodvibes/tui/services.json - custom providers:
~/.goodvibes/tui/providers/*.json - schedules:
.goodvibes/tui/schedules.json - direct TLS certs:
~/.goodvibes/tui/certs/fullchain.pemand~/.goodvibes/tui/certs/privkey.pem
Deployment shapes:
- local TUI only
- TUI with in-process daemon/API host
- source-run headless daemon/API host
- omnichannel runtime with Slack, Discord, Telegram, Home Assistant, webhook, Teams, Matrix, and other surfaces
- remote peer/node-host runtime for distributed execution
Typical workflows:
- code inside the TUI with
read,edit,find,analyze,exec, and live control-room visibility - expose the daemon/API host for browser-based operator access, channels, webhooks, and future external clients
- consume the daemon/API host through stable typed contract artifacts and shared transport seams that back external SDK and companion-app clients
- ingest URLs, bookmarks, docs, spreadsheets, and artifacts into the structured knowledge system for later retrieval
- dispatch and review work across remote peers and node-host runners
The compiled binary is the TUI entrypoint built from src/main.ts. When danger.daemon and/or danger.httpListener are enabled, that same binary starts the daemon and HTTP listener in-process. bun run daemon uses the separate headless daemon entrypoint from source.
Inbound TLS can run in off, proxy, or direct mode. Direct mode defaults to the certificate files above unless explicit paths are configured. Outbound HTTPS trust uses Bun’s bundled roots by default and can be extended or replaced with custom CA files/directories for internal or enterprise endpoints. Operator auth now supports bearer headers and local session cookies across REST, SSE, and control-plane WebSocket flows.
Documentation
- Docs index
- Getting started
- Deployment and services
- Providers and routing
- Knowledge, artifacts, and multimodal
- Channels, remote runtime, and API
- Tools and commands
- Release and publishing
- Foundation artifacts
What is this
goodvibes-tui is a terminal-native product for coding, operations, automation, knowledge work, and integrations. The codebase is built around:
- terminal-native rendering
- Unicode-rich, cell-accurate UI primitives
- compact, token-efficient transcript behavior
- operator-facing control rooms for non-conversational state
- explicit runtime visibility for permissions, routing, health, remote execution, knowledge, and orchestration
- backend-first external surfaces for channels, future web clients, automation, and remote peers
The interface is rendered directly to the alternate screen buffer with raw ANSI escape sequences. Conversation, panels, modals, overlays, and the footer all share the same renderer foundation.
The runtime is organized around typed store domains, typed runtime events, a shared control plane for permissions and orchestration, and product surfaces for reviewing and repairing state. Agents run in-process with isolated histories, scoped tools, and optional worktrees. Operational state such as provider routing, local auth, daemon/gateway posture, channels, search, artifacts, structured knowledge, multimodal analysis, remote sessions, settings control-plane state, and task execution is routed into dedicated panels and APIs.
The TUI now consumes the extracted @pellux/goodvibes-sdk platform layer for shared contracts, daemon route surfaces, transports, remote runtime contracts, and other reusable runtime code. The repo keeps the terminal UI, host wiring, and product-specific composition while future surfaces consume the same SDK-backed runtime foundation.
Features
Multi-Provider Models And Routing
- Native OpenAI, Anthropic, OpenAI Codex, Gemini, InceptionLabs, Amazon Bedrock, Amazon Bedrock Mantle, Anthropic Vertex, and GitHub Copilot support plus a broad OpenAI-compatible/gateway layer
- Dynamic model catalog with benchmark metadata, provider auto-registration, custom provider JSON, and hot-reload
- Interactive model and provider pickers with family, capability, availability, and tier filtering
- Synthetic-provider failover that preserves free / paid / subscription boundaries
- Provider account control room with route posture, auth freshness, fallback risk, and recovery actions
Terminal-Native UI System
- Raw ANSI renderer with direct terminal control
- Shared Unicode glyph primitives for borders, cursors, meters, markers, and selection states
- Conversation, panels, and modals built on the same low-level renderer
- Width-aware overlays, stable bottom docking above the prompt, half-height message surfaces, and structured footer layers
- Shared panel workspace layout budgeting with renderer-owned visible-row budgets
- Copy/selection logic that strips decorative gutters and visual scaffolding from clipboard output
Conversation And Transcript Workflow
- Markdown rendering, syntax highlighting, inline diffs, collapsible blocks, bookmarks, block copy, and block save
- Transcript event navigation by family for operational browsing of long sessions
- Search overlays, compact line-number modes (
all,code,off), and block-level collapse/expand - Presentation routing for non-conversational runtime chatter into control-room panels
- Tracked assistant-message rendering that supports markdown tables, including tolerant handling of slightly malformed LLM-generated separator rows
Panels, Control Rooms, And Workspaces
- Split-pane panel system with panel picker, layout control, and keyboard-first focus behavior
- Dedicated control rooms for provider accounts, provider health, local auth, settings sync, remote, MCP, marketplace, orchestration, tasks, intelligence, worktrees, approvals, forensics, security, policy, cockpit, system messages, and more
- Summary-first heavy panels with posture, issues, next actions, and detail regions
- Routed system-message workspace for startup discovery and operational notices
- Cross-panel actions between Explorer, Preview, and Symbols so file browsing can open previews and jump to symbol locations directly from panel focus
- Live panels stay subscribed while open, so agent, tool, and thinking updates continue while the panel is visible
- Dedicated
Agentspanel provides a view-only live peek into running agent sessions while the background-process strip remains the fast-access surface below the prompt
Modal And Selection UX
- Modal stack navigation that unwinds correctly back to the slash-command menu and prior nested modals
- Search/list focus ownership in searchable modals, so typing only targets filter input when that row is actually focused
- Toggleable selection-modal behavior with
Space/Enterfor primary actions,Left/Rightfor booleans, enums, and numeric adjustments, andShift+Left/Shift+Rightfor step-by-10 number changes - Slash-command menu close behavior that fully clears command mode and prompt state on
Esc
Token And Usage Visibility
- Live thinking-strip token output that continues to advance even when visible response streaming is disabled
- Fresh-input versus cached-context accounting in the footer and token surfaces, so request counts separate new input from cache-read context while the context bar still reflects the full prompt footprint
- Reasoning-heavy OpenAI/OpenAI-compatible streams advance live token/output indicators for reasoning-delta providers
Agents, Tasks, And WRFC
- In-process agents with isolated history, scoped tools, optional worktrees, and structured communication lanes
- Archetype registry that supports built-ins and user-defined markdown archetypes
- Task lifecycle tracking across exec, agent, MCP, plugin, integration, daemon, scheduler, and ACP work
- Automated WRFC loops with review/fix/check chains, configurable gates, and explicit evidence in completion reports
- WRFC panel renders a constraint badge (
c:N/M) per chain, colored by aggregate satisfaction status - Expanded chain detail shows each constraint with status marker
[SAT],[UNS CRIT|MAJOR|MINOR](unsatisfied, severity-tagged), or[UNV](unverified), with*suffix for inherited constraints - Selected-chain summary shows satisfied/total/inherited counts at a glance
- Controller-flagged synthetic issues render above reviewer issues as
[CRITICAL]"Controller flags" - Agent-detail modal surfaces
systemPromptAddendum(WRFC engineer addendum) when present on the agent record - System-message router surfaces
WORKFLOW_CONSTRAINTS_ENUMERATEDas an operator-visible message when constraints are loaded - Built-in planning/strategy layer with TUI-owned project planning, passive SDK-backed planning artifacts, execution plans, adaptive plan modes, and status/explain/override controls
Tools And Intelligence
- Built-in native tools include
read,write,edit,find,exec,fetch,web-search,analyze,inspect,agent,state,workflow,registry,task,team,worklist,mcp,packet,query,remote,repl,control, andchannel - Native file tooling with notebook-aware read/write/edit, AST-aware editing, validation hooks, undo, and compact output shaping
- Sandbox-backed REPL/eval tooling with bounded JavaScript, TypeScript, Python, SQL, and GraphQL runtimes plus persisted REPL history
- Durable memory plus a structured knowledge backend with connectors, extractors, projection rendering, GraphQL, consolidation, and task-time packet injection
- Provider-backed web search with DuckDuckGo default plus SearXNG, Brave, Exa, Firecrawl, Tavily, and Perplexity adapters
- Artifact/file runtime for ingesting, storing, delivering, and reusing documents, images, audio, video, spreadsheets, JSON, markdown, and generated outputs
- Unified multimodal analysis runtime that routes images through media understanding, audio through STT, documents through TS extractors, and video through keyframe/transcript fusion
- Language intelligence with bundled LSP servers, tree-sitter grammars, diagnostics, symbols, references, hover, and outline support
- Intelligence control room with readiness, workflow entry points, and recovery guidance
Security, Auth, And Operational Controls
- Prompt / allow-all / custom permission modes with layered evaluation and risk analysis
- Policy bundle loading, signing, verification, divergence simulation, and rule-suggestion flows for permission changes
- Secure-secret hierarchy with
preferred_securestorage policy by default - Local daemon/listener auth with bootstrap credentials, local user management, password rotation, session revocation, bearer-or-cookie operator auth, and review surfaces
- Config-gated private-host remote fetches for multimodal and knowledge ingest so internal-network URL access is explicit instead of ambient
- Health, policy, security, and setup control surfaces for reviewing and repairing runtime posture
Ecosystem, MCP, And Remote
- Curated marketplace, plugin trust model, quarantine engine, rollback flows, recommendations, and product-control commands
- MCP lifecycle with trust posture, quarantine, reconnect behavior, repair flows, and tool projection into the main registry
- Distributed peer/node-host runtime with pairing, scoped tokens, work pull/complete flows, replay/review artifacts, and operator-facing remote inspection/recovery surfaces
Runtime Foundations
- Typed runtime store and typed runtime-event system with domain-specific dispatch
- Bootstrap composition root with explicit initialization order
- App-scoped runtime service graph with explicit operator and peer contract ownership instead of ambient singleton wiring
- Stable operator and peer client surfaces with direct, HTTP, SSE, and WebSocket transports for future terminal, web, and mobile shells
- Checked-in foundation artifacts for the operator contract, peer contract, canonical knowledge GraphQL schema, and canonical knowledge SQL schema under
docs/foundation-artifacts - Reference in-process and HTTP consumer examples under
examples/reference-operator-client,examples/reference-http-client, andexamples/reference-node-host - Explicit session submit/steer/follow-up semantics with lifecycle-state tracking, correlation/causation IDs, return-context summaries, knowledge capture, compaction, guidance, diagnostics, notifications, retention, idempotency, and integration-helper APIs
- Feature flags, profiles, profile sync bundles, live settings editing, and UI routing controls for system / operational / WRFC messages
- Performance budgets, panel-health contracts, telemetry exporters, and operator playbooks for stuck turns, reconnect failures, permission deadlocks, plugin degradation, and recovery scenarios
Evaluation, Replay, And Incident Analysis
- Evaluation harness with built-in suites, baselines, scorecards, and regression gates
- Deterministic replay tooling with load / step / seek / diff / export flows
- Forensics collector and registry with incident bundles, replay mismatch evidence, root-cause summaries, and export/capture flows
- State inspector and telemetry substrate with transition logs, time-travel buffers, hotspot sampling, and local ledger exporters
Integrations, Notifications, And Delivery
- Omnichannel delivery/runtime surfaces for
web,slack,discord,ntfy,webhook,telegram,google-chat,signal,whatsapp,imessage,msteams,bluebubbles,mattermost, andmatrix - Shared reply pipeline for progress, reasoning, tool output, and final replies across TUI, web, webhook, and channel-native surfaces
- GitHub automation webhook plus daemon/gateway surfaces for future web clients, companion apps, and remote node/device peers
- Delivery queue, dead-letter handling, delivery classification, and notification routing policies
- Local notification/webhook front doors plus portable remote/session handoff bundles
- Optional voice surface, TTS/STT/realtime providers, and teleport bundle workflows for adjacent operator experiences
- Managed hook workflows, contract inspection, hook simulation, and cron-like scheduled agent tasks
Supported Providers & Models
Models are sourced dynamically from models.dev. The model catalog is larger than the built-in runtime list below; the tables here describe the provider/search/voice/media surfaces shipped in source today.
Native chat/runtime providers
| Provider | Type | Notes |
|----------|------|-------|
| openai | Native | GPT-4/GPT-5 family, tool calling, TTS/STT/realtime voice coverage |
| anthropic | Native | Claude family |
| openai-codex | Native | OpenAI subscription/Codex path |
| gemini | Native | Gemini family, chat + embeddings |
| inceptionlabs | OpenAI-compat | Inception/Mercury models |
| amazon-bedrock | Native | Direct Bedrock route |
| amazon-bedrock-mantle | Native | Bedrock Mantle route |
| anthropic-vertex | Native | Anthropic via Google Vertex |
| github-copilot | Native | Copilot-backed chat/runtime integration |
| synthetic | Failover | Virtual provider; routes to the best available backend while preserving billing boundaries |
Built-in compatible and gateway providers
These register automatically when configured and participate in the same routing/model picker/runtime metadata surface:
openrouter,aihubmix,groq,cerebras,mistral,ollama-cloud,huggingface,nvidia,llm7deepseek,fireworks,microsoft-foundry,minimax,moonshot,qianfan,qwen,sglang,stepfun,together,venice,volcengine,xai,xiaomi,zai- gateway/proxy-style integrations:
cloudflare-ai-gateway,vercel-ai-gateway,litellm,copilot-proxy
Provider aliases: Catalog/provider aliases such as inception -> inceptionlabs, copilot -> github-copilot, dashscope -> qwen, x-ai -> xai, and z-ai -> zai are normalized automatically.
Web search providers
| Provider | Notes |
|----------|-------|
| duckduckgo | Built-in no-key default using Lite search + Instant Answer enrichment |
| searxng | Good self-hosted/meta-search option |
| brave | Structured web search API |
| exa | LLM-oriented search/research API |
| firecrawl | Search plus crawl/extraction workflows |
| tavily | LLM-oriented search/evidence API |
| perplexity | Search/research provider surface |
Voice providers
| Provider | Capabilities |
|----------|--------------|
| openai | tts, stt, realtime |
| elevenlabs | tts, stt, realtime |
| deepgram | stt |
| google | stt |
| microsoft | tts |
| vydra | tts |
Media understanding and generation
- Image understanding providers:
openai,gemini,anthropic, and local OpenAI-compatible multimodal backends - Generation providers:
byteplus,runway,alibaba,fal,comfy - Multimodal analysis combines media providers, voice STT providers, and built-in document extractors behind one packet/write-back surface
Local Server Discovery
goodvibes-tui auto-discovers local inference servers on startup. Supported server types:
- Ollama (port 11434)
- LM Studio (port 1234)
- vLLM (detected via
x-vllm-*response headers) - llama.cpp / LocalAI (detected via server header)
- Text Generation Inference (TGI)
- Jan, GPT4All, KoboldCpp, Aphrodite
Discovered servers are registered automatically as OpenAI-compatible providers at startup.
Synthetic Failover Provider
The synthetic provider groups the same model across multiple backends under a single selectable entry. When one backend hits a rate limit or error, requests fail over automatically to the next. Models are cataloged from models.dev (4,000+ models, 100+ providers) with a 24-hour TTL cache.
Many model providers support configurable reasoning effort levels. Selectable options include: instant, low, medium, high.
Custom Providers
Any OpenAI-compatible API can be added by dropping a JSON file in ~/.goodvibes/tui/providers/:
{
"name": "openrouter",
"displayName": "OpenRouter",
"type": "openai-compat",
"baseURL": "https://openrouter.ai/api/v1",
"apiKeyEnv": "OPENROUTER_API_KEY",
"models": [
{
"id": "anthropic/claude-sonnet-4-6",
"displayName": "Claude Sonnet 4.6 (via OpenRouter)",
"description": "Anthropic Claude Sonnet 4.6 via OpenRouter",
"contextWindow": 200000,
"capabilities": {
"toolCalling": true,
"codeEditing": true,
"reasoning": true,
"multimodal": true
}
}
]
}Provider configs are hot-reloaded on file change. Use the /add-provider skill for interactive guided setup with smart defaults for popular providers.
Setup
Prerequisites
- Bun v1.0 or later
- Optional: Go for Go LSP support (gopls auto-installs via
go install) - Optional: For Rust development,
rust-analyzeris auto-downloaded from GitHub releases
Install
git clone https://github.com/mgd34msu/goodvibes-tui.git
cd goodvibes-tui
bun installConfigure API Keys
API keys resolve from environment variables first, then from the GoodVibes secret store. The local store can hold encrypted values directly or provider-backed secret references for Bitwarden, Vaultwarden, Bitwarden Secrets Manager, 1Password, files, and command-backed resolvers.
Set environment variables:
| Provider | Primary Env Var | Accepted Aliases | Type |
|----------|----------------|-----------------|------|
| Anthropic | ANTHROPIC_API_KEY | CLAUDE_API_KEY | Paid |
| OpenAI | OPENAI_API_KEY | OPENAI_KEY | Paid |
| Google Gemini | GEMINI_API_KEY | GOOGLE_API_KEY, GOOGLE_GEMINI_API_KEY | Paid |
| InceptionLabs | INCEPTION_API_KEY | — | Paid |
| Mistral | MISTRAL_API_KEY | — | Paid |
| OpenRouter | OPENROUTER_API_KEY | — | Free tier available |
| Groq | GROQ_API_KEY | — | Free (LPU inference) |
| Cerebras | CEREBRAS_API_KEY | — | Free (wafer-scale inference) |
| AIHubMix | AIHUBMIX_API_KEY | — | Free tier (rate-limited) |
| HuggingFace | HF_API_KEY | HUGGINGFACE_API_KEY, HF_TOKEN | Free tier (rate-limited) |
| Ollama Cloud | OLLAMA_CLOUD_API_KEY | OLLAMA_API_KEY | Free |
| NVIDIA NIM | NVIDIA_API_KEY | — | 1000 free credits |
| LLM7 | LLM7_API_KEY | — | Free |
Additional built-in integrations resolve from the same env/secrets path:
- LLM/gateway providers:
AWS_BEARER_TOKEN_BEDROCK,AWS_ACCESS_KEY_ID,AWS_SECRET_ACCESS_KEY,GOOGLE_APPLICATION_CREDENTIALS,ANTHROPIC_VERTEX_PROJECT_ID,GOOGLE_CLOUD_PROJECT,COPILOT_GITHUB_TOKEN,GH_TOKEN,GITHUB_TOKEN,DEEPSEEK_API_KEY,FIREWORKS_API_KEY,AZURE_OPENAI_API_KEY,MINIMAX_API_KEY,MOONSHOT_API_KEY,QIANFAN_API_KEY,QWEN_API_KEY,DASHSCOPE_API_KEY,MODELSTUDIO_API_KEY,SGLANG_API_KEY,STEPFUN_API_KEY,TOGETHER_API_KEY,VENICE_API_KEY,VOLCANO_ENGINE_API_KEY,XAI_API_KEY,XIAOMI_API_KEY,ZAI_API_KEY,CLOUDFLARE_AI_GATEWAY_API_KEY,AI_GATEWAY_API_KEY,LITELLM_API_KEY,COPILOT_PROXY_API_KEY - Search and media:
PERPLEXITY_API_KEY,DEEPGRAM_API_KEY,ELEVENLABS_API_KEY,XI_API_KEY,VYDRA_API_KEY,BYTEPLUS_API_KEY,FAL_KEY,FAL_API_KEY,COMFY_API_KEY,RUNWAYML_API_SECRET,RUNWAY_API_KEY
Alternatively, store keys encrypted using the /secrets command. Environment variables take precedence when both are set:
/secrets set OPENAI_API_KEY sk-...For self-hosted or external secret managers, link a GoodVibes key to a provider-backed SecretRef:
/secrets link OPENAI_API_KEY goodvibes://secrets/bitwarden?item=GoodVibes%20OpenAI&field=password&sessionEnv=BW_SESSION
/secrets link SLACK_BOT_TOKEN goodvibes://secrets/vaultwarden?item=GoodVibes%20Slack&field=password&server=https%3A%2F%2Fvault.example.test
/secrets link STRIPE_TOKEN goodvibes://secrets/bws/00000000-0000-0000-0000-000000000000?field=value&accessTokenEnv=BWS_ACCESS_TOKEN
/secrets link OPENAI_API_KEY goodvibes://secrets/1password?vault=Private&item=GoodVibes%20OpenAI&field=API%20KeyUse /secrets providers for supported provider shapes and /secrets test <secret-ref> to validate a ref without printing its value.
Synthetic Failover Provider
The synthetic provider groups models available from multiple backends. When one provider hits a rate limit, requests fail over automatically to the next. To enable failover, set API keys for multiple free providers:
# Recommended minimum for failover
export GROQ_API_KEY="..."
export HF_API_KEY="..."
export NVIDIA_API_KEY="..."
export OLLAMA_CLOUD_API_KEY="..."
export OPENROUTER_API_KEY="..."
export AIHUBMIX_API_KEY="..."Then select any model from the synthetic provider (e.g., gpt-oss-120b, kimi-k2.5, qwen-3.5-397b). See Synthetic Provider & Intelligent Failover for full details on failover behavior.
Run
bun run devRun the optional daemon/API host
GOODVIBES_DAEMON_TOKEN=... GOODVIBES_HTTP_TOKEN=... bun run daemonThe daemon/gateway surface is optional, but it is what powers omnichannel routes, the browser-based operator surface, remote peers, knowledge/media APIs, and future external clients.
Build a standalone binary
bun run build
# outputs dist/goodvibesbun run build compiles src/main.ts into dist/goodvibes. The compiled binary runs the TUI and can also host the daemon and HTTP listener in-process when danger.daemon and/or danger.httpListener are enabled in config. The default build does not produce a separate compiled daemon-only executable.
Synthetic Provider & Intelligent Failover
What are synthetic models?
Synthetic models are models available from multiple providers, automatically grouped by the system under a single selectable entry. When you pick a synthetic model, the system routes your request to the best available backend — you never need to think about which provider is serving it.
- Models with different naming across providers (e.g.,
GPT-4ovsgpt 4o) are automatically merged into one entry - Each synthetic model shows how many providers are available for failover in the model picker
Transparent failover
Failover behavior:
- Rate limit (429) — immediately retries the next provider in the pool
- Server error (500) or network error — retries the next provider after a 5-second cooldown
- Client error (400 Bad Request) — does NOT trigger failover; the error indicates a problem with the request itself, not the provider
- All providers temporarily exhausted with short cooldowns (≤120s) — the system automatically waits for the shortest cooldown to expire and retries
Failover is silent by default. The model name in the status bar does not change when switching backends for the same synthetic model.
Cross-model failover (free models only)
When every provider for a free synthetic model is exhausted and cooldowns are too long to wait:
- The system automatically falls back to the next-best free model, ranked by benchmark score
- The user is notified inline (non-blocking) about the model change
- This cascading continues until a working free model is found
- Free/paid/subscription tiers never mix — cross-model failover only happens within the free tier
IMPORTANT NOTE:
This system is not perfect, and there are ways it could result in charges accruing.
This includes but is not limited to when a provider moves a model from free to paid and you have kept the goodvibes-tui session running for longer than 24 hours (and have not run a model refresh manually in that time period). The system will not know that the model is now a paid model.
Refreshes happen automatically if a new session is started (or session is resumed) after the 24-hour TTL expires for the model list. For long-running sessions, please ensure that the models are refreshed daily.
Paid and subscription model exhaustion
Paid and subscription models do not auto-failover to a different model. The user made a deliberate, cost-conscious choice.
When a paid or subscription model is exhausted, the system shows a clear message with recovery options:
- Wait for the cooldown to expire and retry
- Switch to a different model with
/model - Switch to a free synthetic model
Model picker grouping
- Synthetic models are split into Top Models (S-tier or A-tier by benchmark) and All Synthetic
- Each entry shows the number of providers available (e.g.,
4 providers) - Quality tier badges [S/A/B/C] are displayed next to model names based on composite benchmark score
Configuration
Settings are layered, not stored in a single working-directory file:
- defaults
- global TUI settings:
~/.goodvibes/tui/settings.json - project overrides:
.goodvibes/tui/settings.json - CLI/runtime overrides
The shared file ~/.goodvibes/goodvibes.json is reserved for future cross-app state; TUI settings do not live there. You can view and edit settings live with the fullscreen /config workspace or /settings.
Related storage paths:
- secure secrets:
~/.goodvibes/tui/secrets.encand project/ancestor.goodvibes/tui/secrets.enc - plaintext compatibility secrets:
~/.goodvibes/goodvibes.secrets.jsonand project/ancestor.goodvibes/goodvibes.secrets.json - service registry:
.goodvibes/tui/services.json, with service-backed auth/account surfaces in the TUI and daemon - custom provider JSON:
~/.goodvibes/tui/providers/*.json - keybindings:
~/.goodvibes/tui/keybindings.json - REPL history:
.goodvibes/tui/repl-history.json - schedules:
.goodvibes/tui/schedules.json
Key Settings
| Key | Default | Description |
|-----|---------|-------------|
| display.stream | true | Stream responses token by token |
| display.lineNumbers | off | Line-number mode: off, code, or all |
| display.collapseThreshold | 30 | Lines before a block auto-collapses |
| display.theme | vaporwave | Color theme |
| display.showThinking | false | Show model thinking traces |
| display.showTokenSpeed | false | Show tokens/sec in status bar |
| provider.model | openrouter/free | Active model ID |
| provider.reasoningEffort | medium | Reasoning depth for supported models |
| provider.systemPromptFile | | Path to a custom system prompt file |
| `behavior.autoApprove` | `false` | Auto-approve all tool permission prompts |
| `behavior.autoCompactThreshold` | `80` | Context % before auto-compact triggers |
| `behavior.saveHistory` | `true` | Persist conversation history |
| `behavior.returnContextMode` | `off` | Session return-context mode: `off`, `local`, `assisted` |
| `behavior.guidanceMode` | `minimal` | Operational guidance mode: `off`, `minimal`, `guided` |
| `storage.secretPolicy` | `preferred_secure` | Secret storage policy: prefer secure backing store, fall back when allowed |
| `permissions.mode` | `prompt` | Permission mode: `prompt`, `allow-all`, `custom` |
| `ui.systemMessages` | `panel` | Route general system messages to `panel`, `conversation`, or `both` |
| `ui.operationalMessages` | `panel` | Route operational runtime notices to `panel`, `conversation`, or `both` |
| `ui.wrfcMessages` | `both` | Route WRFC/orchestration updates to `panel`, `conversation`, or `both` |
| `danger.agentRecursion` | `false` | Allow agents to spawn subagents |
| `danger.maxGlobalAgents` | `8` | Max simultaneous agents |
| `danger.daemon` | `false` | Enable daemon mode (POST /task) |
| `danger.httpListener` | `false` | Enable HTTP webhook listener |
| `tools.autoHeal` | `false` | Auto-fix syntax errors on write/edit |
| `tools.hooksFile` | `hooks.json` | Hook configuration file name |
| `cache.enabled` | `true` | Enable provider-aware prompt caching |
| `cache.stableTtl` | `1h` | TTL for stable content (system prompt + tools) |
| `cache.monitorHitRate` | `true` | Track and warn on low cache hit rates |
| `helper.enabled` | `false` | Route grunt work to a cheaper helper model |
| `helper.globalProvider` | | Helper model provider (e.g., ollama) |
| helper.globalModel | `` | Helper model ID (e.g., llama3.2:3b) |
Permission Modes
prompt(default) — ask before write, edit, exec, fetch, agent, workflow, and MCP callsallow-all— never prompt, allow everythingcustom— per-tool overrides usingpermissions.tools.<name>keys
Per-tool values: allow, prompt, deny.
Control Rooms, Routing, And Operator Surfaces
GoodVibes is built around routing runtime state to the right surface.
The current product ships dedicated workspaces for:
- provider accounts and provider health
- local auth and local service posture
- settings sync and managed-settings review
- remote peers, node-host contracts, work queues, and artifacts
- knowledge, memory review, and structured projection surfaces
- channels, deliveries, route bindings, and surface setup/doctor flows
- voice, media, search, and multimodal runtime posture
- sandbox posture, presets, setup, and recovery
- MCP posture, trust, reconnect, and repair
- marketplace, plugins, hooks, orchestration, tasks, intelligence, worktrees, approvals, and system messages
Heavy operational surfaces are summary-first:
- posture
- current issues
- next actions
- then deeper detail
Routing is configurable with:
ui.systemMessagesui.operationalMessagesui.wrfcMessages
This is how startup discovery, runtime notices, and orchestration chatter can be sent to a panel, the conversation, or both.
The gateway/event layer is also a first-class product surface. Runtime domains such as session, tasks, agents, automation, routes, control-plane, deliveries, surfaces, watchers, transport, ops, and knowledge are exposed through the control plane.
The notification layer applies policy-aware routing, batching, and visibility controls:
- quiet-while-typing suppression
- adaptive batching and burst control
- domain verbosity settings
- panel jump and dismiss actions
- routing decisions that favor control rooms for low-signal operational noise
That routing stack lives under src/runtime/notifications/* and helps keep the conversation surface compact even when the runtime is busy.
Underneath those surfaces, GoodVibes uses a typed runtime store backed by zustand/vanilla. Conversation, session, permissions, tasks, agents, orchestration, communication, plugins, MCP, ACP/daemon transport, integrations, intelligence, and other domains are updated through typed dispatch paths.
Sandbox, Isolation, And QEMU
GoodVibes includes a real sandbox control plane for both evaluation runtimes and MCP isolation.
Isolation controls:
- REPL isolation:
shared-vmorper-runtime-vm - MCP isolation:
disabled,shared-vm,hybrid,per-server-vm - host posture on Windows:
native-basicorrequire-wsl - VM backend:
localorqemu
The QEMU path includes:
- setup bundle generation under the user GoodVibes data directory by default
- first-run bootstrap scaffolding
- Debian cloud-image download, mutable qcow2 clone, resize, and NoCloud ISO creation through the generated
create-image.sh - host-side wrapper generation
- guest cloud-init seed generation for the
goodvibessudo user, SSH key auth,/workspace, andens3DHCP - guest-test and wrapper-test validation
- session-backed command execution
- guest bundle export / inspect flows
- setup manifest export / apply flows
attachandlaunch-per-commandexecution modes- REPL/MCP-friendly guest bootstrap packages for Python, JavaScript, TypeScript, SQL, GraphQL, Bun, Deno, DuckDB, Go, Rust, Ruby, and common CLI build/search tools
- guest JavaScript-family REPL execution through
sandbox.replJavaScriptCommand, defaulting the generated QEMU setup to/home/goodvibes/.bun/bin/bun
Key commands:
/setup sandbox/sandbox review/sandbox recommend/sandbox doctor/sandbox probe/sandbox qemu setup [dir]/sandbox qemu bootstrap [dir] [size-gb] [--scaffold-only|--no-build|--no-provision]/sandbox qemu inspect-setup <manifest>/sandbox qemu apply-setup <manifest>/sandbox session .../sandbox guest-bundle export <path>/sandbox guest-bundle inspect <path>
Typical first-run path:
/sandbox qemu bootstrap
/sandbox doctor
/sandbox guest-test eval-pyBy default, QEMU setup files, the mutable qcow2 image, SSH keys, logs, and runtime state live in ~/.goodvibes/tui/sandbox, not in the current project. Pass an explicit directory only when you intentionally want a non-default bundle location. Use /sandbox qemu setup or /sandbox qemu bootstrap --scaffold-only if you want to generate/review the bundle without building the image or provisioning guest runtimes.
See QEMU sandbox bootstrapping for host prerequisites, generated files, first-boot behavior, guest runtime packages, and troubleshooting logs.
Remote, Local Services, And Integration Helpers
Omnichannel surfaces
GoodVibes includes a shared channel/runtime layer.
Current surfaces:
tuiwebslackdiscordntfywebhookhomeassistanttelegramgoogle-chatsignalwhatsappimessagemsteamsbluebubblesmattermostmatrix
Inbound adapters, target resolution, account/setup metadata, doctor hooks, routing, and delivery are all driven through the channel runtime.
Remote runtime
The remote runtime is a distributed peer system with:
- pair requests and challenge verification
- peer tokens, scopes, heartbeat, and disconnect/revoke flows
- work queues with claim/lease/complete lifecycle
- node-host contract inspection
- remote review artifacts and recovery posture
- capability inspection and rerun-local-from-artifact flows
Key commands:
/remote/remote show <runner>/remote capabilities [runner]/remote recover [runner]/remote dispatch .../remote dispatch-pool <pool> .../remote export <runner>/remote artifact show <id>/remote import <path>
Local daemon and HTTP listener
Local service surfaces are opt-in:
danger.daemondanger.httpListener
They are protected by local auth, which includes:
- bootstrap credentials written to the bootstrap file
- local user management
- password rotation
- session revocation
- review surfaces in both commands and panels
Once enabled, the daemon exposes a substantial backend surface for:
- provider accounts, usage, routing, and health
- gateway/operator state and browser-based operator review
- knowledge ingest/search/GraphQL/projections/jobs/schedules
- artifacts, media generation, voice, web search, and multimodal analysis
- channels, deliveries, and route bindings
- remote peer pairing, work dispatch, and node-host contracts
The control-plane surface is typed and transport-aware:
/api/control-planefor the live gateway snapshot/api/control-plane/methodsand/api/control-plane/events/catalogfor method/event discovery/api/control-plane/eventsfor SSE subscriptions/api/control-plane/wsfor WebSocket clients/api/control-plane/webfor the built-in browser/operator shell
Key commands:
/auth local review/auth local add-user <username> <password> [roles]/auth local rotate-password <username> <password>/auth local revoke-session <token-or-fingerprint>/auth local clear-bootstrap-file
Integration helpers
GoodVibes also exposes integration-helper APIs for future clients and helpers:
- another GoodVibes instance
- a future web frontend or companion app
- setup/auth helpers
- operational integrations that need session, approval, account, health, knowledge, search, artifact, or delivery posture
This layer is meant to expose control/state APIs, not a UI protocol.
The adjacent local-product access layer also includes dedicated front doors for:
- provider login/logout flows
- install and update posture review
- trust review bundles
- bridge status/review/export/import paths
- setup deep links and portable install/update/auth review bundles
- deeplink review and bundle packaging for operator surfaces
Key commands:
/login/logout/install/update/trust/bridge/profilesync
The setup surface is also broader than a single readiness screen:
- onboarding and doctor flows
- service, hook, remote, and sandbox review
- support-bundle export
- setup-transfer export / inspect / import
- deep links for cockpit, security, remote, knowledge, incident, hooks, orchestration, and tasks
Policy, Permissions, And Trust
The permission system is more than a prompt toggle. The runtime includes:
- layered policy evaluation for prefix rules, arg-shape rules, path scope, network scope, and mode constraints
- decision logs for audit and review
- policy preflight review before applying bundles
- rule suggestion generation from actual approval decisions
- policy signing and signature verification
- simulation and divergence reporting for candidate policy bundles before promotion
- policy runtime state with bundle lifecycle, promote, rollback, and diff support
The adjacent trust layer covers:
- plugin trust tiers
- quarantine and degraded posture
- marketplace and MCP trust review
- security/policy control-room surfaces for review and remediation
The result is that approvals, policy rollout, trust posture, and plugin degradation are inspectable product behavior.
Automation, Hooks, And Scheduling
GoodVibes includes an automation layer with:
- managed hooks with scaffold, chain, enable/disable, inspect, import/export, and simulation flows
- hook-point contracts with execution authority, mutation/injection permissions, timeout policy, and failure policy metadata
- workflow state machines such as
wrfc,fix_loop,test_then_fix, andreview_only - cron-like scheduled agent tasks with timezone-aware schedules, missed-run tracking, run history, and manual trigger support
- TUI-owned project planning with readiness gaps, one-question-at-a-time clarification, project language, decision records, task/dependency/verification metadata, and explicit execution approval
- planning commands with project-planning inspection, active-plan review, and mode/explain/override/status controls
Key commands:
/hooks/workflow/schedule/plan
The goal is to make recurring operational work, review loops, and reaction policies explicit, inspectable, and schedulable.
Services, Profiles, And Setup Transfer
The services/config side is also productized beyond a flat JSON file:
- named service registry with inspect, auth resolution, connectivity tests, auth review, and doctor output
- first-class SecretRef-backed service credentials through env, GoodVibes local storage, file, exec, 1Password, Bitwarden, Vaultwarden, and Bitwarden Secrets Manager providers
- live profile management plus portable profile sync bundle export/import
- setup transfer bundles that can move config/services/ecosystem posture between environments
Key commands:
/services inspect|test|resolve|auth|auth-review|doctor|export|import/profiles/profilesync/setup transfer export|inspect|import
Service entries can use existing tokenKey fields, a SecretRef in the key field, or explicit tokenRef / passwordRef / webhookUrlRef / signingSecretRef / publicKeyRef / appTokenRef fields:
{
"slack": {
"name": "slack",
"authType": "bearer",
"tokenKey": "SLACK_BOT_TOKEN",
"appTokenKey": "SLACK_APP_TOKEN",
"tokenRef": {
"source": "vaultwarden",
"item": "GoodVibes Slack",
"field": "password",
"server": "https://vault.example.test"
},
"appTokenRef": {
"source": "vaultwarden",
"item": "GoodVibes Slack App",
"field": "password",
"server": "https://vault.example.test"
}
}
}Marketplace, Plugins, And Curated Ecosystem Paths
The ecosystem layer is broader than a basic enable/disable plugin list.
Current capabilities include:
- local plugin discovery across configured search directories
- plugin inspect/review output with trust tier, quarantine posture, capability counts, and signature fingerprint visibility
- curated ecosystem catalogs with publish-local, unpublish, catalog review, install, update, uninstall, and installed-receipt flows
- local-first curated plugin distribution via
.goodvibes/tui/ecosystem/*.json - recommendations tied to installed state, denials, and missing capabilities
Key commands:
/plugin list|inspect|review|browse|catalog-review|publish-local|install|update|uninstall/marketplace
So the product supports both direct local plugins and a curated local-first ecosystem channel with review and receipt tracking.
Tools
goodvibes-tui ships 20+ built-in tools. They cover native file and shell operations, bounded eval, coordination/work management, channels, search, MCP/remote control, planning artifacts, and product-control inspection surfaces.
REPL / Eval runtimes
GoodVibes also ships a live bounded repl tool backed by the sandbox/session layer. The current runtimes are:
- JavaScript
- TypeScript
- Python
- SQL
- GraphQL
These are real runtime profiles wired through sandbox profiles such as eval-js, eval-ts, eval-py, eval-sql, and eval-graphql, and REPL history is persisted under .goodvibes/tui/repl-history.json.
The important nuance is that the runtimes are intentionally bounded:
- JavaScript and TypeScript evaluate inside the sandbox exec path
- Python runs in an ephemeral virtualenv
- SQL evaluates against an ephemeral in-memory SQLite database
- GraphQL currently provides bounded GraphQL expression analysis/normalization through the REPL path
Durable memory / knowledge
GoodVibes has three distinct context layers:
- session memory for lightweight pinned notes that only live for the current session
- durable reviewed memory stored in SQLite for reuse, review, export, and task-time injection
- a structured knowledge store with sources, nodes, edges, issues, extractions, usage records, consolidation candidates/reports, schedules, GraphQL, and markdown/wiki-style projections
Durable record classes currently include:
decisionconstraintincidentpatternfactriskrunbookarchitectureownership
Key capabilities:
- scopes:
session,project,team - review states:
fresh,reviewed,stale,contradicted - confidence scores
- provenance links back to sessions, turns, tasks, events, and files
- links between memory records
- review queues and promotion flows
- bundle export/import and handoff export/import
- task-time knowledge selection and injection based on task text, write scope, graph relations, and usage scoring
- structured capture from incidents, policy preflight, MCP posture, and plugin posture
- connector-based ingest for URLs, bookmark exports, URL lists, and artifacts
- TS extractors for HTML/text/markdown/JSON/CSV/TSV/XML/YAML/PDF text/DOCX/XLSX/PPTX
- GraphQL schema + query/mutation surface over the knowledge store
- projection rendering/materialization for overview pages, rollups, backlinks, source health, and exportable markdown/wiki bundles
- scheduled knowledge jobs including
lint,reindex,refresh-stale,refresh-bookmarks,rebuild-projections,light-consolidation, anddeep-consolidation - usage-ledger and consolidation pipeline for candidate scoring, promotion, and report generation
- reviewed memory mirrored into structured knowledge for later retrieval and packet building
- sqlite-vec indexing backed by a pluggable embedding registry with providers for local hashed embeddings, OpenAI, OpenAI-compatible/LM Studio, Gemini, Mistral, and Ollama
There is also a genuine self-improvement loop here:
- failures and incidents can be captured into durable memory
- policy, MCP, and plugin posture can be promoted into durable reviewed knowledge
- operators can review, mark stale, contradict, or promote records
- knowledge jobs can refresh stale sources, rebuild projections, reindex reviewed memory, and run light/deep consolidation
- future tasks can receive automatically selected reviewed knowledge injections
- the runtime can explain exactly which knowledge records it would inject for a task and why
The system supports iterative operator review and reuse of lessons learned in later work.
Key commands:
/recall add .../recall search .../recall queue/recall review .../recall explain .../recall promote .../recall capture .../recall export .../recall import .../recall handoff-export .../recall handoff-import .../knowledge status|ingest-url|import-bookmarks|import-urls|list|search|get|queue|candidates|reports|schedules|lint|packet|explain|reindex|consolidate
This is a reviewed knowledge substrate used by the runtime when preparing task context.
There are also dedicated front doors for memory workflows outside /recall:
/memory-syncfor durable export/import/handofffor reviewable handoff bundles/session-memoryfor session-scoped review/capture/team-memoryfor shared/team-oriented exchange
Web search, artifacts, voice, and multimodal
These systems are first-class runtime families.
web-search: provider-backed search with verbosity control, evidence shaping, optional source fetching, and normalized results across DuckDuckGo, SearXNG, Brave, Exa, Firecrawl, Tavily, and Perplexityartifacts: durable file/object storage for markdown, text, JSON, CSV, spreadsheets, PDFs, images, audio, video, and generated outputs, with metadata, content access, and delivery reusevoice: provider-backed TTS/STT/realtime negotiation with OpenAI, ElevenLabs, Deepgram, Google, Microsoft, and Vydra; the TUI also supports live/ttsspoken output through streaming TTS providers and localmpv/ffplayplaybackcloudflare: optional Workers/Queues batch execution and remote control-plane provisioning through SDK daemon routes; local immediate daemon behavior remains the default until Cloudflare and a batch mode are enabledmultimodal: unified image/audio/video/document analysis with packet building and optional knowledge write-back
These surfaces are exposed through the daemon/API as well as the TUI panels and commands, giving future web and companion clients the same backend runtime.
read
Read files with token-efficient extraction modes.
- 5 extract modes:
content(full text),outline(signatures only, significant token savings),symbols(exported names, even greater savings),ast(structural),lines(specific ranges) - Tree-sitter powered outline and symbol extraction with regex fallback
- Token-budget pagination for large batch reads — request N files, get pages that fit within a budget
- Built-in image, PDF, and Jupyter notebook reading
- Per-file caching with optimistic concurrency control (OCC) conflict detection — tracks what you've read and warns if it changed externally
write
Write files with atomic operations, backup modes, and auto-heal.
- Atomic writes via temp file + rename — no partial writes on crash
- Three overwrite modes:
fail_if_exists,overwrite,backup(copies original to.goodvibes/.backups/) - Auto-heal pipeline: if a written file has syntax errors and
tools.autoHealis enabled, runs formatter → linter → LLM fix automatically - Base64 content support for files with special characters
- Batch writes in a single call with per-file mode control
edit
Structural code editing with AST matching, scope hints, and transactional rollback.
- 5 match modes:
exact,fuzzy(whitespace-insensitive),regex(with capture groups),ast(tree-sitter structural),ast_pattern(ast-grep with metavariables like$VARand$$$ARGS) - Scope hints:
in_function,in_class,near_line— disambiguate matches without increasing context - Occurrence selection:
first,last,all, or specific Nth occurrence — with ambiguity guard by default - Atomic transactions: all edits succeed or all roll back. Also supports
partialandnonemodes - Pre/post validation: run
typecheck,lint,test, orbuildbefore and after edits — auto-rollback on failure - Auto-heal on validation failure (same pipeline as write)
find
Multi-mode search: files, content, symbols, references, and structural AST patterns.
- 5 search modes in one tool:
files(glob),content(regex grep),symbols(exported declarations),references(find all references via LSP with grep fallback),structural(AST pattern matching via ast-grep) - Structural search uses ast-grep to find code patterns like
console.log($$$ARGS)across TypeScript, JavaScript, CSS, and HTML - Scope expansion: expand content matches to their enclosing
functionorclassusing tree-sitter - Multiple queries per call executed in parallel
- Progressive output:
count_only→files_only→locations→matches→context
exec
Shell execution with background processes, retry, progress tracking, and file operations.
- Background execution with process tracking — spawn, poll status, read output, kill
- Retry with exponential backoff on transient failures
untilpattern: watch stdout for a regex match, then stop or promote to background- Pre-command file operations: copy, move, delete files before running commands
- Progress file streaming for long-running commands (auto-enabled above 30s)
- Fail-fast mode: stop sequential execution on first failure, report remaining as skipped
fetch
HTTP client with extraction modes, service registry auth, and batch operations.
- 11 extraction modes:
raw,text,json,markdown,readable(strips nav/sidebar/footer),code_blocks,links,tables,metadata(og-tags),structured(CSS selectors),pdf - Named service registry: configure API credentials once in
.goodvibes/tui/services.json, reference by name in fetch calls - Inline auth:
bearer,basic,api-keyper-request - Batch parallel fetches in a single tool call
web_search
Higher-level provider-backed search built on top of the lower-level fetch/runtime stack.
- Normalized ranked search results
- Verbosity modes from compact URL lists through richer snippet/evidence bundles
- Optional instant-answer enrichment and optional fetched evidence for top-ranked sources
- Provider routing across DuckDuckGo, SearXNG, Brave, Exa, Firecrawl, Tavily, and Perplexity
- Safer split between
fetchas the HTTP/extraction primitive andweb_searchas the search/evidence surface
analyze
15-mode code analysis suite — from impact analysis to upgrade compatibility.
impact: trace exported symbols across the project to find what breaks when you change a filedependencies: build import graph, detect circular dependencies, list external packagesdead_code: find exported symbols with zero references outside their own filesecurity: scan for hardcoded secrets, world-writable files, and missing .env keysbreaking: compare git refs and detect removed/changed export signaturessemantic_diff: LLM-powered diff summary with risk assessment (low/medium/high)upgrade: check npm registry for outdated packages and flag breaking version bumps- Also:
coverage(lcov/istanbul parse),bundle(stats.json),surface(public API),preview(dry-run edit),diff(git ref diff),permissions(dangerous pattern scan),env_audit(.env key comparison),test_find(locate test files for source files)
inspect
21-mode project and frontend inspection tool.
project: detect project type, package manager, test framework, entry points, monorepo statusapi+api_spec+api_validate+api_sync: discover API routes across Next.js (App + Pages Router), Express, Fastify, and Hono → generate OpenAPI 3.0 specs → validate specs against code → detect frontend/backend drift by scanning fetch() callsdatabase: parse Prisma schemas into structured model/field/relation datacomponents: extract React component tree with props, hooks, and child componentsscaffold: generate module skeleton (types, implementation, tests, barrel export) with dry-run- Frontend analysis:
layout(CSS/Tailwind layout hierarchy),accessibility(a11y issue detection),component_state(useState/useReducer/useContext tracing),render_triggers(what causes re-renders),hooks(dependency array auditing with missing-dep detection),overflow/sizing/stacking(CSS issue detection),responsive(Tailwind breakpoint analysis),events(handler analysis),tailwind(class conflict detection),client_boundary(Next.js directive analysis),error_boundary(coverage analysis)
agent
In-process subagent system with 15 management modes.
- Spawn agents from named archetypes (
engineer,reviewer,tester,researcher,general) or custom archetypes from.goodvibes/agents/*.md - Full lifecycle management:
spawn,status,cancel,list,get(detailed view with recent messages),wait(block until completion with timeout) - Inter-agent messaging via
messagemode - Token budget estimation via
budgetmode - Execution plan introspection via
planmode - Git worktree isolation: each agent can work in its own branch, merged back on completion
- Batch spawning via
batch-spawnmode - WRFC chain introspection via
wrfc-chainsandwrfc-historymodes - Cohort tracking via
cohort-statusandcohort-reportmodes
state
Session state, persistent memory, telemetry, hooks, and output modes — all in one tool.
- KV state: session-scoped key-value store with atomic persistence
- Durable memory posture: inspect the reviewed knowledge substrate and related runtime state, while the full durable-memory workflow lives under
/recalland the knowledge panels - Hook management: list, enable, disable, add, and remove hooks at runtime
- Output mode switching: switch between
default,vibecoding, andjustvibesverbosity presets - Analytics: record tool calls, query by filter, export as JSON/CSV, dashboard view — backed by WASM SQLite
- Context and budget reporting for token usage awareness
workflow
Workflow state machines, automation triggers, and scheduled tasks.
- Named workflow definitions:
wrfc(work-review-fix cycle),fix_loop,test_then_fix,review_only - State machine with validated transitions — prevents invalid state changes
- Automation triggers: fire shell commands when specific hook events occur, with optional JS conditions
- Cron scheduler: full 5-field cron expressions with IANA timezone support, missed-run detection, per-task run history, and enable/disable control. Persists to
.goodvibes/tui/schedules.json - Full lifecycle: start, transition, cancel, list active instances
task / team / worklist
Structured execution and coordination tools beyond a single conversation turn.
task: create, inspect, block, cancel, depend, and hand off tasks across sessionsteam: define teams, members, lanes, and role assignmentsworklist: manage durable worklists with ownership and priority
packet / query
Durable planning and operator-communication artifacts.
packet: create, revise, publish, and list implementation packets / execution packetsquery: track operator queries, answers, escalation targets, and closure state
mcp / remote / control
Additional product-control tools that expose runtime breadth directly.
mcp: inspect MCP servers, tools, schema freshness, security posture, auth posture, and quarantine controlsremote: inspect and manage distributed peers, node-host contracts, work queues, artifacts, and review flowscontrol: inspect packaged command families, panel/control-room families, built-in subscription providers, and sandbox presets
channel
The channel tool exposes the omnichannel runtime directly to the model and operator flows.
- list accounts per surface and inspect individual account/setup state
- run account lifecycle actions such as setup, inspect, retest, connect, disconnect, login, and logout
- query shared channel directories and resolve targets across supported surfaces
- inspect channel capabilities, tools, agent-tools, and operator actions
- run channel-owned tools/actions and perform authorization checks through the same surface registry used by the daemon and reply pipeline
registry
Discover and introspect skills, agents, and tools.
- Fuzzy search across skills (
.goodvibes/skills/*.md), agents (.goodvibes/agents/*.md), and built-in tools - Task-based recommendations: describe what you want to do, get ranked suggestions
- Dependency chain resolution for skills
- Full content retrieval for any registry item
Evaluation, Replay, Diagnostics, And Incidents
GoodVibes includes a substantial post-execution and operator-repair stack:
/evalruns built-in evaluation suites, compares baselines, and applies regression gates/replayloads and steps deterministic replay runs/incidentopens, exports, and captures forensics bundlesHealthand diagnostics surfaces expose repair actions, transport issues, task failure state, and replay hooks- the state inspector subsystem tracks transitions, time-travel snapshots, and selector hotspots
- telemetry exporters can write to local ledgers, console sinks, or OTLP bridges
- retention and pruning policy keeps checkpoint/snapshot growth bounded
- idempotency keys prevent duplicate tool execution across replay, reconnect, and retry scenarios
- operational playbooks describe symptoms, checks, and resolution steps for runtime failure classes
The product also includes validation, replay, incident, telemetry, and repair infrastructure.
The adjacent reliability subsystems include:
- notifications
- performance budgets and panel-health monitoring
- retention and pruning
- idempotency protection
- machine-readable recovery playbooks
Those pieces cover conversation-noise routing, panel-health/performance budgets, snapshot pruning, duplicate-execution protection, and machine-readable recovery playbooks used by the diagnostics surface.
Slash Commands
| Command | Aliases | Description |
|---------|---------|-------------|
| /model [id] | /m | Open the fullscreen provider/model workspace, or set the current model by id |
| /provider [name] | /p | Open provider-first model selection, or add <name> <baseURL> [apiKey] / remove <name> |
| /effort [level] | /e | Show or set reasoning effort level |
| /config [category\|key] | /cfg | Open the fullscreen configuration workspace for all SDK config keys, TTS settings, model routes, secrets-backed settings, MCP trust, subscriptions, and feature flags |
| /debug | — | Toggle debug mode |
| /expand [type] | — | Expand blocks by type (all/thinking/tool/cod
