Rei-skills outlook-automation
Automate Outlook tasks via Rube MCP (Composio): emails, calendar, contacts, folders, attachments. Always search tools first for current schemas.
git clone https://github.com/rootcastleco/rei-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/rootcastleco/rei-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/outlook-automation" ~/.claude/skills/rootcastleco-rei-skills-outlook-automation && rm -rf "$T"
skills/outlook-automation/SKILL.mdOutlook Automation via Rube MCP
Automate Microsoft Outlook operations through Composio's Outlook toolkit via Rube MCP.
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Outlook connection via
with toolkitRUBE_MANAGE_CONNECTIONSoutlook - Always call
first to get current tool schemasRUBE_SEARCH_TOOLS
Setup
Get Rube MCP: Add
https://rube.app/mcp as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
- Verify Rube MCP is available by confirming
respondsRUBE_SEARCH_TOOLS - Call
with toolkitRUBE_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
Core Workflows
1. Search and Filter Emails
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
2. Query Emails in a Folder
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 IDfolder
: OData filter (e.g.,filter
)isRead eq false and importance eq 'high'
: Max results (1-1000)top
: Sort field and directionorderby
: Array of fields to returnselect
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
3. Manage Calendar Events
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 IDcalendar_id
: Fields to returnselect
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 occurrencesexpand_recurring_events=true - Decline status is per-attendee via attendees[].status.response
4. Manage Contacts
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 objectsemailAddresses
: Full display namedisplayName
: Optional folder for contactscontact_folder_id
Pitfalls:
- Contact creation supports many fields but only givenName or surname is needed
5. Manage Mail Folders
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 IDparent_folder_id
: New folder namedisplayName
: Show hidden foldersinclude_hidden_folders
Pitfalls:
- Well-known folder names: 'inbox', 'sentitems', 'drafts', 'deleteditems', 'junkemail', 'archive'
- Custom folder operations require the folder ID, not display name
Common Patterns
KQL Search Syntax
Property filters:
- From senderfrom:user@example.com
- To recipientto:recipient@example.com
- Subject containssubject:invoice
- Date filterreceived>=2025-01-01
- Has attachmentshasattachment:yes
Combinators:
- Both conditionsAND
- Either conditionOR- Parentheses for grouping
OData Filter Syntax
Email filters:
- Unread emailsisRead eq false
- High importanceimportance eq 'high'
- Has attachmentshasAttachments eq true
- Date filterreceivedDateTime ge 2025-01-01T00:00:00Z
Calendar filters:
- Events after datestart/dateTime ge '2025-01-01T00:00:00Z'
- Subject contains textcontains(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
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) |
When to Use
This skill is applicable to execute the workflow or actions described in the overview.
🏰 Rei Skills — Curated by Rootcastle Engineering & Innovation | Batuhan Ayrıbaş
Engineering Beyond Boundaries | admin@rootcastle.com