square-automation
Scannednpx machina-cli add skill davepoon/buildwithclaude/square-automation --openclawSquare Automation via Rube MCP
Automate Square payment processing, order management, and invoicing through Composio's Square toolkit via Rube MCP.
Toolkit docs: composio.dev/toolkits/square
Prerequisites
- Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
- Active Square connection via
RUBE_MANAGE_CONNECTIONSwith toolkitsquare - 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 toolkitsquare - If connection is not ACTIVE, follow the returned auth link to complete Square OAuth
- Confirm connection status shows ACTIVE before running any workflows
Core Workflows
1. List and Monitor Payments
When to use: User wants to view payment history or check payment status
Tool sequence:
SQUARE_LIST_PAYMENTS- Retrieve payments with optional filters [Required]SQUARE_CANCEL_PAYMENT- Cancel a pending payment if needed [Optional]
Key parameters:
begin_time/end_time: RFC 3339 timestamps for date range filteringsort_order: 'ASC' or 'DESC' for chronological orderingcursor: Pagination cursor from previous responselocation_id: Filter payments by specific location
Pitfalls:
- Timestamps must be RFC 3339 format (e.g., '2024-01-01T00:00:00Z')
- Pagination required for large result sets; follow
cursoruntil absent - Only pending payments can be cancelled; completed payments require refunds
SQUARE_CANCEL_PAYMENTrequires exactpayment_idfrom list results
2. Search and Manage Orders
When to use: User wants to find orders by criteria or update order details
Tool sequence:
SQUARE_LIST_LOCATIONS- Get location IDs for filtering [Prerequisite]SQUARE_SEARCH_ORDERS- Search orders with filters [Required]SQUARE_RETRIEVE_ORDER- Get full details of a specific order [Optional]SQUARE_UPDATE_ORDER- Modify order state or details [Optional]
Key parameters:
location_ids: Array of location IDs to search within (required for search)query: Search filter object with date ranges, states, fulfillment typesorder_id: Specific order ID for retrieve/update operationscursor: Pagination cursor for search results
Pitfalls:
location_idsis required for SEARCH_ORDERS; get IDs from LIST_LOCATIONS first- Order states include: OPEN, COMPLETED, CANCELED, DRAFT
- UPDATE_ORDER requires the current
versionfield to prevent conflicts - Search results are paginated; follow
cursoruntil absent
3. Manage Locations
When to use: User wants to view business locations or get location details
Tool sequence:
SQUARE_LIST_LOCATIONS- List all business locations [Required]
Key parameters:
- No required parameters; returns all accessible locations
- Response includes
id,name,address,status,timezone
Pitfalls:
- Location IDs are required for most other Square operations (orders, payments)
- Always cache location IDs after first retrieval to avoid redundant calls
- Inactive locations may still appear in results; check
statusfield
4. Invoice Management
When to use: User wants to list, view, or cancel invoices
Tool sequence:
SQUARE_LIST_LOCATIONS- Get location ID for filtering [Prerequisite]SQUARE_LIST_INVOICES- List invoices for a location [Required]SQUARE_GET_INVOICE- Get detailed invoice information [Optional]SQUARE_CANCEL_INVOICE- Cancel a scheduled or unpaid invoice [Optional]
Key parameters:
location_id: Required for listing invoicesinvoice_id: Required for get/cancel operationscursor: Pagination cursor for list resultslimit: Number of results per page
Pitfalls:
location_idis required for LIST_INVOICES; resolve via LIST_LOCATIONS first- Only SCHEDULED, UNPAID, or PARTIALLY_PAID invoices can be cancelled
- CANCEL_INVOICE requires the invoice
versionto prevent race conditions - Cancelled invoices cannot be uncancelled
Common Patterns
ID Resolution
Location name -> Location ID:
1. Call SQUARE_LIST_LOCATIONS
2. Find location by name in response
3. Extract id field (e.g., 'L1234ABCD')
Order lookup:
1. Call SQUARE_SEARCH_ORDERS with location_ids and query filters
2. Extract order_id from results
3. Use order_id for RETRIEVE_ORDER or UPDATE_ORDER
Pagination
- Check response for
cursorfield - Pass cursor value in next request's
cursorparameter - Continue until
cursoris absent or empty - Use
limitto control page size
Date Range Filtering
- Use RFC 3339 format:
2024-01-01T00:00:00Z - For payments:
begin_timeandend_timeparameters - For orders: Use query filter with date_time_filter
- All timestamps are in UTC
Known Pitfalls
ID Formats:
- Location IDs are alphanumeric strings (e.g., 'L1234ABCD')
- Payment IDs and Order IDs are longer alphanumeric strings
- Always resolve location names to IDs before other operations
Versioning:
- UPDATE_ORDER and CANCEL_INVOICE require current
versionfield - Fetch the resource first to get its current version
- Version mismatch returns a 409 Conflict error
Rate Limits:
- Square API has per-endpoint rate limits
- Implement backoff for bulk operations
- Pagination should include brief delays for large datasets
Response Parsing:
- Responses may nest data under
datakey - Money amounts are in smallest currency unit (cents for USD)
- Parse defensively with fallbacks for optional fields
Quick Reference
| Task | Tool Slug | Key Params |
|---|---|---|
| List payments | SQUARE_LIST_PAYMENTS | begin_time, end_time, location_id, cursor |
| Cancel payment | SQUARE_CANCEL_PAYMENT | payment_id |
| Search orders | SQUARE_SEARCH_ORDERS | location_ids, query, cursor |
| Get order | SQUARE_RETRIEVE_ORDER | order_id |
| Update order | SQUARE_UPDATE_ORDER | order_id, version |
| List locations | SQUARE_LIST_LOCATIONS | (none) |
| List invoices | SQUARE_LIST_INVOICES | location_id, cursor |
| Get invoice | SQUARE_GET_INVOICE | invoice_id |
| Cancel invoice | SQUARE_CANCEL_INVOICE | invoice_id, version |
Powered by Composio
Source
git clone https://github.com/davepoon/buildwithclaude/blob/main/plugins/all-skills/skills/square-automation/SKILL.mdView on GitHub Overview
Automate Square payment processing, order management, and invoicing through Composio's Square toolkit via Rube MCP. This integration covers payments, orders, locations, and invoices to streamline operations with up-to-date tool schemas.
How This Skill Works
The workflow begins by querying current tool schemas with RUBE_SEARCH_TOOLS, then establishing a connection to Square via RUBE_MANAGE_CONNECTIONS and completing OAuth if needed. Core workflows invoke Square tools in sequence (e.g., LIST_PAYMENTS, LIST_LOCATIONS, SEARCH_ORDERS, LIST_INVOICES) to fetch data, with optional retrieve, update, or cancel actions as required.
When to Use It
- View payment history or check payment status for a date range
- Find orders by criteria (location, date, state) and update order details
- View all business locations or fetch details for a specific location
- List, view, or cancel invoices for a chosen location
- Validate and refresh the Square connection and tool schemas before heavy operations
Quick Start
- Step 1: Get Rube MCP by adding https://rube.app/mcp as an MCP server in your client configuration
- Step 2: Verify availability by ensuring RUBE_SEARCH_TOOLS responds
- Step 3: Call RUBE_MANAGE_CONNECTIONS with toolkit square; if not ACTIVE, complete OAuth and confirm ACTIVE before workflows
Best Practices
- Always run RUBE_SEARCH_TOOLS first to get current schemas
- Cache location IDs after LIST_LOCATIONS to minimize calls
- Use RFC 3339 timestamps (begin_time/end_time) and pagination with cursor
- Only cancel pending or unfulfilled items; verify status before action
- Ensure RUBE_MANAGE_CONNECTIONS shows ACTIVE before running workflows
Example Use Cases
- Reconcile daily payments for a specific location by listing payments with SQUARE_LIST_PAYMENTS and filtering by time range
- Search for orders by location and date, then retrieve full order details with SQUARE_RETRIEVE_ORDER and update state via SQUARE_UPDATE_ORDER
- Fetch all locations to compare statuses and prepare for location-based reporting
- List invoices for a location, view details with SQUARE_GET_INVOICE, and cancel an unpaid invoice with SQUARE_CANCEL_INVOICE
- Onboard a new Square location by configuring the Rube MCP connection and validating ACTIVE status before processing orders or payments
Frequently Asked Questions
Related Skills
shopify-automation
davepoon/buildwithclaude
Automate Shopify tasks via Rube MCP (Composio): products, orders, customers, inventory, collections. Always search tools first for current schemas.
stripe-automation
davepoon/buildwithclaude
Automate Stripe tasks via Rube MCP (Composio): customers, charges, subscriptions, invoices, products, refunds. Always search tools first for current schemas.