YAGMS
An MCP server for interacting with the Gmail API, enabling email management.
yagms
Yet Another Gmail MCP Server
Setup and Usage
Gmail MCP Server
The Gmail MCP server provides tools to interact with your Gmail account through the Model Context Protocol (MCP).
Prerequisites
- Create OAuth credentials for Gmail API:
- Go to Google Cloud Console
- Create a new project or select an existing one
- Enable the Gmail API
- Create OAuth 2.0 credentials (Desktop application)
- Download the credentials JSON file and save it as
~/.yagms-oauth.keys.json
Build this project
- Install Bun.
- Build the code
bun install
bun run build-gmail # It will emit ./dist/gmail.js
Authentication
Before using the Gmail MCP server, you need to authenticate with your Google account:
# Run the authentication flow
bun run dist/gmail.js auth
This will:
- Launch a browser window for you to sign in to your Google account
- Request permission to access your Gmail account
- Save the authentication credentials to
~/.yagms-credentials.json
Running the Server
After authentication, you can run the Gmail MCP server:
# Run the server
bun run src/gmail.ts
Configuration
You can customize the paths for OAuth keys and credentials using environment variables:
GMAIL_OAUTH_PATH
: Path to the OAuth keys file (default:~/.yagms-oauth.keys.json
)GMAIL_CREDENTIALS_PATH
: Path to save the credentials (default:~/.yagms-credentials.json
)
Available Tools
The Gmail MCP server provides the following tools:
-
list-emails: Get emails from your inbox
- Parameters:
senderEmail
(optional): Filter by sender emailmaxResults
(optional, default: 10): Maximum number of emails to returnlabelIds
(optional, default: ["INBOX"]): Label IDs to filter by
- Parameters:
-
get-email: Get a specific email by ID
- Parameters:
emailId
: The ID of the email to retrieve
- Parameters:
-
search-emails: Search for emails using Gmail search syntax
- Parameters:
query
: Gmail search query (e.g., "from:example@gmail.com has:attachment")maxResults
(optional, default: 10): Maximum number of emails to return
- Parameters:
-
get-labels: Get all Gmail labels
- No parameters required
Example MCP Configuration
Add this to your MCP settings file:
{
"mcpServers": {
"gmail": {
"command": "bun",
"args": ["run", "/path/to/yagms/dist/gmail.js"],
"env": {},
"disabled": false,
"autoApprove": []
}
}
}
Related Servers
MCP Server Whisper
Advanced audio transcription and processing using OpenAI's Whisper and GPT-4o models.
Telegram MCP Server
Interact with the Telegram messaging service to send and receive messages.
Zulip Chat
An MCP server for integrating with the Zulip team chat platform.
Wizzypedia MCP Server
Interact with Wizzypedia through the MediaWiki API, supporting both read-only and authenticated operations.
Interact MCP
Enables real-time communication between AI assistants and users via a web-based chat interface.
MCP Headless Gmail Server
A headless server to get and send emails via the Gmail API, requiring Google API credentials at runtime.
Slack
The most powerful MCP server for Slack Workspaces. This integration supports both Stdio and SSE transports, proxy settings and does not require any permissions or bots being created or approved by Workspace admins 😏.
MCP-Pushover Bridge
Enables AI assistants to send push notifications via the Pushover service.
Human-in-the-Loop Slack MCP Server
Allows AI assistants to request information and receive responses from humans via Slack.
Deepseek R1
An MCP server for the Deepseek R1 model, using the Deepseek API.