Google MailPilot
Enables AI agents to read, triage, respond to, and calendar-manage Gmail with a production-grade MCP control plane and human-in-the-loop safety.
README
Google MailPilot
The AI-native command center for Gmail and Google Workspace
Google MailPilot is the renamed successor to Gmail Secretary, built so LLMs can read, triage, respond to, and calendar-manage Gmail with a production-grade MCP control plane.
โ ๏ธ Release Notice: v5.0.0 is the first public release under the Google MailPilot brand; it fixes MCP tool registration, tightens triage/compose coverage, adds new booking-link helpers, and keeps every mutation human-in-the-loop.
Release highlights:
- Tools now register as soon as
workspace_secretary.toolsimports, preventing FastMCP registration bugs.- Triage/compose tooling gained synchronous tests plus
tests/test_triage_priority_emails.pyandtests/test_web_compose.pyto cover CLI-aware workflows.- Engine/web routes, booking links, and
raw:continuation-state handling now align with Google MailPilot expectations.
๐ฆ Stability Matrix
We believe in transparency. Here is the current readiness of our stack:
| Component | Status | Stability Notes |
|---|---|---|
| IMAP Sync Engine | ๐ข Stable | RFC-compliant, IDLE support, tested on >24k emails. |
| Read Operations | ๐ข Stable | Search, Threading (X-GM-THRID), and Summarization work perfectly. |
| Write Operations | ๐ก Beta | Draft creation is stable. Auto-sending is currently disabled via the Safety Interceptor. |
| Web Dashboard | ๐ Alpha | Early preview. UI may change rapidly. |
A Google MailPilot IMAP/SMTP control plane for AI agents with calendar integration
Built for LLMs that need to read, search, triage, and respond to email autonomously. Not just an MCP wrapper โ a full-featured IMAP control plane engineered for AI orchestration workflows.
๐ Documentation ยท ๐๏ธ Architecture ยท โก Quick Start
Why This Exists
Most email integrations for AI are thin API wrappers. They poll. They re-fetch. They timeout. They don't understand email threading, modification sequences, or push notifications.
Google MailPilot is different. It's a production-grade IMAP control plane that:
- Syncs intelligently โ CONDSTORE tracks what changed, IDLE pushes new mail instantly
- Caches locally โ SQLite or PostgreSQL, your AI reads from local DB in milliseconds
- Understands Gmail โ Native X-GM-THRID threading, X-GM-LABELS, X-GM-RAW search
- Never sends without approval โ Human-in-the-loop by design, drafts first
๐ก RFC Compliance
We implement these IMAP extensions for efficient, real-time email sync:
| RFC | Extension | What It Does | Benefit |
|---|---|---|---|
| RFC 3501 | IMAP4rev1 | Core protocol | Full IMAP compliance |
| RFC 7162 | CONDSTORE | Tracks modification sequences | Skip sync when mailbox unchanged |
| RFC 7162 | CHANGEDSINCE | Fetch only changed flags | 10x faster incremental sync |
| RFC 2177 | IDLE | Push notifications | Instant new mail detection |
| RFC 2971 | ID | Client identification | Better server compatibility |
Gmail-Specific Extensions
| Extension | Purpose |
|---|---|
X-GM-THRID |
Native Gmail thread ID โ no heuristic threading needed |
X-GM-MSGID |
Stable message identifier across folders |
X-GM-LABELS |
Full Gmail label support (stored as JSONB) |
X-GM-RAW |
Gmail's powerful search syntax for targeted sync |
โก Performance
Real benchmarks against a 50,000 email mailbox:
| Operation | Traditional IMAP | Google MailPilot |
|---|---|---|
| Check for new mail | 2-5s (fetch all UIDs) | < 50ms (HIGHESTMODSEQ compare) |
| Sync flag changes | Re-fetch messages | Flags only (CHANGEDSINCE) |
| New mail notification | 5-min poll interval | Instant (IDLE push) |
| Search emails | Server roundtrip | < 10ms (local SQLite FTS5) |
| Thread reconstruction | Parse References headers | Instant (X-GM-THRID) |
How CONDSTORE Works
Traditional Sync:
1. SELECT INBOX
2. FETCH 1:* (FLAGS) โ Downloads ALL flags every time
3. Compare with cache
4. Fetch changed messages
CONDSTORE Sync:
1. SELECT INBOX
2. Compare HIGHESTMODSEQ โ Single integer comparison
3. If unchanged โ done โ Skip everything
4. If changed โ FETCH 1:* (FLAGS) CHANGEDSINCE <modseq>
โ Only changed messages
๐๏ธ Architecture
Dual-process design separating sync from AI interface:
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ AI Layer (Claude, etc.) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โผ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ MCP Server (read-only) โ
โ โข Exposes 25+ tools for email/calendar operations โ
โ โข Reads directly from local database โ
โ โข Mutations proxied to Engine API โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโโโโโโโโ
โผ โผ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ SQLite / PostgreSQL โ โ Secretary Engine โ
โ โข Email cache (FTS5) โโโโโโโโโโ โข IMAP sync (CONDSTORE) โ
โ โข Gmail labels (JSONB) โ โ โข IDLE monitor โ
โ โข Embeddings (pgvector) โ โ โข OAuth2 management โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโ โ โข SMTP send/draft โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โผ
โโโโโโโโโโโโโโโโโโโโ
โ Gmail IMAP โ
โ Gmail SMTP โ
โ Calendar API โ
โโโโโโโโโโโโโโโโโโโโ
Why Two Processes?
| Concern | Engine | MCP Server |
|---|---|---|
| Sync | Owns IMAP connection, IDLE loop | Never touches IMAP |
| Database | All writes | Read-only |
| Uptime | Always running | Scales with AI requests |
| Credentials | Holds OAuth tokens | Stateless |
๐ฏ AI-Native Features
Calendar Integration:
- โก Instant Calendar Access: Sub-50ms queries via intelligent caching layer
- ๐ Offline-First Operations: Create/edit/delete events without internet, sync transparently
- ๐ Background Sync Worker: Autonomous daemon syncs every 60s using Google Calendar API sync tokens
- ๐ท๏ธ Status Indicators: Visual badges show pending/synced/conflict states for offline operations
- โ๏ธ Multi-Calendar Support: Select which calendars to display via web UI settings
Email Intelligence:
Intelligent Signal Extraction
Every email is analyzed for actionable signals:
signals = {
"is_addressed_to_me": True, # In To: field, not just CC
"mentions_my_name": True, # Name appears in body
"has_question": True, # Contains "?" or question phrases
"mentions_deadline": True, # "EOD", "ASAP", "by Friday"
"mentions_meeting": True, # Scheduling keywords detected
"is_from_vip": True, # Sender in configured VIP list
"has_attachments": True, # PDF, DOCX, etc.
"attachment_filenames": ["Q4_Report.pdf"]
}
Human-in-the-Loop Safety
The AI never sends email without explicit approval.
User: "Reply to Sarah saying I'll attend the meeting"
AI: I've drafted this reply:
To: sarah@company.com
Subject: Re: Team Meeting Tomorrow
Hi Sarah,
I'll be there. Looking forward to it!
Best regards
Send this email? (yes/no)
User: "yes"
AI: โ Email sent successfully
Confidence-Based Batch Operations
Bulk operations require approval with confidence tiers:
| Confidence | Batch Size | Display |
|---|---|---|
| High (>90%) | Up to 100 | Date, From, Subject only |
| Medium (50-90%) | Up to 10 | + First 300 chars of body |
| Low (<50%) | Individual | Full context required |
๐ Quick Start
Prerequisites
- Docker and Docker Compose
- Gmail account with App Password (or OAuth2)
- Google Cloud project (for Calendar integration)
1. Clone and Configure
git clone https://github.com/johnneerdael/google-mailpilot.git
cd google-mailpilot
cp config.sample.yaml config/config.yaml
2. Edit Configuration
# config/config.yaml
imap:
host: imap.gmail.com
port: 993
username: your-email@gmail.com
password: your-app-password # Gmail App Password
user:
email: your-email@gmail.com
first_name: Your
last_name: Name
timezone: America/New_York
working_hours:
start: "09:00"
end: "18:00"
vip_senders:
- ceo@company.com
- important-client@example.com
database:
backend: sqlite # or "postgres" for embeddings
path: /app/config/secretary.db
bearer_auth:
enabled: true
token: "generate-with-uuidgen"
3. Start Services
docker-compose up -d
4. Connect Your AI
Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"secretary": {
"url": "http://localhost:8000/mcp",
"headers": {
"Authorization": "Bearer your-token-here"
}
}
}
}
๐ง Available Tools
Email Operations
| Tool | Description |
|---|---|
search_emails |
FTS5-powered local search with Gmail query syntax |
get_email_details |
Full email content with signals and metadata |
get_email_thread |
Complete thread via X-GM-THRID |
summarize_thread |
AI-ready thread summary |
create_draft_reply |
Draft response (never auto-sends) |
send_email |
Send with explicit approval |
modify_gmail_labels |
Add/remove Gmail labels |
move_email |
Move between folders |
Calendar Operations
| Tool | Description |
|---|---|
list_calendar_events |
Events in time range |
get_calendar_availability |
Free/busy lookup |
create_calendar_event |
Create with timezone support |
suggest_reschedule |
Find alternative meeting times |
Triage Operations
| Tool | Description |
|---|---|
get_daily_briefing |
Priority emails + today's calendar |
triage_priority_emails |
Identify high-priority items |
quick_clean_inbox |
Batch cleanup with approval |
Semantic Search (PostgreSQL + pgvector)
| Tool | Description |
|---|---|
semantic_search_emails |
Search by meaning, not keywords |
find_related_emails |
Similar emails to reference |
๐ Database Schema
Email Storage
CREATE TABLE emails (
uid INTEGER,
folder TEXT,
message_id TEXT UNIQUE,
gmail_thread_id BIGINT, -- X-GM-THRID
gmail_msgid BIGINT, -- X-GM-MSGID
gmail_labels JSONB, -- Full label set
subject TEXT,
from_addr TEXT,
to_addr TEXT,
date TIMESTAMPTZ,
internal_date TIMESTAMPTZ, -- INTERNALDATE
body_text TEXT,
body_html TEXT,
flags TEXT,
modseq BIGINT, -- CONDSTORE sequence
has_attachments BOOLEAN,
attachment_filenames JSONB,
-- FTS5 index on subject, from_addr, to_addr, body_text
);
Folder State (CONDSTORE)
CREATE TABLE folder_state (
folder TEXT PRIMARY KEY,
uidvalidity INTEGER,
uidnext INTEGER,
highestmodseq BIGINT -- For CONDSTORE sync
);
๐ Security
| Layer | Protection |
|---|---|
| Transport | TLS 1.2+ for IMAP/SMTP |
| Authentication | OAuth2 or App Passwords (never plain passwords) |
| API | Bearer token authentication |
| Data | Local database, no cloud sync |
| Actions | Human approval for all mutations |
Never Stored
- Plain text passwords
- OAuth refresh tokens in logs
- Email content in error messages
๐ Documentation
| Guide | Description |
|---|---|
| Architecture | Deep dive into dual-process design |
| Configuration | All config options explained |
| Agent Rules | HITL safety patterns |
| API Reference | Complete tool documentation |
๐ ๏ธ Development
# Install with dev dependencies
pip install -e ".[dev]"
# Run tests
pytest
# Run locally
python -m workspace_secretary.engine.api & # Start engine
python -m workspace_secretary.server # Start MCP server
License
MIT License โ see LICENSE for details.
<p align="center"> <strong>Built for AI agents that take email seriously.</strong><br> <a href="https://github.com/johnneerdael/google-mailpilot">GitHub</a> ยท <a href="https://johnneerdael.github.io/google-mailpilot/">Documentation</a> ยท <a href="https://modelcontextprotocol.io/">Model Context Protocol</a> </p>
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.