Outlook Mcp
v1.5.2Production-grade MCP server for personal Outlook (Outlook.com / Hotmail / Live). 54 typed Graph tools across mail, calendar, contacts, to-do, drafts, attachm...
outlook-mcp
MCP server for Microsoft Outlook personal accounts (Outlook.com, Hotmail, Live). Provides AI agents with full access to mail, calendar, contacts, and tasks via Microsoft Graph API.
Independent open-source project. Not affiliated with Microsoft.
Important
- Personal Microsoft accounts only (
@outlook.com,@hotmail.com,@live.com). Work/school accounts (Entra ID) are not supported in v1. - Requires Azure AD app registration — free, takes ~5 minutes, but you need a free Azure account first. See README.
- Auth is CLI-based — run
outlook-mcp authon the host before the agent can use it. No interactive auth through MCP tools.
Setup
- Create a free Azure account at azure.microsoft.com/free (sign up with your
@outlook.comaddress) - Register an Azure AD app (see README for step-by-step)
- Configure: Create
~/.outlook-mcp/config.json:{ "client_id": "YOUR-APP-CLIENT-ID", "tenant_id": "consumers", "timezone": "America/Los_Angeles", "read_only": true } - Register with OpenClaw (writes to
mcp.serversin~/.openclaw/openclaw.json):openclaw mcp set outlook '{"command":"uv","args":["--directory","/path/to/outlook-mcp","run","outlook-mcp"]}' openclaw mcp list # verify - Authenticate on the host:
cd /path/to/outlook-mcp && uv run outlook-mcp auth - Restart the gateway:
openclaw gateway restart
Tools (54)
Auth
outlook_auth_status— Check authentication status and read-only mode
Mail — Read
outlook_list_inbox— List messages with filters (folder, unread, sender, date)outlook_read_message— Get full message by IDoutlook_search_mail— Search mail using KQL queryoutlook_list_folders— List all mail folders
Mail — Write
outlook_send_message— Send email with recipients, CC, BCC, HTML, importanceoutlook_reply— Reply or reply-all to a messageoutlook_forward— Forward a message
Mail — Triage
outlook_move_message— Move to a folderoutlook_delete_message— Delete (soft by default, permanent optional)outlook_flag_message— Set follow-up flagoutlook_categorize_message— Set categoriesoutlook_mark_read— Mark read or unreadoutlook_reclassify_message— Move between Focused Inbox and Other
Calendar
outlook_list_events— List events in date range (expands recurring)outlook_get_event— Get event detailsoutlook_create_event— Create event with attendees, recurrence, online meetingoutlook_update_event— Update event fieldsoutlook_delete_event— Delete eventoutlook_rsvp— Accept, decline, or tentatively accept
Contacts
outlook_list_contacts— List with cursor paginationoutlook_search_contacts— Search by name or emailoutlook_get_contact— Get full detailsoutlook_create_contact— Createoutlook_update_contact— Updateoutlook_delete_contact— Delete
To Do
outlook_list_task_lists— List To Do listsoutlook_list_tasks— List tasks with status filter and paginationoutlook_create_task— Create with due date, importance, recurrenceoutlook_update_task— Updateoutlook_complete_task— Mark completedoutlook_delete_task— Delete
Drafts
outlook_list_drafts— List with paginationoutlook_create_draft— Create for later reviewoutlook_update_draft— Updateoutlook_send_draft— Sendoutlook_delete_draft— Delete
Attachments
outlook_list_attachments— List on a messageoutlook_download_attachment— Download (base64 or save to file)outlook_send_with_attachments— Send with files (auto upload session for >3MB)outlook_attach_to_draft— Add attachments to an existing draft (auto upload session for >3MB)outlook_remove_draft_attachment— Remove a single attachment from a draft
Folder Management
outlook_create_folder— Create (top-level or nested)outlook_rename_folder— Renameoutlook_delete_folder— Delete (refuses well-known folders)
Threading and Batch
outlook_list_thread— Get all messages in a conversationoutlook_copy_message— Copy to another folderoutlook_batch_triage— Batch move/flag/categorize/mark_read (max 20)
User and Admin
outlook_whoami— Current user profileoutlook_list_calendars— Available calendarsoutlook_list_categories— Category definitions with colorsoutlook_get_mail_tips— Pre-send check (OOF, delivery restrictions)outlook_list_accounts— Configured accountsoutlook_switch_account— Switch active account
Privacy
- Zero telemetry, zero local caching
- Only connects to
login.microsoftonline.comandgraph.microsoft.com - Tokens stored in OS keyring (macOS Keychain, Windows Credential Store)
- BYOID: you register your own Azure AD app — no shared client ID
Notes
- IDs are opaque Graph strings — get them from list/search tools, never guess
- Dates are ISO 8601, UTC in responses, config timezone for input interpretation
- Mail search uses KQL syntax
- Start with
read_only: true, flip when comfortable - Granular permissions: For finer control, set
allow_categoriesin config (e.g.,["calendar_write"]to allow only calendar writes). See README for the 7 categories and example policies.
Version tags
latest
Runtime requirements
📬 Clawdis
