Skip to main content
Glama
i11v

Fastmail MCP Server

by i11v

Fastmail MCP Server (Unofficial)

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.

Setup Instructions

1. Get Your Fastmail API Token

  1. Log in to Fastmail

  2. Go to SettingsPrivacy & SecurityAPI tokens

  3. Click New API token

  4. Give it a name (e.g., "Claude MCP")

  5. Select the required scopes: Mail (read/write as needed)

  6. Copy the generated token

2. Configure Claude Code

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.

Available Tools

execute

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 accountId automatically

  • Sends to Fastmail's JMAP API

  • Strips protocol noise (state, queryState, canCalculateChanges, etc.)

  • Returns cleaned methodResponses

Allowed JMAP methods:

  • Core/echo

  • Mailbox/get, Mailbox/query, Mailbox/queryChanges, Mailbox/set

  • Email/get, Email/query, Email/queryChanges, Email/set

  • Thread/get

  • SearchSnippet/get

  • Identity/get

  • EmailSubmission/get, EmailSubmission/query, EmailSubmission/set

Validation rules:

  • Every /get call (except Mailbox/get, Identity/get) must include a properties array

  • Every /query call must include a limit

  • ids: null on /get calls is rejected (use /query first)

  • Destructive operations (destroy, EmailSubmission/set) return an error asking for user confirmation

compose_email (MCP App)

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..."
}

read_email (MCP App)

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"
}

Available Resources

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

API Endpoints

  • POST /mcp - MCP protocol endpoint

  • GET /health - Health check endpoint

Environment Variables

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)

Development

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 Cloudflare

This is an unofficial community project and is not affiliated with Fastmail.

Source code and issues: GitHub

A
license - permissive license
-
quality - not tested
-
maintenance - not tested

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Appeared in Searches

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/i11v/fastmail-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server