Gmail Sender MCP Server
Allows sending emails and creating drafts through the Gmail API.
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 Sender MCP Serversend an email to john@example.com with subject 'Meeting' and body 'See you tomorrow'"
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 Sender MCP Server
An MCP (Model Context Protocol) server that enables sending emails and creating drafts through the Gmail API.
Features
sendEmail: Send emails through your Gmail account with optional file attachments
createDraft: Create email drafts with optional file attachments
OAuth 2.0 authentication with Google
Support for file attachments of various types (PDF, DOC, images, etc.)
Run anywhere with
npx- no local installation required
Related MCP server: Gmail MCP Server
Prerequisites
Node.js v18 or higher
A Google Cloud project with Gmail API enabled
OAuth 2.0 credentials (Client ID and Client Secret)
Setting up Google Cloud Credentials
Go to the Google Cloud Console
Create a new project or select an existing one
Enable the Gmail API for your project
Go to Credentials and create an OAuth 2.0 Client ID
Set the application type to Web application
Add
http://localhost:3500/oauth2callbackas an authorized redirect URISave your Client ID and Client Secret
Installation & Usage
Run with npx (Recommended)
The easiest way to use this server is with npx. No installation required:
GMAIL_CLIENT_ID=your_client_id GMAIL_CLIENT_SECRET=your_client_secret npx gmail-sender-mcp-serverInstall Globally
npm install -g gmail-sender-mcp-serverThen run:
GMAIL_CLIENT_ID=your_client_id GMAIL_CLIENT_SECRET=your_client_secret gmail-sender-mcp-serverInstall Locally (for development)
git clone <repository-url>
cd Gmail_MCP_server
npm install
GMAIL_CLIENT_ID=your_client_id GMAIL_CLIENT_SECRET=your_client_secret npm startAuthentication
On first run, the server will start an OAuth server on port 3500:
Visit
http://localhost:3500/authin your browserSign in with your Google account and grant permissions
The authentication token will be saved to
~/.config/gmail-sender-mcp-server/token.json
The token is stored in your home directory, so it persists across npx runs and works across different machines once authenticated.
Environment Variables
Variable | Required | Description |
| Yes | Your Google OAuth 2.0 Client ID |
| Yes | Your Google OAuth 2.0 Client Secret |
MCP Configuration
To use this server with an MCP client (like Claude Desktop), add it to your MCP configuration:
{
"mcpServers": {
"gmail-sender": {
"type": "stdio",
"command": "npx",
"args": ["gmail-sender-mcp-server"],
"env": {
"GMAIL_CLIENT_ID": "your_client_id",
"GMAIL_CLIENT_SECRET": "your_client_secret"
}
}
}
}Available Tools
sendEmail
Send an email immediately through Gmail.
Parameters:
recipient(required): Email address of the recipientsubject(required): Subject line of the emailbody(required): Body content of the email (plain text)attachmentPath(optional): Absolute path to a file to attach
Example:
{
"recipient": "example@email.com",
"subject": "Hello from MCP",
"body": "This is a test email sent via the Gmail MCP server.",
"attachmentPath": "/path/to/document.pdf"
}createDraft
Create an email draft in Gmail (not sent automatically).
Parameters:
recipient(required): Email address of the recipientsubject(required): Subject line of the emailbody(required): Body content of the email (plain text)attachmentPath(optional): Absolute path to a file to attach
Example:
{
"recipient": "example@email.com",
"subject": "Draft Email",
"body": "This is a draft that can be reviewed and sent later.",
"attachmentPath": "/path/to/image.png"
}Supported Attachment Types
The server automatically detects file types based on extension:
Documents: PDF, DOC, DOCX, TXT
Images: JPG, JPEG, PNG, GIF
Archives: ZIP
Other files are sent as
application/octet-stream
OAuth Scopes
The server uses the https://www.googleapis.com/auth/gmail.compose scope, which allows:
Creating and sending emails
Creating drafts
Modifying drafts
File Structure
gmail-sender-mcp-server/
├── src/
│ └── index.js # Main server implementation
├── package.json # Dependencies and scripts
└── README.md # This file
~/.config/gmail-sender-mcp-server/
└── token.json # OAuth tokens (created after authentication)Security Notes
OAuth tokens are stored in
~/.config/gmail-sender-mcp-server/token.jsonand should be kept secureClient ID and Secret should be passed via environment variables, not committed to version control
The OAuth server only runs on localhost (port 3500)
Consider using a secrets manager for production deployments
Troubleshooting
Authentication Issues
Ensure your OAuth client is configured with
http://localhost:3500/oauth2callbackas a redirect URICheck that the Gmail API is enabled in your Google Cloud project
Verify your
GMAIL_CLIENT_IDandGMAIL_CLIENT_SECRETenvironment variables are set correctly
Token Issues
If authentication fails, delete
~/.config/gmail-sender-mcp-server/token.jsonand re-authenticateTokens may expire; re-authenticate if you get authorization errors
File Attachment Issues
Use absolute paths for attachments
Ensure the file exists and is readable
Check that the file size is within Gmail's limits (25MB for attachments)
License
MIT
Gmail_MCP_server
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Tools
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/TheMossConcept/Gmail_MCP_server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server