From superpowers
Automates Attio CRM operations via natural language: fuzzy search records, run filtered queries, find by ID/attributes, and browse notes through Composio MCP.
How this skill is triggered — by the user, by Claude, or both
Slash command
/superpowers:attio-automationThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Manage your Attio CRM workspace -- fuzzy search across people and companies, run complex filtered queries, browse notes, discover object schemas, and list records -- all through natural language commands.
Manage your Attio CRM workspace -- fuzzy search across people and companies, run complex filtered queries, browse notes, discover object schemas, and list records -- all through natural language commands.
Toolkit docs: composio.dev/toolkits/attio
https://rube.app/mcp
Search for people, companies, deals, or any object by name, domain, email, phone, or social handle.
Tool: ATTIO_SEARCH_RECORDS
Example prompt:
"Search Attio for anyone named Alan Mathis"
Key parameters (all required):
query -- Search string (max 256 characters). Empty string returns default results.objects -- Array of object slugs to search (e.g., ["people"], ["people", "companies"], ["deals"])request_as -- Context: use {"type": "workspace"} for full workspace search, or specify a workspace memberQuery records with server-side filtering, sorting, and complex conditions -- far more powerful than fuzzy search.
Tool: ATTIO_QUERY_RECORDS
Example prompt:
"Find all companies in Attio created after January 2025 sorted by name"
Key parameters:
object (required) -- Object slug or UUID (e.g., "people", "companies", "deals")filter -- Attio filter object with operators like $eq, $contains, $gte, $and, $orsorts -- Array of sort specifications with direction ("asc"/"desc") and attributelimit -- Max records to return (up to 500)offset -- Pagination offsetFilter examples:
{"name": {"first_name": {"$contains": "John"}}}
{"email_addresses": {"$contains": "@example.com"}}
{"created_at": {"$gte": "2025-01-01T00:00:00.000Z"}}
Look up a specific record by its unique ID or search by unique attribute values.
Tool: ATTIO_FIND_RECORD
Example prompt:
"Find the Attio company with domain example.com"
Key parameters:
object_id (required) -- Object type slug: "people", "companies", "deals", "users", "workspaces"record_id -- Direct lookup by UUID (optional)attributes -- Dictionary of attribute filters (e.g., {"email_addresses": "[email protected]"})limit -- Max records (up to 1000)offset -- Pagination offsetList notes across the workspace or filter by specific parent objects and records.
Tool: ATTIO_LIST_NOTES
Example prompt:
"Show the last 10 notes on the Acme Corp company record in Attio"
Key parameters:
parent_object -- Object slug (e.g., "people", "companies", "deals") -- requires parent_record_idparent_record_id -- UUID of the parent record -- requires parent_objectlimit -- Max notes to return (1-50, default 10)offset -- Number of results to skipUnderstand your workspace structure by listing objects and their attribute definitions.
Tools: ATTIO_GET_OBJECT, ATTIO_LIST_ATTRIBUTES
Example prompt:
"What attributes does the companies object have in Attio?"
Key parameters for Get Object:
object_id -- Object slug or UUIDKey parameters for List Attributes:
target -- "objects" or "lists"identifier -- Object or list ID/slugRetrieve records from a specific object type with simple pagination, returned in creation order.
Tool: ATTIO_LIST_RECORDS
Example prompt:
"List the first 100 people records in Attio"
Key parameters:
created_at, updated_at, custom timestamps) MUST use ISO8601 string format (e.g., 2025-01-01T00:00:00.000Z). Unix timestamps or numeric values cause "Invalid timestamp value" errors.name attribute has sub-properties (first_name, last_name, full_name) that MUST be nested under name. Correct: {"name": {"first_name": {"$contains": "John"}}}. Wrong: {"first_name": {...}} -- this fails with "unknown_filter_attribute_slug".email_addresses supports $eq, $contains, $starts_with, $ends_with but NOT $not_empty.{"path": [["companies", "team"], ["people", "name"]], "constraints": {"first_name": {"$eq": "John"}}}.object_id. Use list-specific actions for list operations.ATTIO_SEARCH_RECORDS returns eventually consistent results. For guaranteed up-to-date results, use ATTIO_QUERY_RECORDS instead.ATTIO_LIST_ATTRIBUTES to discover valid slugs for your workspace.| Action | Tool Slug | Required Params |
|---|---|---|
| Fuzzy search records | ATTIO_SEARCH_RECORDS | query, objects, request_as |
| Query with filters | ATTIO_QUERY_RECORDS | object |
| Find record by ID/attributes | ATTIO_FIND_RECORD | object_id |
| List notes | ATTIO_LIST_NOTES | None (optional filters) |
| Get object schema | ATTIO_GET_OBJECT | object_id |
| List attributes | ATTIO_LIST_ATTRIBUTES | target, identifier |
| List records | ATTIO_LIST_RECORDS | Object type |
Powered by Composio
npx claudepluginhub lunartech-x/superpowers --plugin superpowersManages Attio CRM companies, contacts, notes, and deals via Python scripts: search/get companies, create/update records, add notes, parse URLs. For CRM automation.
Performs full CRUD operations—create, read, update, delete, search—on Attio records for people, companies, deals, and custom objects via REST API.
Automates Zoho CRM operations via Composio/Rube MCP: create/update records, search contacts, manage leads, and convert leads. Always searches tools first for current schemas.