Server data from the Official MCP Registry
MCP server wrapping Gemini CLI: query, review, search, structured output, and diff assessment.
MCP server wrapping Gemini CLI: query, review, search, structured output, and diff assessment.
Valid MCP server (3 strong, 3 medium validity signals). 5 known CVEs in dependencies (1 critical, 3 high severity) Package registry verified. Imported from the Official MCP Registry.
5 files analyzed · 6 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: GEMINI_CLI_PATH
Environment variable: GEMINI_DEFAULT_MODEL
Environment variable: GEMINI_FALLBACK_MODEL
Environment variable: GEMINI_MAX_CONCURRENT
Environment variable: GEMINI_MIN_INVOCATION_GAP_MS
Environment variable: GEMINI_SPAWN_JITTER_MAX_MS
Environment variable: GEMINI_API_KEY
Environment variable: GOOGLE_API_KEY
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-hampsterx-gemini-mcp-bridge": {
"env": {
"GEMINI_API_KEY": "your-gemini-api-key-here",
"GOOGLE_API_KEY": "your-google-api-key-here",
"GEMINI_CLI_PATH": "your-gemini-cli-path-here",
"GEMINI_DEFAULT_MODEL": "your-gemini-default-model-here",
"GEMINI_FALLBACK_MODEL": "your-gemini-fallback-model-here",
"GEMINI_MAX_CONCURRENT": "your-gemini-max-concurrent-here",
"GEMINI_SPAWN_JITTER_MAX_MS": "your-gemini-spawn-jitter-max-ms-here",
"GEMINI_MIN_INVOCATION_GAP_MS": "your-gemini-min-invocation-gap-ms-here"
},
"args": [
"-y",
"gemini-mcp-bridge"
],
"command": "npx"
}
}
}From the project's GitHub README.
MCP server that wraps Gemini CLI as a subprocess, exposing its capabilities as Model Context Protocol tools.
Works with any MCP client: Claude Code, Codex CLI, Cursor, Windsurf, VS Code, or any tool that speaks MCP.
If you're in a terminal agent (Claude Code, Codex CLI) with shell access, call Gemini CLI directly:
# Agentic review (Gemini explores the repo, reads files, follows imports)
cd /path/to/repo && gemini -p --yolo "Review the changes on this branch vs main"
# Review specific files
gemini -p "Review this code for bugs and security issues" -- @src/file.ts @src/other.ts
# Pipe a diff
git diff origin/main...HEAD | gemini -p "Review this diff"
# Quick question
gemini -p "Is this approach sound for handling retries?"
Tips: --yolo is needed for agentic file access in headless mode (without it, tool calls block). Use -m gemini-2.5-pro to skip the CLI's internal model routing (~1-2s). Cold start is ~16s per invocation.
Use this MCP bridge instead when:
assess classifies a diff in <2s (no spawn) and recommends a review depth with an estimated wall timescan (diff-only, ~40s), focused (reads changed files, 1-3min), deep (full agentic, up to 30min) with per-depth auto-scaled timeoutsmaxResponseLength parameter)npx gemini-mcp-bridge
npm i -g @google/gemini-cli)gemini auth login)claude mcp add gemini -s user -- npx -y gemini-mcp-bridge
Add to ~/.codex/config.json:
{
"mcpServers": {
"gemini": {
"command": "npx",
"args": ["-y", "gemini-mcp-bridge"]
}
}
}
Add to your MCP settings:
{
"gemini": {
"command": "npx",
"args": ["-y", "gemini-mcp-bridge"]
}
}
| Tool | Description |
|---|---|
| query | Agentic prompt with optional file context. Gemini runs inside your repo with read/grep/glob tools. Supports text and images. |
| search | Google Search grounded query. Gemini searches the web and synthesizes an answer with source URLs. |
| assess | Zero-cost diff analysis pre-flight. Classifies complexity and change kind, adds guidance, and recommends a review depth. No CLI spawn. |
| review | Repo-aware code review at three depths: scan (diff-only), focused (reads changed files), deep (full agentic exploration). |
| structured | JSON Schema validated output via Ajv. Data extraction, classification, or any task needing machine-parseable output. |
| ping | Health check. Verifies CLI is installed and authenticated, reports versions and capabilities. |
| fetch-chunk | Retrieve later segments from a chunked query, review, or search response using its cacheKey. |
Send a prompt with optional file paths as hints. Gemini reads the files itself and can explore surrounding code for context. Text queries run under --approval-mode plan (read-only agentic). Image queries use --yolo for native pixel access.
Key parameters: prompt (required), files (text or images), model, workingDirectory, timeout (default 120s, max 1800s), changeMode (see below).
Change mode: set changeMode: true to ask Gemini to emit structured **FILE: <path>:<start>-<end>** / ===OLD=== / ===NEW=== edit blocks instead of prose. The raw response stays in response (chunked normally); parsed edits are returned on _meta.edits as a machine-applicable array and are never chunked. A pre/post-spawn git snapshot detects any file writes Gemini might attempt, if writes are found, _meta.appliedWrites is set to true and edits is omitted so callers can't re-apply half-applied state. Text-only for v1; requires a git workingDirectory. Plan mode refuses to emit edit blocks (verified on CLI 0.38.0), so change mode runs in default agentic mode with the snapshot guardrail as the safety net.
Runs git diff --numstat and --name-only locally and returns diff stats, changed file list, complexity (trivial/moderate/complex), change kind (empty / code / mixed / non-code / generated), guidance, and suggested review depths with estimated wall-clock time. No CLI spawn, no model call, returns in under 2 seconds.
Key parameters: uncommitted (default true), base, workingDirectory.
Three depth tiers, selectable via the depth parameter. Use the assess tool first for a recommendation.
120s + 15s * files (cap 300s; 240s fallback). Good for light-to-moderate reviews.--yolo. Gemini runs git diff itself, follows imports, checks tests, reads project instruction files (AGENTS.md, CLAUDE.md, GEMINI.md, etc.). Timeout 240s + 45s * files (cap 1800s; 600s fallback). On capacity failures such as 429/503, deep review returns structured failure metadata instead of retrying or silently downgrading. Deepest.The legacy quick boolean is deprecated but still honoured: quick: true → depth: "scan", quick: false → depth: "deep". depth wins when both are set.
Key parameters: uncommitted (default true), base, focus, depth, workingDirectory, timeout, maxResponseLength.
Google Search grounded query. Spawns Gemini CLI in agentic mode with google_web_search, then synthesizes an answer with source URLs.
Key parameters: query (required), model, workingDirectory, timeout.
Large query, review, and search responses are automatically chunked when they exceed the bridge threshold. The first chunk includes a cacheKey and chunk count in _meta and the response footer. Use fetch-chunk with that cacheKey and a 1-based chunkIndex to retrieve later segments within the 10-minute in-memory cache window.
Generate JSON conforming to a provided schema. Schema is embedded in the prompt, response validated with Ajv. Returns isError: true with validation details on failure.
Key parameters: prompt (required), schema (required, JSON string), files, model, workingDirectory, timeout.
No parameters. Returns CLI version, auth status, and server info.
All tools attach execution metadata (_meta) with durationMs, model, and partial (timeout indicator). Review may also attach capacityFailure; assess includes diffKind, guidance, and suggestions. See DESIGN.md for details.
| Variable | Default | Description |
|---|---|---|
GEMINI_DEFAULT_MODEL | (CLI default) | Default model for all tools |
GEMINI_FALLBACK_MODEL | gemini-2.5-flash | Fallback on quota/rate-limit errors (none to disable) |
GEMINI_CLI_PATH | gemini | Path to CLI binary |
GEMINI_MAX_CONCURRENT | 3 | Max concurrent subprocess spawns |
GEMINI_MIN_INVOCATION_GAP_MS | 5000 | Minimum gap between Gemini CLI start times |
GEMINI_SPAWN_JITTER_MAX_MS | 200 | Random extra delay before spawn to avoid deterministic timing |
Prompt templates for review, search, and structured tools live in prompts/. Editable when running from a local clone; bundled when running via npx.
| You need... | Consider |
|---|---|
| Agentic code review, structured output, concurrency management | This bridge |
| Shell command generation, Google Workspace integration | @tuannvm/gemini-mcp-server |
| Lightweight large-context codebase analysis | gemini-mcp-tool |
| No CLI dependency (API-only, broadest feature set) | @rlabs-inc/gemini-mcp |
| Simple API wrapper with broad client support | mcp-server-gemini |
Each invocation spawns a fresh CLI process with ~15-20s cold start (large dependency tree, sync auth checks). No daemon mode yet (tracking; PR in progress).
| Scenario | Typical time |
|---|---|
| Minimal query | 17-25s |
| Scan review (diff-only) | 35-50s |
| Focused review (reads changed files) | 60-180s |
| Deep review (explores repo) | 60s to 30 min |
| Web search + synthesis | 35-60s |
Setting GEMINI_DEFAULT_MODEL avoids the CLI's internal model routing step (~1-2s savings per call).
Three MCP servers, same architecture, different underlying CLIs. Each wraps a terminal agent as a subprocess and exposes it as MCP tools. Pick the one that matches your model provider, or run multiple for cross-model workflows.
| gemini-mcp-bridge | claude-mcp-bridge | codex-mcp-bridge | |
|---|---|---|---|
| CLI | Gemini CLI | Claude Code | Codex CLI |
| Provider | Anthropic | OpenAI | |
| Tools | query, review, search, structured, ping | query, review, search, structured, ping, listSessions | codex, review, search, query, structured, ping, listSessions |
| Agentic review | Gemini explores repo with file reads and git | Claude explores repo with Read/Grep/Glob/git | Codex explores repo in full-auto mode |
| Structured output | Ajv validation | Native --json-schema | Ajv validation |
| Session resume | Not supported | Native --resume | Session IDs with multi-turn |
| Budget caps | Not supported | Native --max-budget-usd | Not supported |
| Effort control | Not supported | --effort low/medium/high/max | reasoningEffort (low/medium/high) |
| Cold start | ~16s | ~1-2s | <100ms (inference dominates) |
| Auth | gemini auth login | claude login (subscription) or ANTHROPIC_API_KEY | OPENAI_API_KEY |
| Cost | Free tier available | Subscription (included) or API credits | Pay-per-token |
| Concurrency | 3 (configurable) | 3 (configurable) | 3 (configurable) |
| Model fallback | Auto-retry with fallback model | Auto-retry with fallback model | Auto-retry with fallback model |
All three share: subprocess env isolation, path sandboxing, FIFO concurrency queue, MCP tool annotations, _meta response metadata, progress heartbeats. The codex and claude bridges also perform output redaction (secret stripping).
npm install
npm run build # Compile TypeScript
npm run dev # Watch mode
npm test # Run tests
npm run lint # ESLint
npm run typecheck # tsc --noEmit
MIT
Be the first to review this server!
by Modelcontextprotocol · AI & ML
Dynamic and reflective problem-solving through structured thought sequences
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.