Outlook MCP Server
A Model Context Protocol (MCP) server that provides access to Microsoft Outlook email functionality, allowing LLMs and other MCP clients to read, search, and manage emails through a standardized interface.
Features
- Folder Management: List available mail folders in your Outlook client
- Email Listing: Retrieve emails from specified time periods
- Email Search: Search emails by contact name, keywords, or phrases with OR operators
- Email Details: View complete email content, including attachments
- Email Composition: Create and send new emails
- Email Replies: Reply to existing emails
Prerequisites
- Windows operating system
- Python 3.11 or later
- Microsoft Outlook installed and configured with an active account
- Claude Desktop or another MCP-compatible client
Installation
- Clone or download this repository
- Install required dependencies:
pip install mcp>=1.2.0 pywin32>=305
- Configure Claude Desktop (or your preferred MCP client) to use this server
Usage
Configure your MCP client to start it automatically.
Add this to your MCP client config:
{
"mcpServers": {
"outlook": {
"isActive": true,
"name": "outlook",
"description": "Outlook Tools",
"command": "python",
"args": [
"${workspaceFolder}/outlook_mcp_server.py"
]
}
}
}
Available Tools
The server provides the following tools with detailed functionality:
-
list_folders:
- Lists all available mail folders in Outlook
- Shows folder hierarchy up to 3 levels deep
- Returns formatted list of folders and subfolders
-
list_recent_emails:
- Lists email titles from specified number of days (1-30)
- Can specify folder to search (defaults to Inbox)
- Caches results for detailed viewing
- Returns number of emails found and instructions to view them
-
search_emails:
- Searches emails by contact name or keyword
- Supports OR operators for multiple search terms
- Searches subject, sender name, and body content
- Returns number of matches and instructions to view them
-
view_email_cache:
- Views cached emails in pages of 5
- Shows email subject, sender, received time, and read status
- Provides navigation to next/previous pages
- Requires prior use of list_recent_emails or search_emails
-
get_email_by_number:
- Retrieves detailed content of a specific email
- Shows full email body, recipients, and attachments
- Requires email number from cached listing
- Provides option to reply to the email
-
reply_to_email_by_number:
- Replies to a specific email by its number
- Uses email number from cached listing
- Sends reply with specified text content
- Maintains original email thread
-
compose_email:
- Creates and sends a new email
- Supports recipient, subject, and body content
- Optional CC field for additional recipients
- Handles email sending through Outlook client
Example Workflow
- Use
list_folders
to see all available mail folders
- Use
list_recent_emails
to view recent emails (e.g., from last 7 days)
- Use
view_email_cache(page=1)
to browse through matching emails in pages of 1
- Use
get_email_by_number
to view a complete email
- Use
reply_to_email_by_number
to respond to an email
Examples
Listing Recent Emails
Could you show me my unread emails from the last 3 days?
Searching for Emails
Search for emails about "project update OR meeting notes" in the last week
Viewing Cached Emails
Show me page 2 of my cached emails
Reading Email Details
Show me the details of email #2 from the list
Replying to an Email
Reply to email #3 with: "Thanks for the information. I'll review this and get back to you tomorrow."
Composing a New Email
Send an email to john.doe@example.com with subject "Meeting Agenda" and body "Here's the agenda for our upcoming meeting..."
Troubleshooting
- Connection Issues: Ensure Outlook is running and properly configured
- Permission Errors: Make sure the script has permission to access Outlook
- Search Problems: For complex searches, try using OR operators between terms
- Email Access Errors: Check if the email ID is valid and accessible
- Server Crashes: Check Outlook's connection and stability
Security Considerations
This server has access to your Outlook email account and can read, send, and manage emails. Use it only with trusted MCP clients and in secure environments.
Limitations
- Currently supports text emails only (not HTML)
- Maximum email history is limited to 30 days
- Search capabilities depend on Outlook's built-in search functionality
- Only supports basic email functions (no calendar, contacts, etc.)