Unofficial Model Context Protocol server for Fastmail integration. Exposes a single execute tool that acts as a validated JMAP proxy — the LLM writes raw JMAP method calls, and the server handles validation, authentication, and response cleaning.
- Log in to Fastmail
- Go to Settings → Privacy & Security → API tokens
- Click New API token
- Give it a name (e.g., "Claude MCP")
- Select the required scopes:
Mail(read/write as needed) - Copy the generated token
Add the following to your Claude Code MCP settings (~/.claude/claude_desktop_config.json or project .mcp.json):
{
"mcpServers": {
"fastmail": {
"type": "url",
"url": "https://fastmail-mcp.i11v.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_FASTMAIL_API_TOKEN"
}
}
}
}Security Note: Keep your API token secure. Never commit it to version control. Consider using environment variables or a secrets manager.
Execute JMAP method calls against Fastmail. Accepts an array of JMAP method call triples [methodName, args, callId].
Input:
{
"methodCalls": [
["Email/query", {
"filter": { "inMailbox": "INBOX_ID" },
"sort": [{ "property": "receivedAt", "isAscending": false }],
"limit": 10
}, "call-0"],
["Email/get", {
"ids": { "resultOf": "call-0", "name": "Email/query", "path": "/ids" },
"properties": ["from", "subject", "receivedAt", "preview"]
}, "call-1"]
]
}What the server does:
- Validates structure, method names, and hygiene rules
- Injects
accountIdautomatically - Sends to Fastmail's JMAP API
- Strips protocol noise (
state,queryState,canCalculateChanges, etc.) - Returns cleaned
methodResponses
Allowed JMAP methods:
Core/echoMailbox/get,Mailbox/query,Mailbox/queryChanges,Mailbox/setEmail/get,Email/query,Email/queryChanges,Email/setThread/getSearchSnippet/getIdentity/getEmailSubmission/get,EmailSubmission/query,EmailSubmission/set
Validation rules:
- Every
/getcall (exceptMailbox/get,Identity/get) must include apropertiesarray - Every
/querycall must include alimit ids: nullon/getcalls is rejected (use/queryfirst)- Destructive operations (
destroy,EmailSubmission/set) return an error asking for user confirmation
Open an interactive email compose form. Optionally pre-fill fields (to, cc, bcc, subject, body). On hosts that support MCP Apps, renders an inline compose UI with send and save-draft buttons. Falls back to structured text on other hosts.
Input:
{
"to": "recipient@example.com",
"subject": "Hello",
"body": "Message text..."
}Display the full content of an email in a rich reader view. Fetches the email by JMAP ID and renders headers, sanitized body, and action buttons (reply, reply all, forward). Falls back to structured text on hosts without MCP Apps support.
Input:
{
"emailId": "M1234abcd"
}Resource-aware MCP clients automatically receive the Fastmail skill — a set of
markdown files teaching the LLM how to drive the execute JMAP tool. Clients
that support resource priority will load SKILL.md first and follow its links
lazily.
All resources use the file:///fastmail-skill/<path> URI scheme and
text/markdown mime type. Tagged audience: ["assistant"].
| URI | Priority | Purpose |
|---|---|---|
file:///fastmail-skill/SKILL.md |
1.0 | Entry point — JMAP methods, rules, UI tools |
file:///fastmail-skill/core/request-format.md |
0.5 | Method-call triples, back-references, callId |
file:///fastmail-skill/core/error-handling.md |
0.5 | JMAP error handling |
file:///fastmail-skill/email/querying.md |
0.5 | Email/query filters and sort |
file:///fastmail-skill/email/reading.md |
0.5 | Email/get body fetching |
file:///fastmail-skill/email/writing.md |
0.5 | Drafts, flags, move, delete |
file:///fastmail-skill/email/search.md |
0.5 | SearchSnippet/get highlights |
file:///fastmail-skill/mailbox/overview.md |
0.5 | Mailbox CRUD |
file:///fastmail-skill/patterns/unread-inbox.md |
0.5 | Show unread inbox |
file:///fastmail-skill/patterns/move-archive.md |
0.5 | Move / archive |
file:///fastmail-skill/patterns/reply.md |
0.5 | Reply pattern |
file:///fastmail-skill/sending/workflow.md |
0.5 | EmailSubmission/set workflow |
file:///fastmail-skill/thread/overview.md |
0.5 | Thread/get |
POST /mcp- MCP protocol endpointGET /health- Health check endpoint
Copy .env.example to .env.development.local and fill in the values:
cp .env.example .env.development.local| Variable | Required | Description |
|---|---|---|
HONEYCOMB_API_KEY |
No | Honeycomb ingest key for OpenTelemetry tracing |
HONEYCOMB_SERVER |
No | Honeycomb API server (default: https://api.honeycomb.io, EU: https://api.eu1.honeycomb.io) |
pnpm install # Install dependencies
pnpm dev # Run local dev server (wrangler)
pnpm check # Run all checks (typecheck + lint + fmt + test)
pnpm run deploy:prod # Deploy to CloudflareThis is an unofficial community project and is not affiliated with Fastmail.
Source code and issues: GitHub