gmail-multi-mcp
Manage multiple Gmail accounts with tools for searching, reading, composing, sending, labeling, archiving, and trashing emails.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@gmail-multi-mcpsearch personal inbox for unread emails"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
gmail-multi-mcp
Connect multiple Gmail accounts to Claude (or any MCP client) from one local server. The official Gmail connector only supports a single Google account — this lets you search, read, draft, send, label, and organize mail across as many accounts as you like, each addressed by a friendly alias.
Your OAuth tokens are stored locally on your machine only — never uploaded anywhere.
Features
🔢 Unlimited accounts — every tool takes an
accountparameter ("personal","work", …)🔎 Search & read — full Gmail search syntax, thread/message reading, attachment download
✍️ Compose — create/list/delete drafts, send mail, replies with correct threading headers
🏷️ Organize — full label management, archive, trash
🔐 Local-first — standard Google OAuth; tokens live in
~/.gmail-mcp/, chmod 600🧩 22 tools, works with Claude Code, Claude Desktop, Cursor, and any MCP client
Related MCP server: Gmail MCP Server
Prerequisites
Node.js ≥ 20
A Google account (and a free Google Cloud project — setup below)
1. Install
git clone https://github.com/Vinksj/claude-gmail-multi.git
cd claude-gmail-multi
npm install
npm run build2. Create your Google OAuth app (one-time, ~10 min)
You register one OAuth "app" with Google; it then works for all the accounts you connect.
Go to console.cloud.google.com → create a project (e.g.
gmail-mcp).APIs & Services → Library → search Gmail API → Enable.
APIs & Services → OAuth consent screen:
User type External → Create.
App name + your support email + your contact email → Save and Continue.
Scopes page → Save and Continue. Test users page → Save and Continue.
Publish to production: on the OAuth consent screen, set Publishing status → Publish app. (In "Testing" mode Google expires your refresh token every 7 days. Publishing avoids that. You'll click through a one-time "Google hasn't verified this app" warning per account — that's normal for a personal app: choose Advanced → Continue.)
APIs & Services → Credentials → Create Credentials → OAuth client ID:
Application type Desktop app → Create → Download JSON.
Save that file as
~/.gmail-mcp/credentials.json:mkdir -p ~/.gmail-mcp && chmod 700 ~/.gmail-mcp mv ~/Downloads/client_secret_*.json ~/.gmail-mcp/credentials.json chmod 600 ~/.gmail-mcp/credentials.json
Note: newer Google Cloud UIs put these under "Google Auth Platform" (Branding / Audience / Clients) instead of "OAuth consent screen" — same steps, different labels.
3. Connect your accounts
npm run auth -- --alias personal --email you@gmail.com
npm run auth -- --alias work --email you@company.comEach opens a browser → pick the matching Google account → approve. The optional --email flag
aborts if the wrong account gets authorized (an easy mistake with multi-login browsers). Connect
as many as you want; re-run any time a token is revoked.
4. Register with your MCP client
Claude Code:
claude mcp add --scope user gmail-multi -- node "$(pwd)/dist/index.js"Claude Desktop / other clients — add to your MCP config:
{
"mcpServers": {
"gmail-multi": {
"command": "node",
"args": ["/absolute/path/to/gmail-multi-mcp/dist/index.js"]
}
}
}Tools appear as gmail-multi's search_threads, create_draft, etc. Ask things like
"search my work inbox for unread from this week" or "draft a reply in personal to Alice."
Tools
Group | Tools |
Accounts |
|
Read |
|
Compose |
|
Labels |
|
Cleanup |
|
Every tool except list_accounts takes an account parameter (alias or email). Replies via
replyToMessageId get correct In-Reply-To/References headers and threading automatically.
How it works
One self-owned Google Cloud OAuth app (Desktop client) authorizes any number of accounts.
Single scope:
https://www.googleapis.com/auth/gmail.modify(read, search, drafts, send, labels, archive, trash — narrower than fullhttps://mail.google.com/).Per-account refresh tokens stored in
~/.gmail-mcp/tokens/<alias>.json(chmod 600); the account registry is~/.gmail-mcp/config.json. Nothing leaves your machine.
~/.gmail-mcp/
├── credentials.json # your OAuth client (you add this)
├── config.json # alias → email map (auto-managed)
└── tokens/<alias>.json # per-account refresh tokens (auto-managed)Security notes
Tokens are stored as plain files readable only by your user (chmod 600). On a single-user machine with full-disk encryption this is reasonable; moving token storage to the OS keychain is a sensible future hardening step.
Never commit
~/.gmail-mcp/— it lives in your home directory, outside this repo, and the repo's.gitignoreexcludes build artifacts and dependencies regardless.The
gmail.modifyscope cannot permanently delete mail —trash_*tools move items to Trash (recoverable for 30 days).
Development
npm run build # tsc -> dist/
npm run inspect # MCP Inspector UI against the built server
npm run auth -- --alias <name> [--email <expected>]Important: stdout is the JSON-RPC channel — never console.log in server code; use console.error.
License
MIT © Saurabh Jain
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Vinksj/claude-gmail-multi'
If you have feedback or need assistance with the MCP directory API, please join our Discord server