eml-mcp

eml-mcp

MCP server for managing email archives as .eml files, synced with OneDrive, enabling AI assistants to read/write inbox, outbox, and drafts.

Category
Visit Server

README

eml-mcp

MCP server for managing email archives stored as .eml files. Designed to work alongside a pair of Power Automate flows that automatically export Outlook emails to OneDrive as .eml files, giving AI assistants full read and write access to your inbox, sent items, and drafts through a structured set of tools.

Requirements

  • Node.js 20+
  • A OneDrive folder (synced locally) — inbox/, outbox/, and drafts/ sub-directories are created automatically on first run

Installation

npx eml-mcp /path/to/emails --from=you@example.com

Add to your MCP client

<details> <summary>Claude Code</summary>

claude mcp add eml -- npx -y eml-mcp /path/to/emails --from=you@example.com

</details>

<details> <summary>GitHub Copilot</summary>

Add to ~/.copilot/mcp-config.json:

{
  "mcpServers": {
    "eml": {
      "type": "stdio",
      "command": "node",
      "args": ["/absolute/path/to/eml-mcp/dist/server.js", "/path/to/emails", "--from=you@example.com"]
    }
  }
}

</details>

<details> <summary>Codex CLI</summary>

Add to ~/.codex/config.toml:

[mcp_servers.eml]
command = "npx"
args = ["-y", "eml-mcp", "/path/to/emails", "--from=you@example.com"]

</details>

Arguments

Argument Required Description
<email-directory> Yes Root directory; inbox/, outbox/, and drafts/ sub-directories must exist inside
--db-path=<path> No SQLite index path (default: ~/.eml-mcp/index.db)
--from=<address> No From address for composed drafts (default: draft@eml-mcp)

Power Automate — Automatic .eml archiving

Each flow watches one Outlook folder and saves every email as an .eml file to the corresponding OneDrive directory. Set up the inbox flow first, then duplicate it for sent items — the only two values that change are noted in the second section.

<details> <summary>Inbox flow — archive received emails</summary>

Trigger

When a new email arrives (V3) — Office 365 Outlook

Set the folder to Inbox. Add subject/sender filters as needed.

Step 1 — Export email (V2)

Export email (V2) — Office 365 Outlook

  • Message Id: Message Id (dynamic value from trigger)

This action returns the raw MIME content of the email (RFC-2822 format, compatible with .eml).

Step 2 — Create file

Create file — OneDrive for Business

  • Folder Path: /Outlook/inbox
  • File Name: <Subject>-<Received Time>.eml — compose using dynamic values from the trigger, sanitizing characters not allowed in file names
  • File Content: Body (dynamic value from the Export email (V2) step)

The file is created in OneDrive and, on next refresh_index call or server restart, it will be picked up automatically by eml-mcp tagged as inbox.

</details>

<details> <summary>Sent Items flow — archive sent emails</summary>

Duplicate the inbox flow and change only two values:

  • Trigger folder: Sent Items
  • Folder Path (Create file step): /Outlook/outbox

eml-mcp will tag these emails as outbox.

</details>


Tools

Tool Description
search_emails Full-text search with filters (from, date, attachments, folder…)
get_email Parse and return a single email
compose_email Create a new draft .eml and open it
update_email Modify an existing draft and re-open it
open_email Open an existing .eml in the default mail client (works for inbox, outbox, and drafts)
delete_email Permanently delete an .eml file and remove it from the index
extract_attachments Save one or all attachments from an email to a directory
open_attachment Open an attachment with the system default application
search_attachments Find emails containing attachments by filename, type, or keyword
refresh_index Incrementally sync the index with disk state (add new, remove deleted, update changed)

Development build

npm install
npm run build

Register the local build in Claude Code:

claude mcp add eml node "/absolute/path/to/eml-mcp/dist/server.js" -- "/path/to/emails" --from=you@example.com

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