Marketplace monday-automation
Automate Monday.com work management including boards, items, columns, groups, subitems, and updates via Rube MCP (Composio). Always search tools first for current schemas.
git clone https://github.com/aiskillstore/marketplace
T=$(mktemp -d) && git clone --depth=1 https://github.com/aiskillstore/marketplace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/sickn33/monday-automation" ~/.claude/skills/aiskillstore-marketplace-monday-automation && rm -rf "$T"
skills/sickn33/monday-automation/SKILL.mdMonday.com Automation via Rube MCP
Automate Monday.com work management workflows including board creation, item management, column value updates, group organization, subitems, and update/comment threads through Composio's Monday toolkit.
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Monday.com connection via
with toolkitRUBE_MANAGE_CONNECTIONSmonday - 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_CONNECTIONSmonday - If connection is not ACTIVE, follow the returned auth link to complete Monday.com OAuth
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. Create and Manage Boards
When to use: User wants to create a new board, list existing boards, or set up workspace structure.
Tool sequence:
- List available workspaces and resolve workspace ID [Prerequisite]MONDAY_GET_WORKSPACES
- List existing boards to check for duplicates [Optional]MONDAY_LIST_BOARDS
- Create a new board with name, kind, and workspace [Required]MONDAY_CREATE_BOARD
- Add columns to the new board [Optional]MONDAY_CREATE_COLUMN
- Add groups to organize items [Optional]MONDAY_CREATE_GROUP
- Retrieve detailed board metadata [Optional]MONDAY_BOARDS
Key parameters:
: Name for the new board (required)board_name
: "public", "private", or "share" (required)board_kind
: Numeric workspace ID; omit for default workspaceworkspace_id
: Folder ID; must be withinfolder_id
if both providedworkspace_id
: ID of accessible template to clonetemplate_id
Pitfalls:
is required and must be one of: "public", "private", "share"board_kind- If both
andworkspace_id
are provided, the folder must exist within that workspacefolder_id
must reference a template the authenticated user can accesstemplate_id- Board IDs are large integers; always use the exact value from API responses
2. Create and Manage Items
When to use: User wants to add tasks/items to a board, list existing items, or move items between groups.
Tool sequence:
- Resolve board name to board ID [Prerequisite]MONDAY_LIST_BOARDS
- List groups on the board to get group_id [Prerequisite]MONDAY_LIST_GROUPS
- Get column IDs and types for setting values [Prerequisite]MONDAY_LIST_COLUMNS
- Create a new item with name and column values [Required]MONDAY_CREATE_ITEM
- List all items on the board [Optional]MONDAY_LIST_BOARD_ITEMS
- Move an item to a different group [Optional]MONDAY_MOVE_ITEM_TO_GROUP
- Paginated item retrieval with filtering [Optional]MONDAY_ITEMS_PAGE
Key parameters:
: Board ID (required, integer)board_id
: Item name, max 256 characters (required)item_name
: Group ID string to place the item in (optional)group_id
: JSON object or string mapping column IDs to valuescolumn_values
Pitfalls:
must use column IDs (not titles); get them fromcolumn_valuesMONDAY_LIST_COLUMNS- Column value formats vary by type: status uses
or{"index": 0}
, date uses{"label": "Done"}
, people uses{"date": "YYYY-MM-DD"}{"personsAndTeams": [{"id": 123, "kind": "person"}]}
has a 256-character maximumitem_name- Subitem boards are NOT supported by
; use GraphQL viaMONDAY_CREATE_ITEMMONDAY_CREATE_OBJECT
3. Update Item Column Values
When to use: User wants to change status, date, text, or other column values on existing items.
Tool sequence:
orMONDAY_LIST_COLUMNS
- Get column IDs and types [Prerequisite]MONDAY_COLUMNS
orMONDAY_LIST_BOARD_ITEMS
- Find the target item ID [Prerequisite]MONDAY_ITEMS_PAGE
- Update text, status, or dropdown with a string value [Required]MONDAY_CHANGE_SIMPLE_COLUMN_VALUE
- Update complex column types (timeline, people, date) with JSON [Required]MONDAY_UPDATE_ITEM
Key parameters for MONDAY_CHANGE_SIMPLE_COLUMN_VALUE:
: Board ID (integer, required)board_id
: Item ID (integer, required)item_id
: Column ID string (required)column_id
: Simple string value (e.g., "Done", "Working on it")value
: true to auto-create status/dropdown labels (default true)create_labels_if_missing
Key parameters for MONDAY_UPDATE_ITEM:
: Board ID (integer, required)board_id
: Item ID (integer, required)item_id
: Column ID string (required)column_id
: JSON object matching the column type schemavalue
: false by default; set true for status/dropdowncreate_labels_if_missing
Pitfalls:
- Use
for simple text/status/dropdown updates (string value)MONDAY_CHANGE_SIMPLE_COLUMN_VALUE - Use
for complex types like timeline, people, date (JSON value)MONDAY_UPDATE_ITEM - Column IDs are lowercase strings with underscores (e.g., "status_1", "date_2", "text"); get them from
MONDAY_LIST_COLUMNS - Status values can be set by label name ("Done") or index number ("1")
defaults differ: true for CHANGE_SIMPLE, false for UPDATE_ITEMcreate_labels_if_missing
4. Work with Groups and Board Structure
When to use: User wants to organize items into groups, add columns, or inspect board structure.
Tool sequence:
- Resolve board ID [Prerequisite]MONDAY_LIST_BOARDS
- List all groups on a board [Required]MONDAY_LIST_GROUPS
- Create a new group [Optional]MONDAY_CREATE_GROUP
orMONDAY_LIST_COLUMNS
- Inspect column structure [Required]MONDAY_COLUMNS
- Add a new column to the board [Optional]MONDAY_CREATE_COLUMN
- Reorganize items across groups [Optional]MONDAY_MOVE_ITEM_TO_GROUP
Key parameters:
: Board ID (required for all group/column operations)board_id
: Name for new group (CREATE_GROUP)group_name
: Must be a valid GraphQL enum token in snake_case (e.g., "status", "text", "long_text", "numbers", "date", "dropdown", "people")column_type
: Column display titletitle
: JSON string for status/dropdown labels, e.g.,defaults'{"labels": ["To Do", "In Progress", "Done"]}'
Pitfalls:
must be exact snake_case values; "person" is NOT valid, use "people"column_type- Group IDs are strings (e.g., "topics", "new_group_12345"), not integers
accepts an array ofMONDAY_COLUMNS
and returns column metadata including settingsboard_ids
is simpler and takes a singleMONDAY_LIST_COLUMNSboard_id
5. Manage Subitems and Updates
When to use: User wants to view subitems of a task or add comments/updates to items.
Tool sequence:
- Find parent item IDs [Prerequisite]MONDAY_LIST_BOARD_ITEMS
- Retrieve subitems with column values [Required]MONDAY_LIST_SUBITEMS_BY_PARENT
- Add a comment/update to an item [Optional]MONDAY_CREATE_UPDATE
- Create subitems via GraphQL mutation [Optional]MONDAY_CREATE_OBJECT
Key parameters for MONDAY_LIST_SUBITEMS_BY_PARENT:
: Array of parent item IDs (integer array, required)parent_item_ids
: true to include column data (default true)include_column_values
: true to include parent item info (default true)include_parent_fields
Key parameters for MONDAY_CREATE_OBJECT (GraphQL):
: Full GraphQL mutation stringquery
: Optional variables objectvariables
Pitfalls:
- Subitems can only be queried through their parent items
- To create subitems, use
with aMONDAY_CREATE_OBJECT
GraphQL mutationcreate_subitem
is for adding comments/updates to items (Monday's "updates" feature), not for modifying item valuesMONDAY_CREATE_UPDATE
is a raw GraphQL endpoint; ensure correct mutation syntaxMONDAY_CREATE_OBJECT
Common Patterns
ID Resolution
Always resolve display names to IDs before operations:
- Board name -> board_id:
and match by nameMONDAY_LIST_BOARDS - Group name -> group_id:
withMONDAY_LIST_GROUPSboard_id - Column title -> column_id:
withMONDAY_LIST_COLUMNSboard_id - Workspace name -> workspace_id:
and match by nameMONDAY_GET_WORKSPACES - Item name -> item_id:
orMONDAY_LIST_BOARD_ITEMSMONDAY_ITEMS_PAGE
Pagination
Monday.com uses cursor-based pagination for items:
returns aMONDAY_ITEMS_PAGE
in the response for the next pagecursor- Pass the
to the next call;cursor
andboard_id
are ignored when cursor is providedquery_params - Cursors are cached for 60 minutes
- Maximum
is 500 per pagelimit
andMONDAY_LIST_BOARDS
use page-based pagination withMONDAY_GET_WORKSPACES
andpagelimit
Column Value Formatting
Different column types require different value formats:
- Status:
or{"index": 0}
or simple string "Done"{"label": "Done"} - Date:
{"date": "YYYY-MM-DD"} - People:
{"personsAndTeams": [{"id": 123, "kind": "person"}]} - Text/Numbers: Plain string or number
- Timeline:
{"from": "YYYY-MM-DD", "to": "YYYY-MM-DD"}
Known Pitfalls
ID Formats
- Board IDs and item IDs are large integers (e.g., 1234567890)
- Group IDs are strings (e.g., "topics", "new_group_12345")
- Column IDs are short strings (e.g., "status_1", "date4", "text")
- Workspace IDs are integers
Rate Limits
- Monday.com GraphQL API has complexity-based rate limits
- Large boards with many columns increase query complexity
- Use
parameter to reduce items per request if hitting limitslimit
Parameter Quirks
for CREATE_COLUMN must be exact snake_case enum values; "people" not "person"column_type
in CREATE_ITEM accepts both JSON string and object formatscolumn_values
auto-creates missing labels by default;MONDAY_CHANGE_SIMPLE_COLUMN_VALUE
does notMONDAY_UPDATE_ITEM
is a raw GraphQL interface; use it for operations without dedicated tools (e.g., create_subitem, delete_item, archive_board)MONDAY_CREATE_OBJECT
Response Structure
- Board items are returned as arrays with
,id
, andname
fieldsstate - Column values include both raw
(JSON) and renderedvalue
(display string)text - Subitems are nested under parent items and cannot be queried independently
Quick Reference
| Task | Tool Slug | Key Params |
|---|---|---|
| List workspaces | | , , |
| Create workspace | | , |
| List boards | | , , |
| Create board | | , , |
| Get board metadata | | , |
| List groups | | |
| Create group | | , |
| List columns | | |
| Get column metadata | | , |
| Create column | | , , |
| Create item | | , , |
| List board items | | |
| Paginated items | | , , |
| Update column (simple) | | , , , |
| Update column (complex) | | , , , |
| Move item to group | | , |
| List subitems | | |
| Add comment/update | | , |
| Raw GraphQL mutation | | , |