@aiwerk/mcp-server-imap
v1.2.0
Published
IMAP/SMTP MCP server for listing, reading, searching and sending email
Readme
@aiwerk/mcp-server-imap
IMAP/SMTP MCP server that works with any email provider. Set host, user, pass — done.
Unlike Gmail-only or Outlook-only MCP servers, this one speaks standard IMAP/SMTP — so it works with every email provider out of the box.
Why this server?
Most email MCP servers only work with one provider (Gmail, Outlook). This one works with any provider that supports IMAP:
- Gmail, Outlook, Yahoo — yes
- Fastmail, ProtonMail Bridge, Zoho — yes
- Self-hosted (Dovecot, Postfix, hMailServer) — yes
- Corporate/hosted (Hostpoint, Infomaniak, OVH) — yes
One server, every mailbox.
Highlights
- Universal — standard IMAP/SMTP, works everywhere
- Simple setup — just
IMAP_HOST,IMAP_USER,IMAP_PASSand you're connected - Safety first — email sending is disabled by default (
SMTP_SEND_ENABLED=false). Your AI agent can read emails but can't send anything until you explicitly opt in - Lazy credentials — the server starts and exposes its tool list without requiring credentials. Auth is only needed when a tool is actually called
- Real MIME parsing — handles multipart, HTML/text, attachments, reply threading
Ad-hoc one-email CLI
Note: On the AIWerk hosted bridge, the
email_sendandemail_replyMCP tools are disabled to protect the platform's SMTP reputation. Use any of the three paths below to send email locally.
Need to send a single email from the command line — for example, to deliver a draft your AI agent composed? Use aiwerk-send-email:
SMTP_HOST=smtp.gmail.com \
SMTP_PORT=587 \
[email protected] \
SMTP_PASS='app-password' \
SMTP_FROM='Me <[email protected]>' \
npx -y @aiwerk/mcp-server-imap aiwerk-send-email \
--to "[email protected]" \
--subject "Re: invoice" \
--body "Got it, will pay Monday."On success, exits 0 and prints JSON: {"ok":true,"messageId":"...","envelope":{...}}
On failure, exits 1 with the error on stderr. Credentials are never printed.
All CLI arguments
| Argument | Required | Description |
|---|---|---|
| --to | Yes | Recipient(s), comma-separated |
| --subject | Yes | Subject line |
| --body | One of body/html | Plain-text body |
| --html | One of body/html | HTML body (both → multipart) |
| --in-reply-to | No | Message-ID of original message (thread preservation) |
| --references | No | Space-separated reference IDs |
| --cc | No | CC recipients, comma-separated |
| --bcc | No | BCC recipients, comma-separated |
CLI environment variables
| Variable | Required | Default | Description |
|---|---|---|---|
| SMTP_HOST | Yes | — | SMTP server hostname |
| SMTP_PORT | Yes | — | 587 for STARTTLS, 465 for implicit TLS |
| SMTP_USER | Yes | — | SMTP username / email address |
| SMTP_PASS | Yes | — | Password or app-specific password |
| SMTP_FROM | Yes | — | Sender address (Name <email> or plain email) |
| SMTP_TLS | No | false | true for implicit TLS (port 465); false for STARTTLS (port 587) |
Install
Three ways to get email tools — pick the one that fits.
1. Quick (single email) — aiwerk-send-email CLI above: no MCP client needed, one command sends one email.
2. Direct stdio MCP server — all 10 email tools exposed to your AI agent:
npx -y @aiwerk/mcp-server-imap3. Local bridge with catalog UX — install via the AIWerk catalog for a guided setup:
npx -y @aiwerk/mcp-bridge install imap-email --catalog bridge.aiwerk.chOption 1 — Hosted (zero setup)
No local runtime, no env vars on your machine — credentials are AES-256-GCM encrypted server-side via HashiCorp Vault.
- Sign up at aiwerkmcp.com.
- Install IMAP Email from the catalog and paste your IMAP/SMTP credentials.
- Point your MCP client (Claude.ai, Cursor, Hermes, …) at your hosted endpoint:
with your Bearer token.https://bridge.aiwerk.ch/u/<your-user-id>/mcp
All 10 tools appear immediately. Install other AIWerk recipes from the same bridge.
Option 2 — Self-hosted (npx)
Run directly — you manage the credentials:
IMAP_HOST="imap.example.com" \
IMAP_USER="[email protected]" \
IMAP_PASS="app-password" \
SMTP_HOST="smtp.example.com" \
npx @aiwerk/mcp-server-imapThe server starts immediately and responds to tools/list even without credentials — they're only required when a tool is actually called (lazy credentials).
Tools (10)
| Tool | Purpose |
|---|---|
| email_list | List emails from a folder |
| email_read | Read a single message with full body |
| email_search | Search by from/to/subject/date/unread |
| email_folders | List all folders with message counts |
| email_move | Move messages between folders |
| email_flag | Set read/star/flag status |
| email_delete | Move messages to Trash |
| email_send | Send a new email (requires opt-in) |
| email_reply | Reply to a message (requires opt-in) |
| email_attachment | List or download attachments |
Configuration
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"email": {
"command": "npx",
"args": ["-y", "@aiwerk/mcp-server-imap"],
"env": {
"IMAP_HOST": "imap.example.com",
"IMAP_USER": "[email protected]",
"IMAP_PASS": "your-app-password",
"SMTP_HOST": "smtp.example.com"
}
}
}
}Cursor / Windsurf / VS Code
Same config format in the respective MCP settings.
AIWerk hosted bridge
If you want zero-setup, install via aiwerkmcp.com — see Option 1 above.
Environment variables
IMAP (required)
| Variable | Default | Description |
|---|---|---|
| IMAP_HOST | — | IMAP server hostname |
| IMAP_USER | — | Email address or username |
| IMAP_PASS | — | Password or app-specific password |
| IMAP_PORT | 993 | IMAP port |
| IMAP_TLS | true | Use TLS |
| IMAP_TIMEOUT | 30000 | Connection timeout (ms) |
SMTP (optional, for sending)
| Variable | Default | Description |
|---|---|---|
| SMTP_HOST | ${IMAP_HOST} | SMTP server hostname |
| SMTP_PORT | 465 | SMTP port |
| SMTP_USER | ${IMAP_USER} | SMTP username |
| SMTP_PASS | ${IMAP_PASS} | SMTP password |
| SMTP_TLS | true | Use TLS |
| SMTP_FROM | ${IMAP_USER} | Sender address |
| SMTP_SEND_ENABLED | false | Must be true to enable sending |
Debug
| Variable | Default | Description |
|---|---|---|
| IMAP_DEBUG | false | Verbose IMAP protocol logging |
Security
- Email sending is disabled by default — set
SMTP_SEND_ENABLED=trueto enable - Credentials are loaded lazily (only when a tool is called, not at startup)
- No credentials are logged
- Keep credentials in
.envor a secret manager — never commit them to git
Supported providers
Tested with: Hostpoint, Gmail (app password), Outlook/Microsoft 365, Yahoo Mail, Fastmail, Dovecot, Postfix.
Works with any standards-compliant IMAP/SMTP server.
Build from source
git clone https://github.com/AIWerk/mcp-server-imap
cd mcp-server-imap
npm install
npm run build
node dist/server.jsContributing
Issues and PRs are welcome! Please open an issue first for larger changes.
Changelog
See CHANGELOG.md for version history.
About AIWerk MCP
Part of the AIWerk MCP platform — curated, signed MCP recipes served either as npm packages for self-hosting or through our multi-tenant hosted bridge (bridge.aiwerk.ch).
Other AIWerk MCP servers:
- @aiwerk/mcp-server-cal — Cal.com scheduling
- @aiwerk/mcp-server-wise — Wise (TransferWise) Personal API, read-only
- @aiwerk/mcp-server-clawhub — ClawHub skill catalog
Browse the full catalog (20+ recipes including GitHub, Linear, Notion, Stripe, …) at aiwerkmcp.com.
License
MIT — AIWerk
