MCP Hub
Back to servers

mcp-gmail

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.

Stars
2
Updated
Feb 16, 2026
Validated
Feb 18, 2026

mcp-gmail

Give Claude full access to your Gmail. Search, read, send, reply, forward, manage drafts, labels, and attachments — all through the Model Context Protocol.

What you can do

"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 accounting@company.com"

17 tools covering everything you'd do in Gmail — without leaving Claude.


Quick Start

Prerequisites

  • Bun runtime
  • A Google account with Gmail

1. Google Cloud setup

Create project & enable Gmail API (click to expand)
  1. Go to Google Cloud Console
  2. Select a projectNew Project → name it (e.g., "Gmail MCP") → Create
  3. Go to APIs & ServicesLibrary → search Gmail APIEnable
Configure OAuth consent screen
  1. Go to APIs & ServicesOAuth consent screen
  2. Click Create on the Overview tab
  3. Fill in App name and User support email
  4. Select ExternalCreate
  5. Data access tab → Add or Remove Scopes → find https://www.googleapis.com/auth/gmail.modify → check it → UpdateSave
  6. Users tab → Add Users → add your Gmail address → Save

Tip: In "Testing" mode, refresh tokens expire every 7 days. To avoid this, go to Publishing statusPublish App. For personal use, Google won't require verification.

Create OAuth credentials
  1. Go to APIs & ServicesCredentials
  2. Create CredentialsOAuth client IDDesktop app
  3. Click CreateDownload JSON
  4. Save as credentials.json in the project root

2. Install & authenticate

git 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).

3. Add to Claude Desktop

Edit your config file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %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. If bun isn't found, use the full path — run which bun to find it.

Restart Claude Desktop. You should see gmail in the MCP servers list.


Tools

Email

ToolDescription
search_emailsSearch using Gmail query syntax
get_emailGet full content by message ID
send_emailSend a new email
reply_to_emailReply to an email (preserves thread)
forward_emailForward to new recipients

Drafts

ToolDescription
create_draftCreate a new draft
list_draftsList all drafts
send_draftSend an existing draft
delete_draftPermanently delete a draft

Organization

ToolDescription
trash_emailMove to trash
archive_emailRemove from inbox
mark_as_readMark as read
mark_as_unreadMark as unread

Labels

ToolDescription
list_labelsList all labels
create_labelCreate a new label
apply_labelApply a label to a message
remove_labelRemove a label from a message

Attachments

ToolDescription
get_attachmentDownload attachment (base64)

Gmail Search Syntax

The search_emails tool supports all Gmail search operators:

from:alice@example.com          # From specific sender
to:bob@example.com              # 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

Troubleshooting

ProblemSolution
credentials.json not foundDownload OAuth credentials from Google Cloud Console
.gmail-tokens.json not foundRun bun run auth
Token has been revokedRe-run bun run auth
Refresh token expiredApp is in "Testing" mode — re-run bun run auth or publish the app
Insufficient permissionsEnsure gmail.modify scope was granted during auth
Server not appearing in ClaudeCheck the config path is absolute, then restart Claude Desktop
Port 3000 is already in useFree port 3000 and re-run bun run auth

License

Apache 2.0

Reviews

No reviews yet

Sign in to write a review