outlook-automation
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
ChineseOutlook Automation via Rube MCP
通过Rube MCP实现Outlook自动化
Automate Microsoft Outlook operations through Composio's Outlook toolkit via Rube MCP.
通过Composio的Outlook工具包,借助Rube MCP自动化Microsoft Outlook操作。
Prerequisites
前提条件
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Outlook connection via with toolkit
RUBE_MANAGE_CONNECTIONSoutlook - Always call first to get current tool schemas
RUBE_SEARCH_TOOLS
- 必须已连接Rube MCP(需具备RUBE_SEARCH_TOOLS权限)
- 通过并使用
RUBE_MANAGE_CONNECTIONS工具包激活Outlook连接outlook - 请始终先调用获取最新的工具架构
RUBE_SEARCH_TOOLS
Setup
设置步骤
Get Rube MCP: Add as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
https://rube.app/mcp- Verify Rube MCP is available by confirming responds
RUBE_SEARCH_TOOLS - Call with toolkit
RUBE_MANAGE_CONNECTIONSoutlook - If connection is not ACTIVE, follow the returned auth link to complete Microsoft OAuth
- Confirm connection status shows ACTIVE before running any workflows
获取Rube MCP:在客户端配置中添加作为MCP服务器。无需API密钥 —— 只需添加端点即可使用。
https://rube.app/mcp- 确认能正常响应,以此验证Rube MCP是否可用
RUBE_SEARCH_TOOLS - 调用并指定工具包为
RUBE_MANAGE_CONNECTIONSoutlook - 如果连接状态未显示为ACTIVE,请按照返回的授权链接完成Microsoft OAuth认证
- 在运行任何工作流之前,确认连接状态显示为ACTIVE
Core Workflows
核心工作流
1. Search and Filter Emails
1. 搜索和筛选邮件
When to use: User wants to find specific emails across their mailbox
Tool sequence:
- - Search with KQL syntax across all folders [Required]
OUTLOOK_SEARCH_MESSAGES - - Get full message details [Optional]
OUTLOOK_GET_MESSAGE - - List message attachments [Optional]
OUTLOOK_LIST_OUTLOOK_ATTACHMENTS - - Download attachment [Optional]
OUTLOOK_DOWNLOAD_OUTLOOK_ATTACHMENT
Key parameters:
- : KQL search string (from:, to:, subject:, received:, hasattachment:)
query - : Pagination start (0-based)
from_index - : Results per page (max 25)
size - : Message ID (use hitId from search results)
message_id
Pitfalls:
- Only works with Microsoft 365/Enterprise accounts (not @hotmail.com/@outlook.com)
- Pagination relies on hitsContainers[0].moreResultsAvailable; stop only when false
- Use hitId from search results as message_id for downstream calls, not resource.id
- Index latency: very recent emails may not appear immediately
- Inline images appear as attachments; filter by mimetype for real documents
适用场景:用户需要在邮箱中查找特定邮件
工具执行顺序:
- - 使用KQL语法在所有文件夹中搜索 [必填]
OUTLOOK_SEARCH_MESSAGES - - 获取完整邮件详情 [可选]
OUTLOOK_GET_MESSAGE - - 列出邮件附件 [可选]
OUTLOOK_LIST_OUTLOOK_ATTACHMENTS - - 下载附件 [可选]
OUTLOOK_DOWNLOAD_OUTLOOK_ATTACHMENT
关键参数:
- : KQL搜索字符串(支持from:、to:、subject:、received:、hasattachment:等字段)
query - : 分页起始位置(从0开始)
from_index - : 每页结果数量(最大25条)
size - : 邮件ID(使用搜索结果中的hitId)
message_id
注意事项:
- 仅适用于Microsoft 365/企业账户(不支持@hotmail.com/@outlook.com个人账户)
- 分页需依赖hitsContainers[0].moreResultsAvailable字段;仅当该字段为false时停止分页
- 后续调用请使用搜索结果中的hitId作为message_id,而非resource.id
- 索引延迟:最新邮件可能不会立即出现在搜索结果中
- 内嵌图片会被视为附件;可通过mimetype筛选真实文档
2. Query Emails in a Folder
2. 查询指定文件夹中的邮件
When to use: User wants to list emails in a specific folder with OData filters
Tool sequence:
- - List mail folders to get folder IDs [Prerequisite]
OUTLOOK_LIST_MAIL_FOLDERS - - Query emails with structured filters [Required]
OUTLOOK_QUERY_EMAILS
Key parameters:
- : Folder name ('inbox', 'sentitems', 'drafts') or folder ID
folder - : OData filter (e.g.,
filter)isRead eq false and importance eq 'high' - : Max results (1-1000)
top - : Sort field and direction
orderby - : Array of fields to return
select
Pitfalls:
- QUERY_EMAILS searches a SINGLE folder only; use SEARCH_MESSAGES for cross-folder search
- Custom folders require folder IDs, not display names; use LIST_MAIL_FOLDERS
- Always check response['@odata.nextLink'] for pagination
- Cannot filter by recipient or body content; use SEARCH_MESSAGES for that
适用场景:用户需要使用OData筛选器列出特定文件夹中的邮件
工具执行顺序:
- - 列出邮件文件夹以获取文件夹ID [前置步骤]
OUTLOOK_LIST_MAIL_FOLDERS - - 使用结构化筛选器查询邮件 [必填]
OUTLOOK_QUERY_EMAILS
关键参数:
- : 文件夹名称(如'inbox'、'sentitems'、'drafts')或文件夹ID
folder - : OData筛选器(例如
filter)isRead eq false and importance eq 'high' - : 最大结果数量(1-1000)
top - : 排序字段及方向
orderby - : 需返回的字段数组
select
注意事项:
- QUERY_EMAILS仅搜索单个文件夹;跨文件夹搜索请使用SEARCH_MESSAGES
- 自定义文件夹需使用文件夹ID而非显示名称;请使用LIST_MAIL_FOLDERS获取ID
- 请始终检查response['@odata.nextLink']以处理分页
- 无法按收件人或邮件正文内容筛选;此类需求请使用SEARCH_MESSAGES
3. Manage Calendar Events
3. 管理日历事件
When to use: User wants to list, search, or inspect calendar events
Tool sequence:
- - List events with filters [Optional]
OUTLOOK_LIST_EVENTS - - Get events in a time window [Optional]
OUTLOOK_GET_CALENDAR_VIEW - - Get specific event details [Optional]
OUTLOOK_GET_EVENT - - List available calendars [Optional]
OUTLOOK_LIST_CALENDARS - - Get free/busy info [Optional]
OUTLOOK_GET_SCHEDULE
Key parameters:
- : OData filter (use start/dateTime, NOT receivedDateTime)
filter - /
start_datetime: ISO 8601 for calendar viewend_datetime - : IANA timezone (e.g., 'America/New_York')
timezone - : Optional non-primary calendar ID
calendar_id - : Fields to return
select
Pitfalls:
- Use calendar event properties only (start/dateTime, end/dateTime), NOT email properties (receivedDateTime)
- Calendar view requires start_datetime and end_datetime
- Recurring events need to see individual occurrences
expand_recurring_events=true - Decline status is per-attendee via attendees[].status.response
适用场景:用户需要列出、搜索或查看日历事件
工具执行顺序:
- - 使用筛选器列出事件 [可选]
OUTLOOK_LIST_EVENTS - - 获取指定时间范围内的事件 [可选]
OUTLOOK_GET_CALENDAR_VIEW - - 获取特定事件的详情 [可选]
OUTLOOK_GET_EVENT - - 列出可用日历 [可选]
OUTLOOK_LIST_CALENDARS - - 获取忙闲信息 [可选]
OUTLOOK_GET_SCHEDULE
关键参数:
- : OData筛选器(使用start/dateTime,而非receivedDateTime)
filter - /
start_datetime: 日历视图的ISO 8601格式时间end_datetime - : IANA时区(例如'America/New_York')
timezone - : 可选的非主日历ID
calendar_id - : 需返回的字段
select
注意事项:
- 仅使用日历事件属性(start/dateTime、end/dateTime),请勿使用邮件属性(receivedDateTime)
- 日历视图必须指定start_datetime和end_datetime
- 如需查看 recurring events的单个实例,需设置
expand_recurring_events=true - 拒绝状态需通过attendees[].status.response查看每个参会人的状态
4. Manage Contacts
4. 管理联系人
When to use: User wants to list, create, or organize contacts
Tool sequence:
- - List contacts [Optional]
OUTLOOK_LIST_CONTACTS - - Create a new contact [Optional]
OUTLOOK_CREATE_CONTACT - - List contact folders [Optional]
OUTLOOK_GET_CONTACT_FOLDERS - - Create contact folder [Optional]
OUTLOOK_CREATE_CONTACT_FOLDER
Key parameters:
- /
givenName: Contact namesurname - : Array of email objects
emailAddresses - : Full display name
displayName - : Optional folder for contacts
contact_folder_id
Pitfalls:
- Contact creation supports many fields but only givenName or surname is needed
适用场景:用户需要列出、创建或整理联系人
工具执行顺序:
- - 列出联系人 [可选]
OUTLOOK_LIST_CONTACTS - - 创建新联系人 [可选]
OUTLOOK_CREATE_CONTACT - - 列出联系人文件夹 [可选]
OUTLOOK_GET_CONTACT_FOLDERS - - 创建联系人文件夹 [可选]
OUTLOOK_CREATE_CONTACT_FOLDER
关键参数:
- /
givenName: 联系人姓名surname - : 邮箱对象数组
emailAddresses - : 完整显示名称
displayName - : 可选的联系人存储文件夹ID
contact_folder_id
注意事项:
- 创建联系人支持多个字段,但仅需提供givenName或surname即可
5. Manage Mail Folders
5. 管理邮件文件夹
When to use: User wants to organize mail folders
Tool sequence:
- - List top-level folders [Required]
OUTLOOK_LIST_MAIL_FOLDERS - - List subfolders [Optional]
OUTLOOK_LIST_CHILD_MAIL_FOLDERS - - Create a new folder [Optional]
OUTLOOK_CREATE_MAIL_FOLDER
Key parameters:
- : Well-known name or folder ID
parent_folder_id - : New folder name
displayName - : Show hidden folders
include_hidden_folders
Pitfalls:
- Well-known folder names: 'inbox', 'sentitems', 'drafts', 'deleteditems', 'junkemail', 'archive'
- Custom folder operations require the folder ID, not display name
适用场景:用户需要整理邮件文件夹
工具执行顺序:
- - 列出顶级文件夹 [必填]
OUTLOOK_LIST_MAIL_FOLDERS - - 列出子文件夹 [可选]
OUTLOOK_LIST_CHILD_MAIL_FOLDERS - - 创建新文件夹 [可选]
OUTLOOK_CREATE_MAIL_FOLDER
关键参数:
- : 知名文件夹名称或文件夹ID
parent_folder_id - : 新文件夹名称
displayName - : 是否显示隐藏文件夹
include_hidden_folders
注意事项:
- 知名文件夹名称包括:'inbox'、'sentitems'、'drafts'、'deleteditems'、'junkemail'、'archive'
- 自定义文件夹操作需使用文件夹ID,而非显示名称
Common Patterns
通用模式
KQL Search Syntax
KQL搜索语法
Property filters:
- - From sender
from:user@example.com - - To recipient
to:recipient@example.com - - Subject contains
subject:invoice - - Date filter
received>=2025-01-01 - - Has attachments
hasattachment:yes
Combinators:
- - Both conditions
AND - - Either condition
OR - Parentheses for grouping
属性筛选器:
- - 发件人筛选
from:user@example.com - - 收件人筛选
to:recipient@example.com - - 主题包含指定内容
subject:invoice - - 日期筛选
received>=2025-01-01 - - 筛选包含附件的邮件
hasattachment:yes
组合符:
- - 同时满足两个条件
AND - - 满足任一条件
OR - 使用括号进行条件分组
OData Filter Syntax
OData筛选器语法
Email filters:
- - Unread emails
isRead eq false - - High importance
importance eq 'high' - - Has attachments
hasAttachments eq true - - Date filter
receivedDateTime ge 2025-01-01T00:00:00Z
Calendar filters:
- - Events after date
start/dateTime ge '2025-01-01T00:00:00Z' - - Subject contains text
contains(subject, 'Meeting')
邮件筛选器:
- - 未读邮件
isRead eq false - - 高优先级邮件
importance eq 'high' - - 包含附件的邮件
hasAttachments eq true - - 日期筛选
receivedDateTime ge 2025-01-01T00:00:00Z
日历筛选器:
- - 指定日期之后的事件
start/dateTime ge '2025-01-01T00:00:00Z' - - 主题包含指定文本的事件
contains(subject, 'Meeting')
Known Pitfalls
已知注意事项
Account Types:
- SEARCH_MESSAGES requires Microsoft 365/Enterprise accounts
- Personal accounts (@hotmail.com, @outlook.com) have limited API access
Field Confusion:
- Email properties (receivedDateTime) differ from calendar properties (start/dateTime)
- Do NOT use email fields in calendar queries or vice versa
账户类型:
- SEARCH_MESSAGES仅支持Microsoft 365/企业账户
- 个人账户(@hotmail.com、@outlook.com)的API访问权限有限
字段混淆:
- 邮件属性(receivedDateTime)与日历属性(start/dateTime)不同
- 请勿在日历查询中使用邮件字段,反之亦然
Quick Reference
快速参考
| Task | Tool Slug | Key Params |
|---|---|---|
| Search emails | OUTLOOK_SEARCH_MESSAGES | query, from_index, size |
| Query folder | OUTLOOK_QUERY_EMAILS | folder, filter, top |
| Get message | OUTLOOK_GET_MESSAGE | message_id |
| List attachments | OUTLOOK_LIST_OUTLOOK_ATTACHMENTS | message_id |
| Download attachment | OUTLOOK_DOWNLOAD_OUTLOOK_ATTACHMENT | message_id, attachment_id |
| List folders | OUTLOOK_LIST_MAIL_FOLDERS | (none) |
| Child folders | OUTLOOK_LIST_CHILD_MAIL_FOLDERS | parent_folder_id |
| List events | OUTLOOK_LIST_EVENTS | filter, timezone |
| Calendar view | OUTLOOK_GET_CALENDAR_VIEW | start_datetime, end_datetime |
| Get event | OUTLOOK_GET_EVENT | event_id |
| List calendars | OUTLOOK_LIST_CALENDARS | (none) |
| Free/busy | OUTLOOK_GET_SCHEDULE | schedules, times |
| List contacts | OUTLOOK_LIST_CONTACTS | top, filter |
| Create contact | OUTLOOK_CREATE_CONTACT | givenName, emailAddresses |
| Contact folders | OUTLOOK_GET_CONTACT_FOLDERS | (none) |
| 任务 | 工具标识 | 关键参数 |
|---|---|---|
| 搜索邮件 | OUTLOOK_SEARCH_MESSAGES | query, from_index, size |
| 查询文件夹邮件 | OUTLOOK_QUERY_EMAILS | folder, filter, top |
| 获取邮件详情 | OUTLOOK_GET_MESSAGE | message_id |
| 列出附件 | OUTLOOK_LIST_OUTLOOK_ATTACHMENTS | message_id |
| 下载附件 | OUTLOOK_DOWNLOAD_OUTLOOK_ATTACHMENT | message_id, attachment_id |
| 列出邮件文件夹 | OUTLOOK_LIST_MAIL_FOLDERS | 无 |
| 列出子文件夹 | OUTLOOK_LIST_CHILD_MAIL_FOLDERS | parent_folder_id |
| 列出日历事件 | OUTLOOK_LIST_EVENTS | filter, timezone |
| 获取日历视图 | OUTLOOK_GET_CALENDAR_VIEW | start_datetime, end_datetime |
| 获取事件详情 | OUTLOOK_GET_EVENT | event_id |
| 列出日历 | OUTLOOK_LIST_CALENDARS | 无 |
| 获取忙闲信息 | OUTLOOK_GET_SCHEDULE | schedules, times |
| 列出联系人 | OUTLOOK_LIST_CONTACTS | top, filter |
| 创建联系人 | OUTLOOK_CREATE_CONTACT | givenName, emailAddresses |
| 列出联系人文件夹 | OUTLOOK_GET_CONTACT_FOLDERS | 无 |