Get the FREE Ultimate OpenClaw Setup Guide →

square-automation

Scanned
npx machina-cli add skill davepoon/buildwithclaude/square-automation --openclaw
Files (1)
SKILL.md
6.5 KB

Square 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_CONNECTIONS with toolkit square
  • 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 square
  3. If connection is not ACTIVE, follow the returned auth link to complete Square OAuth
  4. 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:

  1. SQUARE_LIST_PAYMENTS - Retrieve payments with optional filters [Required]
  2. SQUARE_CANCEL_PAYMENT - Cancel a pending payment if needed [Optional]

Key parameters:

  • begin_time / end_time: RFC 3339 timestamps for date range filtering
  • sort_order: 'ASC' or 'DESC' for chronological ordering
  • cursor: Pagination cursor from previous response
  • location_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 cursor until absent
  • Only pending payments can be cancelled; completed payments require refunds
  • SQUARE_CANCEL_PAYMENT requires exact payment_id from list results

2. Search and Manage Orders

When to use: User wants to find orders by criteria or update order details

Tool sequence:

  1. SQUARE_LIST_LOCATIONS - Get location IDs for filtering [Prerequisite]
  2. SQUARE_SEARCH_ORDERS - Search orders with filters [Required]
  3. SQUARE_RETRIEVE_ORDER - Get full details of a specific order [Optional]
  4. 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 types
  • order_id: Specific order ID for retrieve/update operations
  • cursor: Pagination cursor for search results

Pitfalls:

  • location_ids is required for SEARCH_ORDERS; get IDs from LIST_LOCATIONS first
  • Order states include: OPEN, COMPLETED, CANCELED, DRAFT
  • UPDATE_ORDER requires the current version field to prevent conflicts
  • Search results are paginated; follow cursor until absent

3. Manage Locations

When to use: User wants to view business locations or get location details

Tool sequence:

  1. 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 status field

4. Invoice Management

When to use: User wants to list, view, or cancel invoices

Tool sequence:

  1. SQUARE_LIST_LOCATIONS - Get location ID for filtering [Prerequisite]
  2. SQUARE_LIST_INVOICES - List invoices for a location [Required]
  3. SQUARE_GET_INVOICE - Get detailed invoice information [Optional]
  4. SQUARE_CANCEL_INVOICE - Cancel a scheduled or unpaid invoice [Optional]

Key parameters:

  • location_id: Required for listing invoices
  • invoice_id: Required for get/cancel operations
  • cursor: Pagination cursor for list results
  • limit: Number of results per page

Pitfalls:

  • location_id is required for LIST_INVOICES; resolve via LIST_LOCATIONS first
  • Only SCHEDULED, UNPAID, or PARTIALLY_PAID invoices can be cancelled
  • CANCEL_INVOICE requires the invoice version to 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 cursor field
  • Pass cursor value in next request's cursor parameter
  • Continue until cursor is absent or empty
  • Use limit to control page size

Date Range Filtering

  • Use RFC 3339 format: 2024-01-01T00:00:00Z
  • For payments: begin_time and end_time parameters
  • 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 version field
  • 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 data key
  • Money amounts are in smallest currency unit (cents for USD)
  • Parse defensively with fallbacks for optional fields

Quick Reference

TaskTool SlugKey Params
List paymentsSQUARE_LIST_PAYMENTSbegin_time, end_time, location_id, cursor
Cancel paymentSQUARE_CANCEL_PAYMENTpayment_id
Search ordersSQUARE_SEARCH_ORDERSlocation_ids, query, cursor
Get orderSQUARE_RETRIEVE_ORDERorder_id
Update orderSQUARE_UPDATE_ORDERorder_id, version
List locationsSQUARE_LIST_LOCATIONS(none)
List invoicesSQUARE_LIST_INVOICESlocation_id, cursor
Get invoiceSQUARE_GET_INVOICEinvoice_id
Cancel invoiceSQUARE_CANCEL_INVOICEinvoice_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

  1. Step 1: Get Rube MCP by adding https://rube.app/mcp as an MCP server in your client configuration
  2. Step 2: Verify availability by ensuring RUBE_SEARCH_TOOLS responds
  3. 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

Add this skill to your agents

Related Skills

Sponsor this space

Reach thousands of developers