Adds pre-built workflow skills for 78 SaaS apps across 16 categories: CRM, project management, communication, email, code/DevOps, storage, spreadsheets, calendar, social media, marketing, support, e-commerce, design, analytics, HR, and automation platforms. Each skill includes: - Real tool slugs discovered from Composio's RUBE_SEARCH_TOOLS API - Step-by-step workflow sequences with [Prerequisite/Required/Optional] tags - Key parameter documentation with format guidance - Known pitfalls from actual API behavior - Quick reference tables for all available tools - Setup instructions for Rube MCP connection Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
189 lines
7.1 KiB
Markdown
189 lines
7.1 KiB
Markdown
---
|
|
name: outlook-automation
|
|
description: Automate Outlook tasks via Rube MCP (Composio): emails, calendar, contacts, folders, attachments. Always search tools first for current schemas.
|
|
requires:
|
|
mcp: [rube]
|
|
---
|
|
|
|
# Outlook 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 `RUBE_MANAGE_CONNECTIONS` with toolkit `outlook`
|
|
- Always call `RUBE_SEARCH_TOOLS` first to get current tool schemas
|
|
|
|
## Setup
|
|
|
|
1. Verify Rube MCP is available by confirming `RUBE_SEARCH_TOOLS` responds
|
|
2. Call `RUBE_MANAGE_CONNECTIONS` with toolkit `outlook`
|
|
3. If connection is not ACTIVE, follow the returned auth link to complete Microsoft OAuth
|
|
4. 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**:
|
|
1. `OUTLOOK_SEARCH_MESSAGES` - Search with KQL syntax across all folders [Required]
|
|
2. `OUTLOOK_GET_MESSAGE` - Get full message details [Optional]
|
|
3. `OUTLOOK_LIST_OUTLOOK_ATTACHMENTS` - List message attachments [Optional]
|
|
4. `OUTLOOK_DOWNLOAD_OUTLOOK_ATTACHMENT` - Download attachment [Optional]
|
|
|
|
**Key parameters**:
|
|
- `query`: KQL search string (from:, to:, subject:, received:, hasattachment:)
|
|
- `from_index`: Pagination start (0-based)
|
|
- `size`: Results per page (max 25)
|
|
- `message_id`: Message ID (use hitId from search results)
|
|
|
|
**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**:
|
|
1. `OUTLOOK_LIST_MAIL_FOLDERS` - List mail folders to get folder IDs [Prerequisite]
|
|
2. `OUTLOOK_QUERY_EMAILS` - Query emails with structured filters [Required]
|
|
|
|
**Key parameters**:
|
|
- `folder`: Folder name ('inbox', 'sentitems', 'drafts') or folder ID
|
|
- `filter`: OData filter (e.g., `isRead eq false and importance eq 'high'`)
|
|
- `top`: Max results (1-1000)
|
|
- `orderby`: Sort field and direction
|
|
- `select`: Array of fields to return
|
|
|
|
**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**:
|
|
1. `OUTLOOK_LIST_EVENTS` - List events with filters [Optional]
|
|
2. `OUTLOOK_GET_CALENDAR_VIEW` - Get events in a time window [Optional]
|
|
3. `OUTLOOK_GET_EVENT` - Get specific event details [Optional]
|
|
4. `OUTLOOK_LIST_CALENDARS` - List available calendars [Optional]
|
|
5. `OUTLOOK_GET_SCHEDULE` - Get free/busy info [Optional]
|
|
|
|
**Key parameters**:
|
|
- `filter`: OData filter (use start/dateTime, NOT receivedDateTime)
|
|
- `start_datetime`/`end_datetime`: ISO 8601 for calendar view
|
|
- `timezone`: IANA timezone (e.g., 'America/New_York')
|
|
- `calendar_id`: Optional non-primary calendar ID
|
|
- `select`: Fields to return
|
|
|
|
**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 `expand_recurring_events=true` to see individual occurrences
|
|
- 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**:
|
|
1. `OUTLOOK_LIST_CONTACTS` - List contacts [Optional]
|
|
2. `OUTLOOK_CREATE_CONTACT` - Create a new contact [Optional]
|
|
3. `OUTLOOK_GET_CONTACT_FOLDERS` - List contact folders [Optional]
|
|
4. `OUTLOOK_CREATE_CONTACT_FOLDER` - Create contact folder [Optional]
|
|
|
|
**Key parameters**:
|
|
- `givenName`/`surname`: Contact name
|
|
- `emailAddresses`: Array of email objects
|
|
- `displayName`: Full display name
|
|
- `contact_folder_id`: Optional folder for contacts
|
|
|
|
**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**:
|
|
1. `OUTLOOK_LIST_MAIL_FOLDERS` - List top-level folders [Required]
|
|
2. `OUTLOOK_LIST_CHILD_MAIL_FOLDERS` - List subfolders [Optional]
|
|
3. `OUTLOOK_CREATE_MAIL_FOLDER` - Create a new folder [Optional]
|
|
|
|
**Key parameters**:
|
|
- `parent_folder_id`: Well-known name or folder ID
|
|
- `displayName`: New folder name
|
|
- `include_hidden_folders`: Show 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:user@example.com` - From sender
|
|
- `to:recipient@example.com` - To recipient
|
|
- `subject:invoice` - Subject contains
|
|
- `received>=2025-01-01` - Date filter
|
|
- `hasattachment:yes` - Has attachments
|
|
|
|
**Combinators**:
|
|
- `AND` - Both conditions
|
|
- `OR` - Either condition
|
|
- Parentheses for grouping
|
|
|
|
### OData Filter Syntax
|
|
|
|
**Email filters**:
|
|
- `isRead eq false` - Unread emails
|
|
- `importance eq 'high'` - High importance
|
|
- `hasAttachments eq true` - Has attachments
|
|
- `receivedDateTime ge 2025-01-01T00:00:00Z` - Date filter
|
|
|
|
**Calendar filters**:
|
|
- `start/dateTime ge '2025-01-01T00:00:00Z'` - Events after date
|
|
- `contains(subject, 'Meeting')` - Subject contains text
|
|
|
|
## 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) |
|