- Add date_added to all 950+ skills for complete tracking - Update version to 6.5.0 in package.json and README - Regenerate all indexes and catalog - Sync all generated files Features from merged PR #150: - Stars/Upvotes system for community-driven discovery - Auto-update mechanism via START_APP.bat - Interactive Prompt Builder - Date tracking badges - Smart auto-categorization All skills validated and indexed. Made-with: Cursor
253 lines
9.5 KiB
Markdown
253 lines
9.5 KiB
Markdown
---
|
|
name: intercom-automation
|
|
description: "Automate Intercom tasks via Rube MCP (Composio): conversations, contacts, companies, segments, admins. Always search tools first for current schemas."
|
|
risk: unknown
|
|
source: community
|
|
date_added: "2026-02-27"
|
|
---
|
|
|
|
# Intercom Automation via Rube MCP
|
|
|
|
Automate Intercom operations through Composio's Intercom toolkit via Rube MCP.
|
|
|
|
## Prerequisites
|
|
|
|
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
|
|
- Active Intercom connection via `RUBE_MANAGE_CONNECTIONS` with toolkit `intercom`
|
|
- Always call `RUBE_SEARCH_TOOLS` first to get current tool schemas
|
|
|
|
## 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.
|
|
|
|
|
|
1. Verify Rube MCP is available by confirming `RUBE_SEARCH_TOOLS` responds
|
|
2. Call `RUBE_MANAGE_CONNECTIONS` with toolkit `intercom`
|
|
3. If connection is not ACTIVE, follow the returned auth link to complete Intercom OAuth
|
|
4. Confirm connection status shows ACTIVE before running any workflows
|
|
|
|
## Core Workflows
|
|
|
|
### 1. Manage Conversations
|
|
|
|
**When to use**: User wants to create, list, search, or manage support conversations
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_LIST_ALL_ADMINS` - Get admin IDs for assignment [Prerequisite]
|
|
2. `INTERCOM_LIST_CONVERSATIONS` - List all conversations [Optional]
|
|
3. `INTERCOM_SEARCH_CONVERSATIONS` - Search with filters [Optional]
|
|
4. `INTERCOM_GET_CONVERSATION` - Get conversation details [Optional]
|
|
5. `INTERCOM_CREATE_CONVERSATION` - Create a new conversation [Optional]
|
|
|
|
**Key parameters**:
|
|
- `from`: Object with `type` ('user'/'lead') and `id` for conversation creator
|
|
- `body`: Message body (HTML supported)
|
|
- `id`: Conversation ID for retrieval
|
|
- `query`: Search query object with `field`, `operator`, `value`
|
|
|
|
**Pitfalls**:
|
|
- CREATE_CONVERSATION requires a contact (user/lead) as the `from` field, not an admin
|
|
- Conversation bodies support HTML; plain text is auto-wrapped in `<p>` tags
|
|
- Search query uses structured filter objects, not free-text search
|
|
- Conversation IDs are numeric strings
|
|
|
|
### 2. Reply and Manage Conversation State
|
|
|
|
**When to use**: User wants to reply to, close, reopen, or assign conversations
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_GET_CONVERSATION` - Get current state [Prerequisite]
|
|
2. `INTERCOM_REPLY_TO_CONVERSATION` - Add a reply [Optional]
|
|
3. `INTERCOM_ASSIGN_CONVERSATION` - Assign to admin/team [Optional]
|
|
4. `INTERCOM_CLOSE_CONVERSATION` - Close conversation [Optional]
|
|
5. `INTERCOM_REOPEN_CONVERSATION` - Reopen closed conversation [Optional]
|
|
|
|
**Key parameters**:
|
|
- `conversation_id` / `id`: Conversation ID
|
|
- `body`: Reply message body (HTML supported)
|
|
- `type`: Reply type ('admin' or 'user')
|
|
- `admin_id`: Admin ID for replies from admin, assignment, and close/reopen
|
|
- `assignee_id`: Admin or team ID for assignment
|
|
- `message_type`: 'comment' (default) or 'note' (internal)
|
|
|
|
**Pitfalls**:
|
|
- `admin_id` is REQUIRED for admin replies, close, reopen, and assignment operations
|
|
- Always fetch admin IDs first with LIST_ALL_ADMINS or IDENTIFY_AN_ADMIN
|
|
- Duplicate sends can occur on retry; implement idempotency checks
|
|
- Internal notes use `message_type: 'note'`; visible only to workspace members
|
|
- Closing requires an admin_id and optional body message
|
|
|
|
### 3. Manage Contacts
|
|
|
|
**When to use**: User wants to search, view, or manage contacts (users and leads)
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_SEARCH_CONTACTS` - Search contacts with filters [Required]
|
|
2. `INTERCOM_GET_A_CONTACT` - Get specific contact [Optional]
|
|
3. `INTERCOM_SHOW_CONTACT_BY_EXTERNAL_ID` - Look up by external ID [Optional]
|
|
4. `INTERCOM_LIST_CONTACTS` - List all contacts [Optional]
|
|
5. `INTERCOM_LIST_TAGS_ATTACHED_TO_A_CONTACT` - Get contact tags [Optional]
|
|
6. `INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_CONTACT` - Get contact segments [Optional]
|
|
7. `INTERCOM_DETACH_A_CONTACT` - Remove contact from company [Optional]
|
|
|
|
**Key parameters**:
|
|
- `contact_id`: Contact ID for retrieval
|
|
- `external_id`: External system ID for lookup
|
|
- `query`: Search filter object with `field`, `operator`, `value`
|
|
- `pagination`: Object with `per_page` and `starting_after` cursor
|
|
|
|
**Pitfalls**:
|
|
- SEARCH_CONTACTS uses structured query filters, not free-text; format: `{field, operator, value}`
|
|
- Supported operators: `=`, `!=`, `>`, `<`, `~` (contains), `!~` (not contains), `IN`, `NIN`
|
|
- Contact types are 'user' (identified) or 'lead' (anonymous)
|
|
- LIST_CONTACTS returns paginated results; use `starting_after` cursor for pagination
|
|
- External IDs are case-sensitive
|
|
|
|
### 4. Manage Admins and Teams
|
|
|
|
**When to use**: User wants to list workspace admins or identify specific admins
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_LIST_ALL_ADMINS` - List all admins and teams [Required]
|
|
2. `INTERCOM_IDENTIFY_AN_ADMIN` - Get specific admin details [Optional]
|
|
|
|
**Key parameters**:
|
|
- `admin_id`: Admin ID for identification
|
|
|
|
**Pitfalls**:
|
|
- LIST_ALL_ADMINS returns both admins and teams
|
|
- Admin IDs are required for conversation replies, assignment, close, and reopen
|
|
- Teams appear in the admins list with `type: 'team'`
|
|
|
|
### 5. View Segments and Counts
|
|
|
|
**When to use**: User wants to view segments or get aggregate counts
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_LIST_SEGMENTS` - List all segments [Optional]
|
|
2. `INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_CONTACT` - Segments for a contact [Optional]
|
|
3. `INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_COMPANIES` - Segments for a company [Optional]
|
|
4. `INTERCOM_GET_COUNTS` - Get aggregate counts [Optional]
|
|
|
|
**Key parameters**:
|
|
- `contact_id`: Contact ID for segment lookup
|
|
- `company_id`: Company ID for segment lookup
|
|
- `type`: Count type ('conversation', 'company', 'user', 'tag', 'segment')
|
|
- `count`: Sub-count type
|
|
|
|
**Pitfalls**:
|
|
- GET_COUNTS returns approximate counts, not exact numbers
|
|
- Segment membership is computed; changes may not reflect immediately
|
|
|
|
### 6. Manage Companies
|
|
|
|
**When to use**: User wants to list companies or manage company-contact relationships
|
|
|
|
**Tool sequence**:
|
|
1. `INTERCOM_LIST_ALL_COMPANIES` - List all companies [Required]
|
|
2. `INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_COMPANIES` - Get company segments [Optional]
|
|
3. `INTERCOM_DETACH_A_CONTACT` - Remove contact from company [Optional]
|
|
|
|
**Key parameters**:
|
|
- `company_id`: Company ID
|
|
- `contact_id`: Contact ID for detachment
|
|
- `page`: Page number for pagination
|
|
- `per_page`: Results per page
|
|
|
|
**Pitfalls**:
|
|
- Company-contact relationships are managed through contact endpoints
|
|
- DETACH_A_CONTACT removes the contact-company association, not the contact itself
|
|
|
|
## Common Patterns
|
|
|
|
### Search Query Filters
|
|
|
|
**Single filter**:
|
|
```json
|
|
{
|
|
"field": "email",
|
|
"operator": "=",
|
|
"value": "user@example.com"
|
|
}
|
|
```
|
|
|
|
**Multiple filters (AND)**:
|
|
```json
|
|
{
|
|
"operator": "AND",
|
|
"value": [
|
|
{"field": "role", "operator": "=", "value": "user"},
|
|
{"field": "created_at", "operator": ">", "value": 1672531200}
|
|
]
|
|
}
|
|
```
|
|
|
|
**Supported fields for contacts**: email, name, role, created_at, updated_at, signed_up_at, last_seen_at, external_id
|
|
|
|
**Supported fields for conversations**: created_at, updated_at, source.type, state, open, read
|
|
|
|
### Pagination
|
|
|
|
- Most list endpoints use cursor-based pagination
|
|
- Check response for `pages.next` with `starting_after` cursor
|
|
- Pass cursor in `pagination.starting_after` for next page
|
|
- Continue until `pages.next` is null
|
|
|
|
### Admin ID Resolution
|
|
|
|
```
|
|
1. Call INTERCOM_LIST_ALL_ADMINS to get all admins
|
|
2. Find the desired admin by name or email
|
|
3. Use admin.id for replies, assignments, and state changes
|
|
```
|
|
|
|
## Known Pitfalls
|
|
|
|
**Admin ID Requirement**:
|
|
- Admin ID is required for: reply (as admin), assign, close, reopen
|
|
- Always resolve admin IDs first with LIST_ALL_ADMINS
|
|
|
|
**HTML Content**:
|
|
- Conversation bodies are HTML
|
|
- Plain text is auto-wrapped in paragraph tags
|
|
- Sanitize HTML input to prevent rendering issues
|
|
|
|
**Idempotency**:
|
|
- Replies and conversation creation are not idempotent
|
|
- Duplicate sends can occur on retry or timeout
|
|
- Track message IDs to prevent duplicates
|
|
|
|
**Rate Limits**:
|
|
- Default: ~1000 requests per minute (varies by plan)
|
|
- 429 responses include rate limit headers
|
|
- Implement exponential backoff for retries
|
|
|
|
## Quick Reference
|
|
|
|
| Task | Tool Slug | Key Params |
|
|
|------|-----------|------------|
|
|
| List conversations | INTERCOM_LIST_CONVERSATIONS | (pagination) |
|
|
| Search conversations | INTERCOM_SEARCH_CONVERSATIONS | query |
|
|
| Get conversation | INTERCOM_GET_CONVERSATION | id |
|
|
| Create conversation | INTERCOM_CREATE_CONVERSATION | from, body |
|
|
| Reply to conversation | INTERCOM_REPLY_TO_CONVERSATION | conversation_id, body, admin_id |
|
|
| Assign conversation | INTERCOM_ASSIGN_CONVERSATION | conversation_id, admin_id, assignee_id |
|
|
| Close conversation | INTERCOM_CLOSE_CONVERSATION | id, admin_id |
|
|
| Reopen conversation | INTERCOM_REOPEN_CONVERSATION | id, admin_id |
|
|
| Search contacts | INTERCOM_SEARCH_CONTACTS | query |
|
|
| Get contact | INTERCOM_GET_A_CONTACT | contact_id |
|
|
| Contact by external ID | INTERCOM_SHOW_CONTACT_BY_EXTERNAL_ID | external_id |
|
|
| List contacts | INTERCOM_LIST_CONTACTS | (pagination) |
|
|
| Contact tags | INTERCOM_LIST_TAGS_ATTACHED_TO_A_CONTACT | contact_id |
|
|
| Contact segments | INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_CONTACT | contact_id |
|
|
| Detach contact | INTERCOM_DETACH_A_CONTACT | contact_id, company_id |
|
|
| List admins | INTERCOM_LIST_ALL_ADMINS | (none) |
|
|
| Identify admin | INTERCOM_IDENTIFY_AN_ADMIN | admin_id |
|
|
| List segments | INTERCOM_LIST_SEGMENTS | (none) |
|
|
| Company segments | INTERCOM_LIST_ATTACHED_SEGMENTS_FOR_COMPANIES | company_id |
|
|
| Get counts | INTERCOM_GET_COUNTS | type, count |
|
|
| List companies | INTERCOM_LIST_ALL_COMPANIES | page, per_page |
|
|
|
|
## When to Use
|
|
This skill is applicable to execute the workflow or actions described in the overview.
|