WorkMail MCP Server
Enables Claude Desktop to securely access Amazon WorkMail email and calendar functionality through a local MCP server. Provides tools for reading, searching, and sending emails, as well as managing calendar events with built-in security protections.
README
WorkMail MCP Server
A Model Context Protocol (MCP) server that connects Claude Desktop to Amazon WorkMail, providing email and calendar access over a secure local stdio transport.
Features
| Tool | Description |
|---|---|
list_emails |
List emails from any folder with pagination |
read_email |
Read full email content by ID |
search_emails |
Search emails using AQS query syntax |
send_email |
Send an email (requires explicit confirmation) |
list_calendar_events |
List calendar events in a date range |
get_calendar_event |
Get full event details by ID |
create_calendar_event |
Create a calendar event (requires explicit confirmation) |
Security
- Credentials are stored in macOS Keychain (hardware-encrypted on Apple Silicon) — never in config files or environment variables
- Transport uses stdio (local pipe) — no HTTP server, no open ports
- Wire encryption via HTTPS/TLS to the WorkMail EWS endpoint
- Input validation on every tool call via Zod schemas
- Output sanitization redacts credential values from all responses and error messages
- Rate limiting prevents runaway request loops (configurable, default 30/min)
- Write protection —
send_emailandcreate_calendar_eventrequire aconfirm: trueparameter
Prerequisites
- macOS (uses Keychain for credential storage)
- Node.js 20+
- Amazon WorkMail account with username/password authentication
Setup
1. Install dependencies
git clone https://github.com/your-username/workmail-mcp-server.git
cd workmail-mcp-server
npm install
2. Configure environment
cp .env.example .env
Edit .env if your WorkMail is in a different region:
WORKMAIL_MCP_EWS_ENDPOINT=https://ews.mail.us-west-2.awsapps.com/EWS/Exchange.asmx
The EWS endpoint follows the pattern https://ews.mail.<region>.awsapps.com/EWS/Exchange.asmx. Common regions: us-east-1, us-west-2, eu-west-1.
3. Store credentials
npm run setup-credentials
This prompts for your WorkMail email and password, stores them in macOS Keychain, and validates the connection.
4. Build
npm run build
5. Register with Claude Desktop
Add the following to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"workmail": {
"command": "node",
"args": ["/absolute/path/to/workmail-mcp-server/dist/index.js"]
}
}
}
Restart Claude Desktop. The WorkMail server should appear as connected.
Configuration
All settings are optional and have sensible defaults. Set them in .env or as environment variables:
| Variable | Default | Description |
|---|---|---|
WORKMAIL_MCP_EWS_ENDPOINT |
https://ews.mail.us-west-2.awsapps.com/EWS/Exchange.asmx |
WorkMail EWS endpoint URL |
WORKMAIL_MCP_MAX_EMAILS |
25 |
Max emails returned per request (1-100) |
WORKMAIL_MCP_MAX_CALENDAR_DAYS |
30 |
Max calendar date range in days (1-90) |
WORKMAIL_MCP_RATE_LIMIT |
30 |
Max requests per minute (1-60) |
WORKMAIL_MCP_LOG_LEVEL |
info |
Log verbosity: error, warn, info, debug |
Environment variables set in claude_desktop_config.json take precedence over .env.
Usage
Once connected, ask Claude Desktop to interact with your WorkMail:
- "List my recent emails"
- "Read the email from Sarah about the Q3 report"
- "Search my inbox for messages about the deployment"
- "What meetings do I have this week?"
- "Send an email to team@example.com about the status update"
- "Create a meeting for tomorrow at 2pm with Alex"
Development
# Run directly from TypeScript (no build step)
npm run dev
# Rebuild after changes
npm run build
# Re-run credential setup
npm run setup-credentials
Logs are written to stderr in JSON format. To see them while running via Claude Desktop, check the MCP server logs in Claude Desktop's developer tools.
Architecture
Claude Desktop <──stdio──> MCP Server (Node.js)
│
▼
EWS Client Layer
│
▼
Amazon WorkMail (Exchange Web Services)
The server uses the EWS protocol at the Exchange2010_SP2 compatibility level, which is the version supported by Amazon WorkMail.
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.