Rovodev CLI MCP
Exposes Rovodev CLI as MCP tools for interacting with Rovodev agent, including session management, streaming chunk-caching, and tool-based CLI operations.
README
Rovodev CLI MCP
An MCP server wrapper that exposes Rovodev CLI as MCP tools. Modeled after gemini-mcp-tool.
Install
npm install -g rovodev-cli-mcp
Or use with npx:
npx -y rovodev-cli-mcp
Configure in Claude Desktop
{
"mcpServers": {
"rovodev": {
"command": "npx",
"args": ["-y", "rovodev-cli-mcp"]
}
}
}
Environment variables to customize underlying CLI:
ROVODEV_CLI_PATHorROVODEV_CMD(default:acli)ROVODEV_SUBCOMMAND(default:"rovodev run")ROVODEV_CONFIG_FLAG(default:--config-file)ROVODEV_SHADOW_FLAG(default:--shadow)ROVODEV_VERBOSE_FLAG(default:--verbose)ROVODEV_RESTORE_FLAG(default:--restore)ROVODEV_YOLO_FLAG(default:--yolo)ROVODEV_HELP_FLAG(default:--help)
Chunking configuration (for large responses):
MCP_CHUNK_SIZE(preferred)ROVODEV_CHUNK_SIZE(legacy) The first one found is used; default is 20000 characters if none are set.
Global setup for Claude Code (user scope)
Install the MCP server for your user so it’s available across projects in Claude Code.
-
Add with npx (no global npm install required):
claude mcp add -s user rovodev -- npx -y rovodev-cli-mcp -
Optional: use a globally installed binary instead of npx
npm i -g rovodev-cli-mcp claude mcp add -s user rovodev rovodev-cli-mcp -
Optional: set environment overrides when adding
claude mcp add -s user rovodev -- \ npx -y rovodev-cli-mcp \ -e ROVODEV_CLI_PATH=acli \ -e ROVODEV_SUBCOMMAND="rovodev run" \ -e ROVODEV_CONFIG_FLAG=--config-file \ -e ROVODEV_SHADOW_FLAG=--shadow \ -e ROVODEV_VERBOSE_FLAG=--verbose \ -e ROVODEV_RESTORE_FLAG=--restore \ -e ROVODEV_YOLO_FLAG=--yolo \ -e ROVODEV_HELP_FLAG=--help -
Verify it’s connected:
claude mcp list -
Remove from user scope (to update or uninstall):
claude mcp remove -s user rovodev
Global setup for Amazon Q CLI
Install the MCP server for Amazon Q CLI to use Rovodev tools in Q chat sessions.
-
Add with npx (no global npm install required):
q mcp add --name rovodev --command npx --args "-y,rovodev-cli-mcp" -
Optional: set environment variables when adding
q mcp add --name rovodev --command npx --args "-y,rovodev-cli-mcp" \ --env "ROVODEV_CLI_PATH=acli" \ --env "ROVODEV_SUBCOMMAND=rovodev run" -
Verify it's installed:
q mcp list -
Check server status:
q mcp status --name rovodev -
Remove (to update or uninstall):
q mcp remove --name rovodev
Using tools in Q CLI: Tools are available with the rovodev___ prefix:
rovodev___ask-rovodev- Send messages to Rovodev agent (enhanced with session support)rovodev___tap-rovodev- Alias for ask-rovodevrovodev___session_manager- Manage isolated sessions for context persistencerovodev___health_check- Check server health and CLI availabilityrovodev___diagnostics- Get comprehensive system diagnosticsrovodev___next-chunk- Fetch next chunk for large responsesrovodev___fetch-chunk- Fetch specific chunk by indexrovodev___Help- Show Rovodev CLI helprovodev___Ping- Test connectivity
Local development with Claude Code
If you are iterating on this repo and want Claude Code to use your local build:
- Install deps and build
npm i
npm run build
- Point Claude Code at your local
dist/index.js
claude mcp remove -s user rovodev || true
claude mcp add -s user rovodev -- node "$(pwd)/dist/index.js"
- Verify connection
claude mcp list
- Optional: quick smoke test (no Claude required)
node scripts/smoke.mjs
Notes:
- This server communicates over stdio. Do not print to stdout; only stderr is safe for logs.
- The server already routes logs to stderr; if you add logs, follow the same pattern.
- You can still register via
npx -y rovodev-cli-mcp, but during development usingnode dist/index.jsavoids npm network hiccups.
Troubleshooting
-
"Failed to connect" in
claude mcp list- Ensure your Node is >= 18 (
node -v). - Ensure no output is written to stdout (stdout is reserved for the MCP protocol). This repo's logger writes to stderr only.
- Try registering the local path:
claude mcp add -s user rovodev -- node "$(pwd)/dist/index.js". - If using WSL, register from the Linux side; Claude Code on Windows can discover WSL user-scoped config.
- Ensure your Node is >= 18 (
-
Authentication errors (API key issues)
- If you see "Authentication Error" messages, your rovodev CLI API key may be expired or invalid
- Check your rovodev CLI configuration and update your API key
- The server now detects authentication issues and provides clear error messages instead of hanging
-
Underlying CLI not found
- The default command is
acli. Install it or override:
claude mcp add -s user rovodev -- \ node "$(pwd)/dist/index.js" \ -e ROVODEV_CLI_PATH=/path/to/your/cli - The default command is
-
Large responses
- Use
ask-rovodevfirst. If the response is chunked, callnext-chunkrepeatedly with the providedcacheKey. You can also fetch a specific page withfetch-chunk. - Tune chunk size with env vars (in order of precedence):
MCP_CHUNK_SIZE, then legacyROVODEV_CHUNK_SIZE.
- Use
Tools and streaming
This server supports streaming chunk-caching to reduce memory usage for large outputs. The ask-rovodev tool streams the CLI output directly into a chunk cache. If the output exceeds the page chunk size, it returns the first chunk and a cacheKey so you can fetch subsequent chunks with next-chunk or fetch-chunk.
Tools
Enhanced Core Tools
ask-rovodev:{ message?: string, prompt?: string, configFile?: string, shadow?: boolean, verbose?: boolean, restore?: boolean, yolo?: boolean, sessionId?: string, retries?: number, backoffMs?: number, args?: string[], pagechunksize?: number }- New: Session isolation with
sessionId, retry logic withretries/backoffMs - Default:
yolomode is enabled for non-interactive MCP usage; setyolo: falseto disable if you need interactive behavior. - Tip: If your message starts with dashes (e.g.,
--example), the underlying CLI may interpret it as a flag. The server inserts--before such messages to prevent flag parsing.
- New: Session isolation with
tap-rovodev: alias ofask-rovodev
Session Management
session_manager:{ action: "create" | "destroy" | "list" | "get" | "cleanup", sessionId?: string, timeoutMs?: number }- Manage isolated sessions for maintaining context across multiple commands
Health & Diagnostics
health_check:{ detailed?: boolean }- Check server health including CLI availability, session manager status, and environment configuration
diagnostics:{ includePerformance?: boolean, includeHealth?: boolean, includeSessions?: boolean, includeSystem?: boolean, includeRecentExecutions?: boolean, recentLimit?: number }- Get comprehensive system diagnostics including performance metrics and resource usage
Utility Tools
next-chunk:{ cacheKey: string }Fetch the next chunk sequentially from a cached large responsefetch-chunk:{ cacheKey: string, chunkIndex: number }(optional) Fetch a specific chunk by indexHelp: show help from underlying CLIPing: connectivity test
Server behavior and tuning via env vars:
- Logging level:
MCP_LOG_LEVEL(debug | info | warn | error | silent) - Exec timeout:
MCP_EXEC_TIMEOUT_MS(kill underlying CLI after N ms; includes partial stdout tail in error) - Max stdout buffer:
MCP_MAX_STDOUT_SIZE(maximum output buffer size before termination) - Working directory:
MCP_CWD(set process cwd for the underlying CLI) - Chunk cache TTL:
MCP_CHUNK_TTL_MS(default 20 minutes) - Chunk cache max entries:
MCP_CHUNK_MAX_ENTRIES(default 500)
Handling large responses (simple sequential flow)
- If the output is too large, the first
ask-rovodevcall returns page 1 plus acacheKey:- Response header example:
cacheKey: <key>,chunk: 1/N
- Response header example:
- To continue, call
next-chunkwith the samecacheKeyto get chunk 2, then 3, etc. until it reports no further chunks.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.