miro-automation
npx skills add https://github.com/composiohq/awesome-claude-skills --skill miro-automation
Agent 安装分布
Skill 文档
Miro Automation via Rube MCP
Automate Miro whiteboard operations through Composio’s Miro toolkit via Rube MCP.
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Miro connection via
RUBE_MANAGE_CONNECTIONSwith toolkitmiro - Always call
RUBE_SEARCH_TOOLSfirst 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.
- Verify Rube MCP is available by confirming
RUBE_SEARCH_TOOLSresponds - Call
RUBE_MANAGE_CONNECTIONSwith toolkitmiro - If connection is not ACTIVE, follow the returned auth link to complete Miro OAuth
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. List and Browse Boards
When to use: User wants to find boards or get board details
Tool sequence:
MIRO_GET_BOARDS2– List all accessible boards [Required]MIRO_GET_BOARD– Get detailed info for a specific board [Optional]
Key parameters:
query: Search term to filter boards by namesort: Sort by ‘default’, ‘last_modified’, ‘last_opened’, ‘last_created’, ‘alphabetically’limit: Number of results per page (max 50)offset: Pagination offsetboard_id: Specific board ID for detailed retrieval
Pitfalls:
- Pagination uses offset-based approach, not cursor-based
- Maximum 50 boards per page; iterate with offset for full list
- Board IDs are long alphanumeric strings; always resolve by search first
2. Create Boards and Items
When to use: User wants to create a new board or add items to an existing board
Tool sequence:
MIRO_CREATE_BOARD– Create a new empty board [Optional]MIRO_CREATE_STICKY_NOTE_ITEM– Add sticky notes to a board [Optional]MIRO_CREATE_FRAME_ITEM2– Add frames to organize content [Optional]MIRO_CREATE_ITEMS_IN_BULK– Add multiple items at once [Optional]
Key parameters:
name/description: Board name and description (for CREATE_BOARD)board_id: Target board ID (required for all item creation)data: Content object withcontentfield for sticky note textstyle: Styling object withfillColorfor sticky note colorposition: Object withxandycoordinatesgeometry: Object withwidthandheight
Pitfalls:
board_idis required for ALL item operations; resolve via GET_BOARDS2 first- Sticky note colors use hex codes (e.g., ‘#FF0000’) in the
fillColorfield - Position coordinates use the board’s coordinate system (origin at center)
- BULK create has a maximum items-per-request limit; check current schema
- Frame items require
geometrywith both width and height
3. Browse and Manage Board Items
When to use: User wants to view, find, or organize items on a board
Tool sequence:
MIRO_GET_BOARD_ITEMS– List all items on a board [Required]MIRO_GET_CONNECTORS2– List connections between items [Optional]
Key parameters:
board_id: Target board ID (required)type: Filter by item type (‘sticky_note’, ‘shape’, ‘text’, ‘frame’, ‘image’, ‘card’)limit: Number of items per pagecursor: Pagination cursor from previous response
Pitfalls:
- Results are paginated; follow
cursoruntil absent for complete item list - Item types must match Miro’s predefined types exactly
- Large boards may have thousands of items; use type filtering to narrow results
- Connectors are separate from items; use GET_CONNECTORS2 for relationship data
4. Share and Collaborate on Boards
When to use: User wants to share a board with team members or manage access
Tool sequence:
MIRO_GET_BOARDS2– Find the board to share [Prerequisite]MIRO_SHARE_BOARD– Share the board with users [Required]MIRO_GET_BOARD_MEMBERS– Verify current board members [Optional]
Key parameters:
board_id: Board to share (required)emails: Array of email addresses to inviterole: Access level (‘viewer’, ‘commenter’, ‘editor’)message: Optional invitation message
Pitfalls:
- Email addresses must be valid; invalid emails cause the entire request to fail
- Role must be one of the predefined values; case-sensitive
- Sharing with users outside the organization may require admin approval
- GET_BOARD_MEMBERS returns all members including the owner
5. Create Visual Connections
When to use: User wants to connect items on a board with lines or arrows
Tool sequence:
MIRO_GET_BOARD_ITEMS– Find items to connect [Prerequisite]MIRO_GET_CONNECTORS2– View existing connections [Optional]
Key parameters:
board_id: Target board IDstartItem: Object withidof the source itemendItem: Object withidof the target itemstyle: Connector style (line type, color, arrows)
Pitfalls:
- Both start and end items must exist on the same board
- Item IDs are required for connections; resolve via GET_BOARD_ITEMS first
- Connector styles vary; check available options in schema
- Self-referencing connections (same start and end) are not allowed
Common Patterns
ID Resolution
Board name -> Board ID:
1. Call MIRO_GET_BOARDS2 with query=board_name
2. Find board by name in results
3. Extract id field
Item lookup on board:
1. Call MIRO_GET_BOARD_ITEMS with board_id and optional type filter
2. Find item by content or position
3. Extract item id for further operations
Pagination
- Boards: Use
offsetandlimit(offset-based) - Board items: Use
cursorandlimit(cursor-based) - Continue until no more results or cursor is absent
- Default page sizes vary by endpoint
Coordinate System
- Board origin (0,0) is at the center
- Positive X is right, positive Y is down
- Items positioned by their center point
- Use
position: {x: 0, y: 0}for center of board - Frames define bounded areas; items inside inherit frame position
Known Pitfalls
Board IDs:
- Board IDs are required for virtually all operations
- Always resolve board names to IDs via GET_BOARDS2 first
- Do not hardcode board IDs; they vary by account
Item Creation:
- Each item type has different required fields
- Sticky notes need
data.contentfor text - Frames need
geometry.widthandgeometry.height - Position defaults to (0,0) if not specified; items may overlap
Rate Limits:
- Miro API has rate limits per token
- Bulk operations preferred over individual item creation
- Use MIRO_CREATE_ITEMS_IN_BULK for multiple items
Response Parsing:
- Response data may be nested under
datakey - Item types determine which fields are present in response
- Parse defensively; optional fields may be absent
Quick Reference
| Task | Tool Slug | Key Params |
|---|---|---|
| List boards | MIRO_GET_BOARDS2 | query, sort, limit, offset |
| Get board details | MIRO_GET_BOARD | board_id |
| Create board | MIRO_CREATE_BOARD | name, description |
| Add sticky note | MIRO_CREATE_STICKY_NOTE_ITEM | board_id, data, style, position |
| Add frame | MIRO_CREATE_FRAME_ITEM2 | board_id, data, geometry, position |
| Bulk add items | MIRO_CREATE_ITEMS_IN_BULK | board_id, items |
| Get board items | MIRO_GET_BOARD_ITEMS | board_id, type, cursor |
| Share board | MIRO_SHARE_BOARD | board_id, emails, role |
| Get members | MIRO_GET_BOARD_MEMBERS | board_id |
| Get connectors | MIRO_GET_CONNECTORS2 | board_id |