gemini-cli
Integrates the local gemini CLI tool with Claude Code, allowing Claude to execute Gemini AI queries via the MCP protocol.
README
Gemini CLI MCP Server
A Model Context Protocol (MCP) server that integrates the local gemini CLI tool with Claude Code. This server acts as a bridge, allowing Claude Code to execute Gemini AI queries through the standardized MCP protocol.
Made 99% with Claude Code (including this line).
How It Works
This MCP server provides a simple interface between Claude Code and the Gemini CLI tool:
- Claude Code sends a prompt via MCP protocol
- The server receives the prompt through stdio JSON-RPC communication
- Server executes
gemini -p "<prompt>"as a child process - Gemini CLI response is captured and returned to Claude Code
- Claude Code displays the result to the user
Claude Code ↔ [JSON-RPC stdio] ↔ MCP Server ↔ [child_process] ↔ gemini CLI
Prerequisites
- Node.js v18+ installed
- Gemini CLI tool installed and available in your PATH
- Test with:
gemini -p "Hello world"
- Test with:
- Claude Code installed and configured
Installation
-
Clone or download this repository:
git clone <repository-url> cd gemini-mcp-server -
Install dependencies:
npm install -
Build the project:
npm run build
Claude Code Configuration
Method 1: Using Claude Code CLI (Recommended)
claude mcp add gemini-cli node /absolute/path/to/gemini-mcp-server/dist/index.js
Method 2: Manual Configuration
Edit your Claude Code configuration file (~/.claude.json):
{
"mcpServers": {
"gemini-cli": {
"type": "stdio",
"command": "node",
"args": ["/absolute/path/to/gemini-mcp-server/dist/index.js"]
}
}
}
Important: Use the absolute path to your built index.js file.
Method 3: Development Mode
For development, you can run directly with ts-node:
{
"mcpServers": {
"gemini-cli": {
"type": "stdio",
"command": "npx",
"args": ["ts-node", "/absolute/path/to/gemini-mcp-server/src/index.ts"]
}
}
}
Setup Verification
-
Restart Claude Code after configuration changes
-
Check MCP server status:
claude mcp list -
Verify in Claude Code:
- Run
/mcpcommand - Should show
gemini-cli: connected
- Run
-
Test the integration:
Hey Claude, use the gemini-cli tool to ask: "What is TypeScript?"
Available Tools
gemini_query
Executes a query using the local Gemini CLI tool.
Parameters:
prompt(string, required): The text prompt to send to Geminimodel(string, optional): Gemini model to use (defaults togemini-2.5-flash)
Example usage in Claude Code:
Please use the gemini_query tool with prompt: "Explain the difference between async and await"
# With model selection (otherwise defaults to gemini-2.5-flash)
Please use the gemini_query tool with prompt: "What is TypeScript?" and model: "gemini-1.5-flash"
Development
Project Structure
gemini-mcp-server/
├── src/
│ ├── index.ts # Main MCP server
│ ├── gemini-cli.ts # CLI wrapper
│ └── types.ts # TypeScript interfaces
├── dist/ # Compiled output
├── package.json
├── tsconfig.json
├── PLAN.md # Implementation details
└── README.md # This file
Development Commands
# Install dependencies
npm install
# Build for production
npm run build
# Development with auto-reload
npm run dev
# Run tests
npm test
# Run tests with coverage
npm run test:coverage
# Run tests in watch mode
npm run test:watch
Development Mode
For active development, you can run the server directly:
npm run dev
Then configure Claude Code to use ts-node as shown in Method 3 above.
Troubleshooting
Common Issues
-
"Connection closed" error
- Ensure you're using absolute paths in configuration
- Check that Node.js can execute the built file
- Verify the gemini CLI is in your PATH
-
"Command not found: gemini"
- Install the Gemini CLI tool
- Ensure it's in your system PATH
- Test manually:
gemini -p "test"
-
Server not appearing in /mcp
- Restart Claude Code after configuration changes
- Check the configuration file syntax
- Verify absolute paths are correct
-
Tool not available
- Run
claude mcp listto check server status - Look for connection errors in Claude Code logs
- Run
Debugging
-
Test the server manually:
node dist/index.js # Send JSON-RPC messages via stdin for testing -
Test with simulated responses (when Gemini CLI quota is exhausted):
GEMINI_TEST_MODE=true node dist/index.js # Uses simulated responses instead of calling Gemini CLI -
Check Gemini CLI directly:
# Test with default model (gemini-2.5-flash) gemini -m gemini-2.5-flash -p "Hello world" -
Verify Claude Code configuration:
claude mcp list
Testing the MCP Server
Test 1: Basic Server Test
cd /Users/zain/code/mcp/gemini-mcp-claude
node dist/index.js
Then send these JSON-RPC messages one by one:
# 1. Initialize the server
{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"test","version":"1.0.0"}}}
# 2. List available tools
{"jsonrpc":"2.0","id":2,"method":"tools/list","params":{}}
# 3. Test basic query (uses gemini-2.5-flash by default)
{"jsonrpc":"2.0","id":3,"method":"tools/call","params":{"name":"gemini_query","arguments":{"prompt":"What is 2+2?"}}}
# 4. Test with model override
{"jsonrpc":"2.0","id":4,"method":"tools/call","params":{"name":"gemini_query","arguments":{"prompt":"Hello world","model":"gemini-1.5-flash"}}}
Press Ctrl+C to exit when done.
Test 2: Test Mode (If Quota Exhausted)
cd /Users/zain/code/mcp/gemini-mcp-claude
GEMINI_TEST_MODE=true node dist/index.js
Send the same JSON-RPC messages as above. You'll get simulated responses instead of hitting the Gemini API.
Test 3: Verify Gemini CLI Directly
# Test default model
gemini -m gemini-2.5-flash -p "What is 2+2?"
# Test alternative model
gemini -m gemini-1.5-flash -p "Hello world"
Test 4: Configure in Claude Code
# Add to Claude Code
claude mcp add gemini-cli node $(pwd)/dist/index.js
# Verify configuration
claude mcp list
# Test in Claude Code
# Run /mcp command to see connection status
Expected Results
- Initialize: Returns server info with protocol version
- List tools: Shows
gemini_querytool with model parameter support - Tool calls: Return Gemini responses or proper error messages
- Test mode: Returns simulated responses immediately
- Claude Code: Shows
gemini-cli: connectedstatus
If you hit quota limits, the server will timeout after 5 minutes (or 10 seconds in test mode) and return a proper error message.
Testing
The project includes comprehensive test suites:
Running Tests
# Run all tests
npm test
# Run tests with coverage report
npm run test:coverage
# Run tests in watch mode (for development)
npm run test:watch
Test Coverage
- Unit Tests:
tests/gemini-cli.test.ts- Tests for CLI wrapper functions - Integration Tests:
tests/mcp-server.test.ts- Full MCP server testing - JSON Error Handling: Tests for robust JSON parsing
- Model Selection: Tests for default and custom model usage
- Validation: Tests for input validation and error cases
The test suite provides:
- 92%+ coverage of the CLI module
- Full MCP protocol compliance testing
- Error scenario testing (invalid JSON, timeouts, etc.)
- Both test and production mode validation
Security Notes
- The server validates input to prevent command injection
- Prompts are properly escaped when passed to the shell
- Command execution is limited by timeout (5 minutes for production, 10 seconds for test mode)
- Only stderr is used for logging (stdout reserved for MCP protocol)
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Test with Claude Code
- Submit a pull request
License
MIT License - see LICENSE file for details.
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.