Gmail
Tools for common Gmail operations, such as sending emails.
Gmail MCP Server
This MCP (Model Context Protocol) server provides tools for common operations with gmail.
Features
send_mail: Send new emails
Prerequisites
- Python 3.12+
- uv - Fast Python package installer and resolver
- Google Cloud Console Setup
- Go to: Google Cloud Console
- Create a new project for this MCP Server
- Enable Gmail API
- Go to: APIs and services > Library
- Search: Gmail API
- Click on: Gmail API tile in the results
- Click on: Enable
- Setup OAuth
- Go to: APIs and services > Credentials
- Click on": Create Credentials > OAuth client ID
- Choose Application Type: Web application
- Add: Authorised redirect URIs: http://localhost:4321/
- Create client
- Download the JSON and save it to
credentials.jsonin this project root. This has the Client ID, Client Secret, etc.
Installation
-
Clone this repository:
git clone https://github.com/heuristech/gmail-mcp-server.git cd gmail-mcp-server -
Create a virtual environment and install the package in development mode:
# Create a virtual environment uv venv # Activate the virtual environment # On macOS/Linux: source .venv/bin/activate # On Windows: .venv\Scripts\activate # Install dependencies uv sync
Get Refresh Token
python get_refresh_token.py
This will:
- Start a server on
port:4321to receivetokenspost Google OAuth - Open your browser for Google OAuth
- On succeeful authentication it will save
token.jsonwithrefresh_tokenalong withclient_id, andclient_secret. - It will also display the
refresh_tokenon console.
Create .env
copy example.env .env
Setup the corresponding value using what you received in the previous step.
Inspect
Use MCP Inspector to test it in the development mode.
mcp dev server.py
Claude Desktop Integration
Once your server is ready, install it in Claude Desktop
mcp install server.py --with google-auth --with google-auth-oauthlib --with google-auth-httplib2 --with google-api-python-client -f .env
MCP server configuration:
{
"mcpServers": {
"gmail-mcp-server": {
"command": "uv",
"args": [
"--directory",
"/:your.path.to/gmail-mcp-server/server.py",
"run",
"server.py"
],
"env": {
"CLIENT_ID": "google.auth.app.client.id",
"CLIENT_SECRET": "google.auth.app.client.secret",
"REFRESH_TOKEN": "google.auth.app.refresh.token"
}
}
}
}
Related Servers
MCP Intercom Server
Provides access to Intercom conversations and chats. Requires an Intercom API key.
Phone-a-Friend MCP Server
An AI-to-AI consultation system for complex problem-solving and reasoning, using OpenRouter for model access.
Pikud Haoref Real-Time Alert System
Provides real-time access to Israeli emergency alerts from the official Pikud Haoref API.
AI Interaction Tool
An AI interaction tool with an advanced UI for the Model Context Protocol (MCP).
Slack Webhook
Post messages to Slack channels using incoming webhooks.
Bluesky MCP Server
An MCP server for Bluesky that provides tools to interact with the ATProtocol.
A2A Client MCP Server
An MCP server client for the Agent-to-Agent (A2A) protocol, enabling LLMs to interact with A2A agents.
MCP Email Service
A service for managing multiple email accounts from various providers like 163, Gmail, QQ, and Outlook.
Slack
An MCP server for interacting with the Slack API, allowing for sending messages, managing channels, and other workspace actions.
Perplexity Chat
A Python-based server for the Perplexity API that manages chat history and conversations.