Back to Skill Hub
Download Skill Package

System Prompt / Instructions

Square Automation via Rube MCP

Automate Square payment processing, order management, and invoicing through Composio's Square toolkit via Rube MCP.

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

| 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 |

Frequently Asked Questions

What is square-automation?

square-automation is an expert AI persona designed to improve your coding workflow. Automate Square tasks via Rube MCP (Composio): payments, orders, invoices, locations. Always search tools first for current schemas. It provides senior-level context directly within your IDE.

How do I install the square-automation skill in Cursor or Windsurf?

To install the square-automation skill, download the package, extract the files to your project's .cursor/skills directory, and type @square-automation in your editor chat to activate the expert instructions.

Is square-automation free to download?

Yes, the square-automation AI persona is completely free to download and integrate into compatible Agentic IDEs like Cursor, Windsurf, Github Copilot, and Anthropic MCP servers.

@

square-automation

Automate Square tasks via Rube MCP (Composio): payments, orders, invoices, locations. Always search tools first for current schemas.

Download Skill Package

IDE Invocation

@square-automation
COPY

Platform

IDE Native

Price

Free Download

Setup Instructions

Cursor & Windsurf

  1. Download the zip file above.
  2. Extract to .cursor/skills
  3. Type @square-automation in editor chat.

Copilot & ChatGPT

Copy the instructions from the panel on the left and paste them into your custom instructions setting.

"Adding this square-automation persona to my Cursor workspace completely changed the quality of code my AI generates. Saves me hours every week."

A
Alex Dev
Senior Engineer, TechCorp