brv command from a script, pipeline, or SSH session and it works out of the box.
Daemon-first headless execution requires ByteRover CLI v2.0.0 or later.
Quick Start
Connect a provider
To use the built-in ByteRover provider, authenticate first with
brv login --api-key $BYTEROVER_API_KEY. Since v3.8.3, brv login defaults to a browser OAuth flow; in CI, SSH, or other non-interactive shells, always pass --api-key (SSH and non-interactive shells are auto-detected and will skip the browser, but passing --api-key explicitly is clearer). To use a third-party provider instead (no ByteRover login needed):The --format json Flag
The --format json flag is the key to automation. It produces structured JSON output on every command, making it easy to parse results in scripts and pipelines.
| Flag | Description | Default |
|---|---|---|
--format <text|json> | Output format: text for human-readable, json for structured | text |
--format json.
Supported Commands
| Command | Key Flags | Auth Required | Description |
|---|---|---|---|
brv status | — | No | Show CLI and project status |
brv query "<question>" | — | No | Query the context tree |
brv curate "<context>" | --files, --folder, --detach | No | Curate context to the tree |
brv curate view [id] | --status, --since, --before, --limit, --detail | No | View curate history and audit trail |
brv providers connect <provider> | --api-key, --model, --base-url | No | Connect an LLM provider |
brv providers list | — | No | List available providers and connection status |
brv providers switch <provider> | — | No | Switch the active provider |
brv providers disconnect <provider> | — | No | Disconnect an LLM provider |
brv model | — | No | Show active model and provider |
brv model list | --provider | No | List available models |
brv model switch <model> | --provider | No | Switch the active model |
brv connectors | — | No | List installed agent connectors |
brv connectors install <agent> | --type | No | Install a coding agent connector |
brv hub list | — | No | List available skills and bundles |
brv hub install <id> | --agent, --scope, --registry | No | Install a skill or bundle from the hub |
brv login --api-key <key> | — | — | Authenticate for cloud sync |
brv vc push | --set-upstream | Yes | Push commits to cloud |
brv vc pull | --allow-unrelated-histories | Yes | Pull commits from cloud |
brv vc remote set-url origin <url> | — | Yes | Switch to a different remote space |
brv vc remote remove origin | — | No | Disconnect the local space from ByteRover cloud |
brv space list | — | Yes | List available teams and spaces |
Commands marked “No” under Auth Required work entirely locally — no account, no internet (when using a local or third-party LLM provider). Exception:
brv providers connect byterover and brv providers switch byterover require a logged-in ByteRover account. See Local vs Cloud for a full breakdown.JSON Output Format
When using--format json, every command outputs one or more JSON lines to stdout. Each line follows the same envelope structure.
Response Envelope
Single-Response Commands
Commands likestatus, vc push, vc pull, and vc status emit a single JSON line:
Streaming Commands
Commands likequery and curate emit multiple JSON lines as the task progresses. Each line includes a data.event field:
| Event | Description |
|---|---|
thinking | LLM reasoning started |
toolCall | Tool invoked (includes toolName, args) |
toolResult | Tool completed (includes success) |
response | LLM final answer content |
completed | Task finished (includes result, status) |
error | Task failed (includes message, status) |
Error Responses
Errors setsuccess: false and include error details in data:
Coding Agent Integration (brv mcp)
The brv mcp command starts an MCP (Model Context Protocol) server that coding agents use to access your project’s context tree.
It is a hidden command — coding agents spawn it automatically; you don’t run it directly.
How It Works
Available MCP Tools
| Tool | Parameters | Description |
|---|---|---|
brv-query | query (required) | Query the context tree for project knowledge |
brv-curate | context, files, folder | Store context to the context tree |
Setup
The easiest way to configure MCP integration is through the TUI’s/connectors command, which sets up the MCP configuration for your coding agent automatically.
For manual setup and supported agents, see Coding Agent Connectors. For details on how the MCP server connects to the daemon and reuses the agent pool, see Daemon-First Architecture.
Curate History (brv curate view)
The brv curate view command lets you inspect curate operation history — useful for CI/CD audit trails, debugging failed curations, and verifying what was curated.
| Flag | Description | Default |
|---|---|---|
--status <status> | Filter by status: cancelled, completed, error, processing (repeatable) | All |
--since <time> | Show entries after this time (ISO date or relative: 1h, 24h, 7d) | — |
--before <time> | Show entries before this time (ISO date or relative) | — |
--limit <n> | Maximum number of entries to return | 10 |
--detail | Include operations for each entry | false |
CI/CD Integration
All CLI commands work in CI/CD environments out of the box. The daemon auto-starts, handles execution, and shuts down after 30 minutes of inactivity — no cleanup step needed.Common Patterns
Local-only (no auth needed):- Install ByteRover CLI
- Connect a provider (or use the built-in — requires
brv loginfirst) - Run commands (query, curate, status)
- Install ByteRover CLI
- Authenticate with an API key
- Set up space for the project
- Run commands (query, curate, push, pull)
Workflow Examples
- Local-Only
- GitHub Actions (Cloud Sync)
- GitLab CI (Cloud Sync)
No ByteRover authentication needed when using your own API key. To use the built-in ByteRover provider in CI/CD, add a
brv login step first.The cloud sync examples above use
brv login, brv vc clone, brv vc push, and brv vc pull — these require authentication. If you only need local operations (curate, query, status), skip the authentication and clone steps.Authentication for Cloud Sync
Authentication is only required for cloud features:vc push, vc pull, vc clone, vc remote, and space list. Local operations — status, query, curate, providers, connectors, model — work without any authentication.
CI/CD and automation environments use API key authentication instead of browser-based OAuth.
Generate an API Key
- Go to ByteRover Dashboard
- Click Create API Key
- Copy the key (starts with
brv_) - Store securely in your CI/CD secrets
Secure Storage
- GitHub Actions: Repository secrets (
Settings > Secrets > Actions) - GitLab CI: CI/CD variables (
Settings > CI/CD > Variables, masked) - Jenkins: Credentials plugin with secret text
Environment & Token Storage
ByteRover stores authentication tokens as AES-256-GCM encrypted files in a platform-specific data directory:| Platform | Storage Location |
|---|---|
| macOS | ~/Library/Application Support/brv/ |
| Linux / CI runners | ~/.local/share/brv/ |
| Windows | %LOCALAPPDATA%/brv/ |
Proxy Configuration
CI/CD runners and enterprise build environments often route traffic through a corporate proxy. ByteRover CLI (v2.4.0+) respects standard proxy environment variables — set them in your pipeline and ByteRover’s internal service traffic (cloud sync, hub, authentication) will route through the proxy automatically. Traffic to external LLM providers is not proxied. GitHub Actions:Troubleshooting
Do I need to authenticate?
Do I need to authenticate?
Short answer: Only for cloud sync features and the ByteRover built-in provider.Local operations (
status, query, curate, connectors) work without authentication. Provider and model commands also work without authentication when using third-party providers.Requires authentication:- ByteRover built-in provider —
brv providers connect byteroverandbrv providers switch byteroverrequirebrv login --api-key. - Cloud operations —
vc push,vc pull,vc clone,vc remote,space listrequirebrv login --api-key.
Daemon fails to start in CI/CD
Daemon fails to start in CI/CD
Cause: Container restrictions, port access issues, or stale lock files.Solution: Force a clean restart:Check daemon logs for details:
Space not configured
Space not configured
Cause: Running cloud commands without setting up a space first.Solution: Clone a space before running cloud commands:Use
brv space list --format json to see available teams and spaces.Provider not configured
Provider not configured
Cause:
brv query or brv curate fails with “No provider connected”.Solution: Connect a provider:JSON output not appearing
JSON output not appearing
Cause: Errors are written to stderr, not stdout.Solution: Redirect both streams when capturing output:Or capture them separately:
Authentication fails in CI/CD
Authentication fails in CI/CD
Cause: Keychain unavailable, token expired, or incorrect API key.Solution:
- Verify the API key is correct and not expired
- Ensure the
BYTEROVER_API_KEYsecret is properly configured in your CI/CD platform - Re-run
brv login --api-key $BYTEROVER_API_KEY - Check that the secret is not masked in a way that corrupts special characters
Permission denied for token storage
Permission denied for token storage
Cause: Cannot write to
~/.local/share/brv/ directory.Solution: Ensure the directory exists and is writable:Next Steps
Daemon-First Architecture
How the background daemon powers instant startup, agent pool reuse, and shared state
Coding Agent Connectors
Connect coding agents like Cursor, Claude Code, and Windsurf via MCP
CLI Reference
Complete command reference for all ByteRover CLI commands
Troubleshooting
Common issues and solutions for ByteRover CLI