Skip to main content

MCP server giving AI assistants full access to Apple Mail - read, search, compose, organize & analyze emails

Project description

Apple Mail MCP Server

License: MIT PyPI Python 3.10+ MCP GitHub stars

Star History

Star History Chart

An MCP server that gives AI assistants full access to Apple Mail -- read, search, compose, organize, and analyze emails via natural language. Built with FastMCP.

Quick Install

Prerequisites: macOS with Apple Mail configured, Python 3.10+

Claude Code Plugin (Recommended)

Two commands — gets you the MCP server, /email-management slash command, and the Email Management Expert skill:

claude plugin marketplace add patrickfreyer/apple-mail-mcp
claude plugin install apple-mail@apple-mail-mcp

Then restart Claude Code.

Other Install Methods

uvx (zero install, MCP server only)
claude mcp add apple-mail -- uvx mcp-apple-mail

Or for Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "apple-mail": {
      "command": "uvx",
      "args": ["mcp-apple-mail"]
    }
  }
}
pip install (MCP server only)
pip install mcp-apple-mail
claude mcp add apple-mail -- mcp-apple-mail
Claude Desktop MCPB
  1. Download the latest apple-mail-mcp-vX.Y.Z.mcpb from Releases
  2. Open Claude Desktop → Settings → Developer → MCP Servers → Install from file
  3. Select the .mcpb file and grant Mail.app permissions
Manual setup
git clone https://github.com/patrickfreyer/apple-mail-mcp.git
cd apple-mail-mcp/plugin
python3 -m venv venv
venv/bin/pip install -r requirements.txt

claude mcp add apple-mail -- /bin/bash $(pwd)/start_mcp.sh

Tools (22)

Reading & Search

Tool Description
get_inbox_overview Dashboard with unread counts, folders, and recent emails
list_inbox_emails List emails with account/read-status filtering and optional content preview
get_mailbox_unread_counts Unread counts per mailbox or per-account summary
list_accounts List all configured Mail accounts
search_emails Unified search — subject, sender, body text, dates, attachments, cross-account
get_email_thread Conversation thread view

Organization

Tool Description
list_mailboxes Folder hierarchy with message counts
create_mailbox Create new mailboxes (supports nested paths)
move_email Move/archive emails with filters (subject, sender, date, read status, dry-run)
update_email_status Mark read/unread, flag/unflag — by filters or message IDs
manage_trash Soft delete, permanent delete, empty trash (with dry-run)

Composition

Tool Description
compose_email Send new emails (plain text or HTML body)
reply_to_email Reply or reply-all with optional HTML body
forward_email Forward with optional message, CC/BCC
manage_drafts Create, list, send, and delete drafts
create_rich_email_draft Build a rich HTML .eml draft, open it in Mail, and optionally save it to Drafts

Attachments

Tool Description
list_email_attachments List attachments with names and sizes
save_email_attachment Save attachments to disk

Smart Inbox

Tool Description
get_awaiting_reply Find sent emails that haven't received a reply
get_needs_response Identify emails that likely need your response
get_top_senders Analyse most frequent senders by count or domain

Analytics & Export

Tool Description
get_statistics Email analytics (volume, top senders, read ratios)
export_emails Export single emails or mailboxes to TXT/HTML
inbox_dashboard Interactive UI dashboard (requires mcp-ui-server)

Configuration

Read-Only Mode

Pass --read-only to disable tools that send email (compose_email, reply_to_email, forward_email). Draft management remains available (list, create, delete) but sending a draft via manage_drafts is blocked.

{
  "mcpServers": {
    "apple-mail": {
      "command": "/path/to/venv/bin/python3",
      "args": ["/path/to/apple_mail_mcp.py", "--read-only"]
    }
  }
}

User Preferences (Optional)

Set the USER_EMAIL_PREFERENCES environment variable to give the assistant context about your workflow:

{
  "mcpServers": {
    "apple-mail": {
      "command": "/path/to/venv/bin/python3",
      "args": ["/path/to/apple_mail_mcp.py"],
      "env": {
        "USER_EMAIL_PREFERENCES": "Default to BCG account, show max 50 emails, prefer Archive and Projects folders"
      }
    }
  }
}

For .mcpb installs, configure this in Claude Desktop under Developer > MCP Servers > Apple Mail MCP.

Safety Limits

Batch operations have conservative defaults to prevent accidental bulk actions:

Operation Default Limit
update_email_status 10 emails
manage_trash 5 emails
move_email 1 email

Override via function parameters when needed.

Usage Examples

Show me an overview of my inbox
Search for emails about "project update" in my Gmail
Reply to the email about "Domain name" with "Thanks for the update!"
Move emails with "invoice" in the subject to my Archive folder
Show me email statistics for the last 30 days
Create a rich HTML draft for a weekly update and open it in Mail

