Gmail & Calendar Multi-Account MCP Server

Gmail & Calendar Multi-Account MCP Server

A local MCP server that connects multiple Gmail and Google Calendar accounts to Claude Desktop, enabling email and calendar management across accounts.

Category
Visit Server

README

Gmail & Calendar Multi-Account MCP Server

A local Model Context Protocol (MCP) server that connects multiple Gmail accounts and Google Calendars to Claude Desktop. Runs entirely on your machine — no cloud hosting required.

Features

  • Multiple accounts — connect as many Gmail or Google Workspace accounts as you need
  • Unified email search — search across all accounts simultaneously with Gmail's full query syntax
  • Full read access — read individual messages and entire threads
  • Send & draft — compose and send emails, or save drafts, from any account
  • Label management — list labels, mark as read/unread, star messages
  • Google Calendar — list calendars, browse upcoming events, search by keyword

Requirements

  • macOS (tested on macOS 14+)
  • Python 3.11+
  • A Google Cloud project with the Gmail API and Calendar API enabled (free)
  • Claude Desktop

Installation

1. Clone the repository

git clone https://github.com/DiegoMaldonadoRosas/gmail-mcp.git
cd gmail-mcp

2. Run the setup script

bash setup.sh

This creates a virtual environment and installs all Python dependencies.

3. Configure your accounts

Copy the example config and fill in your accounts:

cp config.json.example config.json

Edit config.json:

{
  "accounts": {
    "personal": {
      "email": "you@gmail.com",
      "description": "Personal Gmail"
    },
    "work": {
      "email": "you@company.com",
      "description": "Work account"
    }
  },
  "credentials_dir": "./credentials"
}

The account keys (personal, work) are the names you'll use when asking Claude to interact with a specific account.

4. Get Google OAuth credentials

  1. Go to Google Cloud Console
  2. Create a project and enable both the Gmail API and the Google Calendar API
  3. Go to APIs & Services → Credentials → + Create Credentials → OAuth 2.0 Client ID
  4. Choose Desktop app as the application type
  5. Download the JSON file and save it as credentials/client_secret.json
  6. Go to APIs & Services → OAuth consent screen → Test users and add every email address you configured in config.json

5. Authenticate your accounts

source .venv/bin/activate
python setup_auth.py

A browser window will open for each account. Sign in with the correct Google account. Tokens are saved locally and refreshed automatically — you only need to do this once per account.

Note: If you previously authenticated for Gmail only, you must re-run setup_auth.py after adding Calendar support so the tokens include the new Calendar permissions.

6. Add the server to Claude Desktop

Open ~/Library/Application Support/Claude/claude_desktop_config.json and add:

{
  "mcpServers": {
    "gmail": {
      "command": "/absolute/path/to/gmail-mcp/.venv/bin/python",
      "args": ["/absolute/path/to/gmail-mcp/server.py"]
    }
  }
}

Replace /absolute/path/to/gmail-mcp with the actual path where you cloned the repo.

7. Restart Claude Desktop

All tools will appear automatically.

Available Tools

Gmail

Tool Description
list_accounts List all configured accounts and their auth status
gmail_get_profile Get account profile and mailbox stats
gmail_search Search emails using Gmail query syntax (one or all accounts)
gmail_read_message Read the full content of a message
gmail_read_thread Read all messages in a thread
gmail_send Send an email from a specific account
gmail_create_draft Save an email as a draft
gmail_list_drafts List drafts in an account
gmail_list_labels List all labels and folders
gmail_modify_labels Add or remove labels (mark read/unread, star, etc.)
gmail_trash Move a message to trash

Google Calendar

Tool Description
calendar_list_calendars List all calendars for an account (primary, work, shared, etc.)
calendar_list_events List upcoming events, optionally filtered by date range
calendar_search Search events by keyword (title, description, location, attendees)
calendar_get_event Get full details of a specific event

Usage Examples

Once connected, you can ask Claude things like:

Email:

  • "Do I have any unread emails in my work account?"
  • "Search for invoices received in the last month across all my accounts"
  • "Read the last email from John in my personal account"
  • "Draft a reply to the budget email in my work account"
  • "Mark all emails from newsletter@example.com as read"

Calendar:

  • "What meetings do I have this week in my work account?"
  • "Search for events related to 'product launch' in my personal calendar"
  • "List all my calendars in my work account"
  • "What are the details of tomorrow's standup?"

Adding a New Account

  1. Add the account to config.json
  2. Add the email as a Test User in Google Cloud Console (OAuth consent screen)
  3. Run python setup_auth.py — it will only prompt for the new account
  4. Restart Claude Desktop

Security

  • OAuth tokens are stored locally in credentials/tokens/ and are excluded from version control via .gitignore
  • config.json (which contains your email addresses) is also excluded from version control
  • Nothing is sent to any third-party server — all communication is directly between your Mac and Google's APIs
  • To revoke access at any time, visit myaccount.google.com/permissions

Project Structure

gmail-mcp/
├── server.py           # MCP server — exposes 15 tools to Claude
├── auth.py             # OAuth2 token manager (per account)
├── gmail.py            # Gmail API wrapper
├── gcalendar.py        # Google Calendar API wrapper
├── config.py           # Configuration loader
├── setup_auth.py       # One-time authentication script
├── setup.sh            # First-time installer
├── requirements.txt    # Python dependencies
├── config.json.example # Account configuration template
└── .gitignore          # Excludes credentials and config.json

License

MIT

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured