gmail-mcp
Enables AI assistants to send, read, list, and reply to emails via the Gmail API.
README
gmail-mcp
A Model Context Protocol (MCP) server that exposes Gmail actions as tools, allowing AI assistants like Claude to send, read, list, and reply to emails on your behalf.
Tools
| Tool | Description |
|---|---|
send_email |
Send an email to a recipient |
list_emails |
List emails matching a Gmail search query |
read_email |
Read a specific email by message ID |
read_emails_from_sender |
Fetch recent emails from a specific sender |
reply_email |
Reply to an email, preserving thread headers |
forward_recent_replies_to_webhook |
Forward recent Gmail replies to a signed LeadBorg email webhook |
Requirements
- Python 3.13+
- A Google Cloud project with the Gmail API enabled
- OAuth 2.0 credentials (
google_creds.json)
Setup
1. Get Google OAuth credentials
- Go to the Google Cloud Console.
- Create a project (or select an existing one).
- Enable the Gmail API.
- Under APIs & Services > Credentials, create an OAuth 2.0 Client ID (Application type: Desktop app).
- Download the JSON file and save it as
google_creds.jsonin the project root.
2. Install dependencies
# Using uv (recommended)
uv sync
# Or pip
pip install -e .
3. Authenticate
Run the server once manually to trigger the OAuth browser flow:
python gmail_mcp.py
This creates a token.json file at ~/.config/gmail-mcp/token.json. Subsequent runs reuse and auto-refresh this token.
Running the server
The transport is controlled by the MCP_TRANSPORT environment variable (default: stdio).
stdio (default — for Claude Desktop / MCP clients)
python gmail_mcp.py
Streamable HTTP
MCP_TRANSPORT=streamable-http MCP_PORT=8001 python gmail_mcp.py
# or alias:
MCP_TRANSPORT=http python gmail_mcp.py
SSE
MCP_TRANSPORT=sse python gmail_mcp.py
Environment variables
| Variable | Default | Description |
|---|---|---|
MCP_TRANSPORT |
stdio |
Transport mode: stdio, sse, streamable-http (alias: http) |
MCP_HOST |
127.0.0.1 |
Host for HTTP/SSE transports |
MCP_PORT |
8001 |
Port for HTTP/SSE transports |
GOOGLE_CREDS_PATH |
~/.config/gmail-mcp/google_creds.json |
Path to OAuth client credentials file |
GOOGLE_TOKEN_PATH |
~/.config/gmail-mcp/token.json |
Path to cached OAuth token file |
Claude Desktop configuration
Add the following to your claude_desktop_config.json:
{
"mcpServers": {
"gmail": {
"command": "python",
"args": ["/absolute/path/to/gmail_mcp.py"]
}
}
}
Running tests
python -m pytest tests/
# or
python -m unittest discover tests/
Project structure
gmail-mcp/
├── gmail_mcp.py # MCP server and tool definitions
├── main.py # Alternate entry point (HTTP transport)
├── pyproject.toml
└── tests/
└── test_gmail_mcp.py
~/.config/gmail-mcp/
├── google_creds.json # OAuth client credentials (not committed)
└── token.json # Cached OAuth token (generated at runtime)
Permissions
The server requests two OAuth scopes:
https://www.googleapis.com/auth/gmail.readonly— read access to emailshttps://www.googleapis.com/auth/gmail.send— permission to send email
This does not grant access to delete messages permanently.
LeadBorg integration notes
When using this server from LeadBorg, configure the email MCP endpoint as:
http://localhost:8001/mcp/
Set the provider to gmail-mcp. LeadBorg will pass a signed reply_to alias to
send_email; Gmail-MCP writes it as the Reply-To header so inbound replies can
be correlated back to the lead.
For local reply ingestion, run the forward_recent_replies_to_webhook tool with
the LeadBorg webhook URL (/api/webhooks/email/mcp) and the same signing secret
configured as EMAIL_WEBHOOK_SIGNING_SECRET.
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.