AgentStack
SKILL verified MIT Self-run

Shopify Admin Order Cancellation Analysis

skill-40rty-ai-shopify-admin-skills-shopify-admin-order-cancellation-analysis · by 40RTY-ai

Read-only: tracks cancellation rate over time and breaks down cancelled orders by cancelReason to surface fraud, inventory, customer, and declined-payment patterns.

No reviews yet
0 installs
0 views
view→install

Install

$ agentstack add skill-40rty-ai-shopify-admin-skills-shopify-admin-order-cancellation-analysis

✓ scanned · ✓ verified — works with Claude Code, Cursor, and more.

Security review

✓ Passed

No issues found. Passed automated security review. · v0.1.0 How review works →

  • Prompt-injection patterns
  • Secret / credential exfiltration
  • Dangerous shell & filesystem operations
  • Untrusted network calls
  • Known-malicious package signatures
Are you the author of Shopify Admin Order Cancellation Analysis? Claim this listing to set pricing, connect Stripe payouts, and keep 70% of every sale.

About

Purpose

Computes cancellation rate (cancelled orders / total orders) over a configurable window, broken down by cancelReason (CUSTOMER, FRAUD, INVENTORY, DECLINED, OTHER, STAFF). Surfaces shifts in cancellation patterns — for example, a spike in INVENTORY cancellations suggests a stock data integrity problem, while a spike in FRAUD suggests a coordinated attack. Read-only — no mutations.

Prerequisites

  • Authenticated Shopify CLI session: shopify store auth --store --scopes read_orders
  • API scopes: read_orders

Parameters

| Parameter | Type | Required | Default | Description | |-----------|------|----------|---------|-------------| | store | string | yes | — | Store domain (e.g., mystore.myshopify.com) | | daysback | integer | no | 30 | Lookback window for orders included in the analysis | | bucket | string | no | day | Time bucket: day, week, or month | | minvalue | float | no | 0 | Only include orders above this total value | | reason_filter | string | no | — | Optional filter to a single cancelReason | | format | string | no | human | Output format: human or json |

Safety

> ℹ️ Read-only skill — no mutations are executed. Safe to run at any time. The analysis uses cancelReason as recorded by Shopify or staff at cancellation time — accuracy depends on staff selecting the correct reason.

Workflow Steps

  1. OPERATION: orders — query

Inputs: query: "created_at:>=''", first: 250, select cancelledAt, cancelReason, displayFinancialStatus, totalPriceSet, pagination cursor Expected output: All orders created in the window (cancelled and non-cancelled) for rate calculation; paginate until hasNextPage: false

  1. Partition orders into cancelled (cancelledAt != null) and not cancelled. Compute overall rate = cancelled / total.
  1. For cancelled orders, group by cancelReason and by time bucket. Compute rate per bucket and per reason.
  1. Identify time buckets where any single reason exceeds 2x its trailing 7-bucket average — flag as anomalies.

GraphQL Operations

# orders:query — validated against api_version 2025-01
query OrdersForCancellationAnalysis($query: String!, $after: String) {
  orders(first: 250, after: $after, query: $query) {
    edges {
      node {
        id
        name
        createdAt
        cancelledAt
        cancelReason
        displayFinancialStatus
        displayFulfillmentStatus
        totalPriceSet {
          shopMoney {
            amount
            currencyCode
          }
        }
        customer {
          id
          numberOfOrders
        }
        staffMember {
          id
          name
        }
      }
    }
    pageInfo {
      hasNextPage
      endCursor
    }
  }
}

Session Tracking

Claude MUST emit the following output at each stage. This is mandatory.

On start, emit:

╔══════════════════════════════════════════════╗
║  SKILL: Order Cancellation Analysis          ║
║  Store:                        ║
║  Started:              ║
╚══════════════════════════════════════════════╝

After each step, emit:

[N/TOTAL]   
          → Params: 
          → Result: 

On completion, emit:

For format: human (default):

══════════════════════════════════════════════
CANCELLATION ANALYSIS  ( days, by )
  Total orders:        
  Cancelled orders:      (%)
  Lost revenue:        $

  By reason:
    CUSTOMER       (%)
    FRAUD          (%)
    INVENTORY      (%)
    DECLINED       (%)
    OTHER          (%)

  Anomaly buckets (>2x trailing avg):
      reason=  rate=%
  Output: cancellation_analysis_.csv
══════════════════════════════════════════════

For format: json, emit:

{
  "skill": "order-cancellation-analysis",
  "store": "",
  "period_days": 30,
  "bucket": "day",
  "total_orders": 0,
  "cancelled_orders": 0,
  "cancellation_rate": 0,
  "lost_revenue": 0,
  "currency": "USD",
  "by_reason": {
    "CUSTOMER": 0, "FRAUD": 0, "INVENTORY": 0, "DECLINED": 0, "OTHER": 0
  },
  "anomalies": [],
  "output_file": "cancellation_analysis_.csv"
}

Output Format

CSV file cancellation_analysis_.csv with columns: bucket_start, bucket_end, total_orders, cancelled_orders, rate_pct, reason_customer, reason_fraud, reason_inventory, reason_declined, reason_other, lost_revenue, currency

Error Handling

| Error | Cause | Recovery | |-------|-------|----------| | THROTTLED | API rate limit exceeded | Wait 2 seconds, retry up to 3 times | | cancelReason is null on cancelled order | Older order pre-dating reason field | Bucket into OTHER, log count | | No orders in window | Empty store or test domain | Exit with summary: 0 orders, 0% rate | | Cancelled order created outside window | Cancellation happened in window but order older | Excluded by design — analyses creation cohort |

Best Practices

  • A baseline cancellation rate of 1–3% is typical; spikes above 5% warrant investigation.
  • Sustained INVENTORY cancellations indicate a sync issue between storefront stock and warehouse — pair this skill with multi-location-inventory-audit.
  • Sustained FRAUD cancellations indicate either improving fraud filters (good) or a coordinated attack (bad) — cross-reference with order-risk-report.
  • High DECLINED rates often correlate with checkout friction or expired payment methods — investigate alongside checkout abandonment data.
  • Run weekly to catch reason-mix shifts early; run after every major promotion to confirm cancellations did not spike.

Source & license

This open-source skill is cataloged on AgentStack and links to its original source — we do not rehost the code.

Install and usage instructions live in the source repository linked above.

Reviews

No reviews yet — be the first.

Versions

  • v0.1.0 Imported from the upstream source.