Rich HTML Drafts

Use create_rich_email_draft when you need a visually formatted email, newsletter, or leadership update.

  • It generates an unsent .eml file with multipart plain-text + HTML bodies
  • It can open the draft directly in Mail for editing
  • It can optionally ask Mail to save the opened compose window into Drafts
  • It accepts partial details, so you can start with just an account and subject and fill in the rest later

This is more reliable than injecting raw HTML into AppleScript content, which Mail often stores as literal markup.

Email Management Skill

A companion Claude Code Skill is included that teaches Claude expert email workflows (Inbox Zero, daily triage, folder organization). When installed as a plugin, the skill is loaded automatically. For standalone MCP installs, copy it manually:

cp -r plugin/skills/email-management ~/.claude/skills/email-management

Requirements

  • macOS with Apple Mail configured
  • Python 3.7+
  • fastmcp (+ optional mcp-ui-server for dashboard)
  • Claude Desktop or any MCP-compatible client
  • Mail.app permissions: Automation + Mail Data Access (grant in System Settings > Privacy & Security > Automation)

Troubleshooting

Issue Fix
Mail.app not responding Ensure Mail.app is running; check Automation permissions in System Settings
Slow searches Set include_content: false and lower max_results
Mailbox not found Use exact folder names; nested folders use / separator (e.g., Projects/Alpha)
Permission errors Grant access in System Settings > Privacy & Security > Automation
Rich draft shows raw HTML Use create_rich_email_draft instead of pasting HTML into manage_drafts or AppleScript content

Project Structure

apple-mail-mcp/
├── .claude-plugin/
│   └── marketplace.json       # Marketplace manifest (for plugin distribution)
├── plugin/                    # Claude Code plugin
│   ├── .claude-plugin/
│   │   └── plugin.json        # Plugin manifest
│   ├── commands/              # /email-management slash command
│   ├── skills/                # Email Management Expert skill
│   ├── apple_mail_mcp/        # Python MCP server package (24 tools)
│   ├── apple_mail_mcp.py      # Entry point
│   ├── start_mcp.sh           # Startup wrapper (auto-creates venv)
│   └── requirements.txt
├── apple-mail-mcpb/           # MCPB build files (Claude Desktop)
├── LICENSE
└── README.md

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/my-feature)
  3. Commit and push
  4. Open a Pull Request

Releasing

Follow these steps when cutting a new release to keep all version strings in sync:

  1. Bump __version__ in plugin/apple_mail_mcp/__init__.py to the new version.
  2. Update apple-mail-mcpb/manifest.json ("version" field) to match.
  3. Update pyproject.toml (version = ... under [project]) to match.
  4. Update both version fields in server.json ("version" and "packages"[0]["version"]) to match.
  5. Run python3 scripts/check_versions.py — it must print OK before you proceed.
  6. Commit, tag, and push: git tag vX.Y.Z && git push origin vX.Y.Z.
  7. Create a GitHub release from the tag.
  8. Build and publish to PyPI: python -m build && twine upload dist/* (requires PyPI credentials).

The test suite also enforces version consistency (tests/test_version_consistency.py), so any CI run on a branch with mismatched versions will fail fast.

License

MIT -- see LICENSE.

Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_apple_mail-3.1.7.tar.gz (52.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_apple_mail-3.1.7-py3-none-any.whl (59.7 kB view details)

Uploaded Python 3

File details

Details for the file mcp_apple_mail-3.1.7.tar.gz.

File metadata

  • Download URL: mcp_apple_mail-3.1.7.tar.gz
  • Upload date:
  • Size: 52.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mcp_apple_mail-3.1.7.tar.gz
Algorithm Hash digest
SHA256 2a762d95cf483c647b01506dc51aa7aa6d7110421d83607248ebcf3dbec05246
MD5 d333d85bc833bb97d7eae768b44b4c6e
BLAKE2b-256 4342478d18df19b4141fa98ace9ff06dc49937ec1a29f1b6be78ce4b8f7ad291

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_apple_mail-3.1.7.tar.gz:

Publisher: release.yml on patrickfreyer/apple-mail-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_apple_mail-3.1.7-py3-none-any.whl.

File metadata

  • Download URL: mcp_apple_mail-3.1.7-py3-none-any.whl
  • Upload date:
  • Size: 59.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mcp_apple_mail-3.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 963b5bc79e713cec4090647e1e831bdffbb69c2a8b2bb64b8e9769d01d73b959
MD5 edd752224515602553d8e0c690176898
BLAKE2b-256 f38d83d1bc1ba5fcbde451856f7d4b4dc8caf1f91a73cf87f4ca5ce61cea9b8c

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_apple_mail-3.1.7-py3-none-any.whl:

Publisher: release.yml on patrickfreyer/apple-mail-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page