loading…
Search for a command to run...
loading…
Provides a suite of 17 tools for searching, reading, sending, and managing Gmail messages and drafts through the Model Context Protocol. It enables comprehensiv
Provides a suite of 17 tools for searching, reading, sending, and managing Gmail messages and drafts through the Model Context Protocol. It enables comprehensive email management including label organization, archiving, and attachment handling directly within MCP-compatible clients like Claude.
Give Claude full access to your Gmail. Search, read, send, reply, forward, manage drafts, labels, and attachments — all through the Model Context Protocol.
"Search my inbox for emails from Sarah this week" "Draft a reply to that meeting invite" "Archive all read emails labeled 'notifications'" "Forward the latest invoice to [email protected]"
17 tools covering everything you'd do in Gmail — without leaving Claude.
https://www.googleapis.com/auth/gmail.modify → check it → Update → SaveTip: In "Testing" mode, refresh tokens expire every 7 days. To avoid this, go to Publishing status → Publish App. For personal use, Google won't require verification.
credentials.json in the project rootgit clone https://github.com/user/mcp-gmail.git # replace with your repo URL
cd mcp-gmail
bun install
bun run auth # opens browser for Gmail authorization
Tokens are saved locally to .gmail-tokens.json (git-ignored).
Edit your config file:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json{
"mcpServers": {
"gmail": {
"command": "bun",
"args": ["/ABSOLUTE/PATH/TO/mcp-gmail/src/index.ts"]
}
}
}
Note: Claude Desktop doesn't inherit your shell
PATH. Ifbunisn't found, use the full path — runwhich bunto find it.
Restart Claude Desktop. You should see gmail in the MCP servers list.
| Tool | Description |
|---|---|
search_emails |
Search using Gmail query syntax |
get_email |
Get full content by message ID |
send_email |
Send a new email |
reply_to_email |
Reply to an email (preserves thread) |
forward_email |
Forward to new recipients |
| Tool | Description |
|---|---|
create_draft |
Create a new draft |
list_drafts |
List all drafts |
send_draft |
Send an existing draft |
delete_draft |
Permanently delete a draft |
| Tool | Description |
|---|---|
trash_email |
Move to trash |
archive_email |
Remove from inbox |
mark_as_read |
Mark as read |
mark_as_unread |
Mark as unread |
| Tool | Description |
|---|---|
list_labels |
List all labels |
create_label |
Create a new label |
apply_label |
Apply a label to a message |
remove_label |
Remove a label from a message |
| Tool | Description |
|---|---|
get_attachment |
Download attachment (base64) |
The search_emails tool supports all Gmail search operators:
from:[email protected] # From specific sender
to:[email protected] # To specific recipient
subject:meeting # Subject contains "meeting"
has:attachment # Has attachments
is:unread # Unread emails
is:starred # Starred emails
label:important # Has label
after:2024/01/01 # After date
before:2024/12/31 # Before date
newer_than:7d # Last 7 days
"exact phrase" # Exact match
from:alice subject:report # Combine operators
| Problem | Solution |
|---|---|
credentials.json not found |
Download OAuth credentials from Google Cloud Console |
.gmail-tokens.json not found |
Run bun run auth |
Token has been revoked |
Re-run bun run auth |
Refresh token expired |
App is in "Testing" mode — re-run bun run auth or publish the app |
Insufficient permissions |
Ensure gmail.modify scope was granted during auth |
| Server not appearing in Claude | Check the config path is absolute, then restart Claude Desktop |
Port 3000 is already in use |
Free port 3000 and re-run bun run auth |
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"mcp-gmail": {
"command": "npx",
"args": []
}
}
}Read, send and search emails from Claude
Send, search and summarize Slack messages
No-code MCP client for team chat platforms, such as Slack, Microsoft Teams, and Discord.
A community discord server dedicated to MCP by [Frank Fiegel](https://github.com/punkpeye)