sudo-mcp-gmail
Provides tools for managing Gmail, including creating, updating, and sending drafts and messages, replying, forwarding, listing labels, marking messages read/unread, listing and searching messages with structured filters and raw Gmail queries.
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., "@sudo-mcp-gmailsearch emails about project update"
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.
sudo-mcp-gmail
A Python MCP server for Gmail that lets MCP clients such as Claude Desktop, Codex desktop, and other compatible clients use the published package name sudo-mcp-gmail:
create Gmail drafts with
to,cc,bcc,subject,body_text, optionalbody_html, and attachments from local files or HTTPS URLsupdate existing Gmail drafts
fetch and send Gmail drafts by draft ID
reply, reply-all, and forward messages
send Gmail messages with the same fields and attachment support
list Gmail labels
mark messages read or unread
list recent Gmail messages
read a specific Gmail message
search Gmail using raw Gmail queries or structured filters such as subject keywords, body keywords, senders, and company domains
preserve original attachment filenames and file extensions when safely available
Warning: send_gmail_message, send_gmail_draft, reply_to_gmail_message, reply_all_gmail_message, and forward_gmail_message send mail immediately from your Gmail account.
Tools
create_gmail_draft
Creates a Gmail draft with optional attachments.
Inputs:
to: list[str]subject: strbody_text: strcc: list[str] | Nonebcc: list[str] | Nonebody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
update_gmail_draft
Updates an existing draft by Gmail draft ID.
Inputs:
draft_id: strto: list[str]subject: strbody_text: strcc: list[str] | Nonebcc: list[str] | Nonebody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
get_gmail_draft
Fetches a draft by Gmail draft ID.
Inputs:
draft_id: str
send_gmail_draft
Sends an existing draft by Gmail draft ID.
Inputs:
draft_id: str
reply_to_gmail_message
Replies to a Gmail message.
Inputs:
message_id: strbody_text: strbody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
reply_all_gmail_message
Replies-all to a Gmail message.
Inputs:
message_id: strbody_text: strbody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
forward_gmail_message
Forwards a Gmail message.
Inputs:
message_id: strto: list[str]body_text: strcc: list[str] | Nonebcc: list[str] | Nonebody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
send_gmail_message
Sends a Gmail message immediately.
Inputs:
to: list[str]subject: strbody_text: strcc: list[str] | Nonebcc: list[str] | Nonebody_html: str | Noneattachments: list[str] | None— local file paths or HTTPS URLs
list_gmail_labels
Lists Gmail labels.
mark_gmail_message_read
Marks a Gmail message as read.
Inputs:
message_id: str
mark_gmail_message_unread
Marks a Gmail message as unread.
Inputs:
message_id: str
list_gmail_messages
Lists Gmail messages.
Inputs:
query: str | Nonelabel_ids: list[str] | Nonemax_results: int
get_gmail_message
Fetches a full Gmail message.
Inputs:
message_id: str
search_gmail_messages
Searches Gmail using structured filters and returns the Gmail query it built.
Inputs:
raw_query: str | Nonesubject_keywords: list[str] | Nonebody_keywords: list[str] | Nonefrom_addresses: list[str] | Nonecompany_domains: list[str] | Nonehas_attachments: bool | Nonenewer_than_days: int | Nonelabel_ids: list[str] | Nonemax_results: int
Prerequisites
Python 3.10+
A Google account with Gmail enabled
A Google Cloud project with the Gmail API enabled
OAuth desktop client credentials downloaded as JSON
Gmail API setup
Open Google Cloud Console.
Create or select a project.
Enable Gmail API.
Go to APIs & Services → OAuth consent screen.
Configure the consent screen.
Go to APIs & Services → Credentials.
Create OAuth client ID credentials.
Choose Desktop app.
Download the JSON credentials file.
Save it as
credentials.jsonin the project root, or set a custom path withGMAIL_MCP_CREDENTIALS_FILE.
Install from source
python -m venv .venv
source .venv/Scripts/activate
pip install -e .Install from pip
After you publish the package to PyPI, install it anywhere without cloning the repo:
pip install sudo-mcp-gmailThen run it with:
sudo-mcp-gmailIf you want to pin a specific release:
pip install sudo-mcp-gmail==0.1.0Authentication
The first time the server needs Gmail access, it opens a local browser OAuth flow.
By default:
client credentials file:
credentials.jsonrefresh token file:
token.json
Environment variables:
GMAIL_MCP_CREDENTIALS_FILE— path to Google OAuth desktop credentials JSONGMAIL_MCP_TOKEN_FILE— path where the Gmail refresh token will be stored
Example:
export GMAIL_MCP_CREDENTIALS_FILE="C:/path/to/credentials.json"
export GMAIL_MCP_TOKEN_FILE="C:/path/to/token.json"On Windows PowerShell:
$env:GMAIL_MCP_CREDENTIALS_FILE = "C:\path\to\credentials.json"
$env:GMAIL_MCP_TOKEN_FILE = "C:\path\to\token.json"Run locally
sudo-mcp-gmailClaude Desktop MCP config
Add a server entry pointing to the installed command. Example shape:
{
"mcpServers": {
"gmail": {
"command": "sudo-mcp-gmail",
"env": {
"GMAIL_MCP_CREDENTIALS_FILE": "C:/path/to/credentials.json",
"GMAIL_MCP_TOKEN_FILE": "C:/path/to/token.json"
}
}
}
}If your client requires launching via Python directly, use:
{
"mcpServers": {
"gmail": {
"command": "python",
"args": ["-m", "sudo_mcp_gmail.server"],
"env": {
"GMAIL_MCP_CREDENTIALS_FILE": "C:/path/to/credentials.json",
"GMAIL_MCP_TOKEN_FILE": "C:/path/to/token.json"
}
}
}
}Codex or other MCP clients
Use the same pattern:
command:
sudo-mcp-gmailorpython -m sudo_mcp_gmail.serverpass the Gmail credentials/token file paths through environment variables
Attachment URL safety
Remote attachments support HTTPS URLs only.
Blocked attachment sources:
http://...file://...https://localhost/...private-network or loopback IP targets such as
https://127.0.0.1/...orhttps://192.168.1.10/...
Safety behavior:
remote downloads are size-limited to 10 MB
filenames are taken from
Content-Dispositionwhen available, otherwise from the URL pathfilenames are sanitized before attaching
original filename and extension are preserved when safely available
Example prompts in an MCP client
"Create a Gmail draft to jane@example.com with cc to finance@example.com, subject 'Q2 follow-up', body 'Please see attached', and attach
C:/tmp/report.pdf.""Update Gmail draft
r-1234567890with a new subject and body.""Get the Gmail draft with ID
r-1234567890.""Send the Gmail draft with ID
r-1234567890.""Reply to message
<message_id>with body 'Thanks, received.'""Reply all to message
<message_id>and attachC:/tmp/notes.txt.""Forward message
<message_id>to jane@example.com with note 'Please review'.""List Gmail labels."
"Mark message
<message_id>as read.""Mark message
<message_id>as unread.""Send an email to jane@example.com with subject 'Hello', body 'Checking in', and attach
C:/tmp/agenda.docx.""Create a Gmail draft to jane@example.com and attach
https://example.com/files/report.pdf.""Send an email to jane@example.com and attach
https://example.com/files/invoice.pdf.""List my last 10 inbox emails."
"Get message
<message_id>.""Search my email for invoices from stripe.com in the last 30 days with attachments."
Security notes
Keep
credentials.jsonand token files private.Do not commit OAuth credentials or refresh tokens.
This server uses the Gmail scope
https://www.googleapis.com/auth/gmail.modify, which allows reading mailbox data, creating drafts, sending messages, replying, forwarding, and modifying labels/read state.Sending/replying/forwarding tools act immediately, so use them carefully.
Remote attachment URLs are restricted to HTTPS and blocked for localhost/private-network targets.
Remote attachment downloads are limited to 10 MB.
Build and publish the pip package
Build distributable artifacts:
python -m pip install --upgrade pip
pip install -e .[dev]
python -m buildThis creates:
dist/*.tar.gz— source distributiondist/*.whl— wheel distribution
Validate the package metadata before upload:
python -m twine check dist/*Upload to TestPyPI first:
python -m twine upload --repository testpypi dist/*Install from TestPyPI to verify:
pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple sudo-mcp-gmailUpload to PyPI:
python -m twine upload dist/*After publishing, anyone can install and run it with:
pip install sudo-mcp-gmail
sudo-mcp-gmailDevelopment
Install development tooling:
pip install -e .[dev]
pytestRelease checklist
Update the version in
pyproject.tomlandsrc/sudo_mcp_gmail/__init__.py.Clear old build artifacts if needed.
Run
pytest.Run
python -m build.Run
python -m twine check dist/*.Upload to TestPyPI, verify install, then upload to PyPI.
Create a git tag matching the release version if you want versioned releases in GitHub.
Suggested future features
archive/unarchive tools
trash/untrash tools
label add/remove tools for messages and threads
thread-level tools
download Gmail attachments
pagination support for large searches
unread/starred/important convenience filters
better HTML sanitization or markdown-to-HTML support for outgoing messages
attachment metadata in read/search results
This server cannot be installed
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/sahilyadav902/sudo-mcp-gmail'
If you have feedback or need assistance with the MCP directory API, please join our Discord server