Proton MCP Server

Proton MCP Server

Enables full Proton Mail management through the Model Context Protocol by connecting to a local Proton Mail Bridge instance. It allows users to list, search, read, send, and organize emails using natural language commands.

Category
Visit Server

README

Proton MCP Server

A complete TypeScript Model Context Protocol (MCP) server for Proton Mail integration via Proton Mail Bridge.

What This Does

This MCP server provides full email management capabilities through Claude Code by connecting to Proton Mail Bridge running locally. It allows you to:

  • List and browse mailbox folders
  • List, search, and read emails
  • Send new emails and replies
  • Move and delete emails
  • Access full message content with attachments

Prerequisites

  1. Proton Mail Bridge running and accessible on localhost:
    • IMAP server on port 1143 (STARTTLS)
    • SMTP server on port 1025 (STARTTLS)
  2. Node.js 18 or higher
  3. A valid Proton Mail account with Bridge credentials

Setup

1. Install Dependencies

npm install

2. Configure Environment

Copy the environment template and add your Proton credentials:

cp .env.example .env

Edit .env with your settings:

PROTON_IMAP_HOST=127.0.0.1
PROTON_IMAP_PORT=1143
PROTON_SMTP_HOST=127.0.0.1
PROTON_SMTP_PORT=1025
PROTON_USER=your-proton-email@protonmail.com
PROTON_PASS=your-bridge-password

3. Build

npm run build

4. Run Locally (Development)

npm run dev

Or run the compiled version:

npm start

Usage with Claude Code

Add this MCP server to your Claude settings (~/.claude/settings.json):

{
  "mcpServers": {
    "proton": {
      "command": "node",
      "args": ["/path/to/proton-mcp-server/dist/index.js"],
      "env": {
        "PROTON_USER": "your-email@protonmail.com",
        "PROTON_PASS": "your-bridge-password",
        "PROTON_IMAP_HOST": "127.0.0.1",
        "PROTON_IMAP_PORT": "1143",
        "PROTON_SMTP_HOST": "127.0.0.1",
        "PROTON_SMTP_PORT": "1025"
      }
    }
  }
}

Or with TypeScript/tsx:

{
  "mcpServers": {
    "proton": {
      "command": "npx",
      "args": ["tsx", "/path/to/proton-mcp-server/src/index.ts"]
    }
  }
}

Available Tools

Reading Tools (Read-Only)

  • proton_list_folders — List all mailbox folders with message and unread counts
  • proton_list_emails — List emails in a folder with pagination (newest first)
  • proton_search_emails — Advanced search with filters (from, to, subject, date range, body content, unread status)
  • proton_read_email — Read the complete email content including headers, body, and attachment list

Writing Tools

  • proton_send_email — Send a new email (plain text or HTML)
  • proton_reply_email — Reply to an email with proper threading headers
  • proton_move_email — Move email to another folder
  • proton_delete_email — Delete email (move to Trash)

Project Structure

proton-mcp-server/
├── src/
│   ├── index.ts              # Main entry point
│   ├── constants.ts          # Configuration constants
│   ├── types.ts              # TypeScript interfaces
│   ├── schemas/
│   │   └── index.ts          # Zod input schemas
│   ├── services/
│   │   ├── imap.ts           # IMAP client wrapper
│   │   └── smtp.ts           # SMTP client wrapper
│   └── tools/
│       ├── folders.ts        # proton_list_folders
│       ├── list.ts           # proton_list_emails
│       ├── search.ts         # proton_search_emails
│       ├── read.ts           # proton_read_email
│       ├── send.ts           # proton_send_email
│       ├── reply.ts          # proton_reply_email
│       ├── move.ts           # proton_move_email
│       └── delete.ts         # proton_delete_email
├── package.json
├── tsconfig.json
├── .env.example
├── .gitignore
└── README.md (this file)

Implementation Notes

IMAP Connection

  • Uses imapflow library with STARTTLS on port 1143
  • Proton Bridge uses self-signed certificates, so tls.rejectUnauthorized: false
  • All connections are properly closed with logout() in finally blocks

SMTP Connection

  • Uses nodemailer with STARTTLS on port 1025
  • Supports plain text and HTML email bodies
  • Properly sets In-Reply-To and References headers for email threading

Message Parsing

  • Uses mailparser to extract full message content
  • Supports text, HTML, and attachment handling
  • Returns attachment metadata (filename, content type, size)

Pagination

  • Email list pagination uses offset and limit parameters
  • Results are always newest first
  • Search results also support pagination

Troubleshooting

Connection Issues

  • Ensure Proton Mail Bridge is running: protonmail-bridge --cli
  • Check localhost connectivity: telnet 127.0.0.1 1143 (IMAP) and 1025 (SMTP)
  • Verify credentials in .env file

Email Issues

  • Some email clients may not recognize replies without proper Message-ID headers
  • HTML emails are parsed to text; use the raw HTML body for better formatting
  • Large attachments may take time to process

Build Issues

  • Ensure Node.js 18+ is installed: node --version
  • Clear node_modules and reinstall: npm clean-install
  • Check TypeScript compilation: npm run build

Dependencies

  • @modelcontextprotocol/sdk — MCP protocol implementation
  • imapflow — IMAP client for email reading
  • nodemailer — SMTP client for sending emails
  • mailparser — Email parsing and content extraction
  • zod — Input validation schemas
  • dotenv — Environment variable loading

License

MIT

Support

For issues with Proton Mail Bridge, see: https://proton.me/support/bridge

For MCP protocol documentation, see: https://modelcontextprotocol.io

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured