gift-card-balance-report
Purpose
Queries all active and partially-redeemed gift cards and reports the total outstanding gift card liability (unredeemed balances). Used for balance sheet reporting, accounting for deferred revenue, and auditing unused gift cards before they expire. Read-only — no mutations.
Prerequisites
- Authenticated Shopify CLI session:
shopify store auth --store <domain> --scopes read_gift_cards - API scopes:
read_gift_cards
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| store | string | yes | — | Store domain (e.g., mystore.myshopify.com) |
| status | string | no | enabled | Filter by status: enabled, disabled, or all |
| expiring_within_days | integer | no | 30 | Flag gift cards expiring within this many days |
| format | string | no | human | Output format: human or json |
Safety
ℹ️ Read-only skill — no mutations are executed. Safe to run at any time.
Workflow Steps
-
OPERATION:
giftCards— query Inputs:query: "status:<status>",first: 250, pagination cursor Expected output: All matching gift cards withbalance,initialValue,expiresOn,lastCharacter,usedOn; paginate untilhasNextPage: false -
Flag cards expiring within
expiring_within_days -
Aggregate: total outstanding balance (liability), count by status, total initial value issued
GraphQL Operations
# giftCards:query — validated against api_version 2025-01
query GiftCardBalances($query: String, $after: String) {
giftCards(first: 250, after: $after, query: $query) {
edges {
node {
id
balance {
amount
currencyCode
}
initialValue {
amount
currencyCode
}
enabled
expiresOn
createdAt
lastCharacters
customer {
id
displayName
defaultEmailAddress {
emailAddress
}
}
}
}
pageInfo {
hasNextPage
endCursor
}
}
}
Session Tracking
Claude MUST emit the following output at each stage. This is mandatory.
On start, emit:
╔══════════════════════════════════════════════╗
║ SKILL: Gift Card Balance Report ║
║ Store: <store domain> ║
║ Started: <YYYY-MM-DD HH:MM UTC> ║
╚══════════════════════════════════════════════╝
After each step, emit:
[N/TOTAL] <QUERY|MUTATION> <OperationName>
→ Params: <brief summary of key inputs>
→ Result: <count or outcome>
On completion, emit:
For format: human (default):
══════════════════════════════════════════════
GIFT CARD BALANCE REPORT
Active gift cards: <n>
Total outstanding balance: $<amount> (liability)
Total initial value issued: $<amount>
Redeemed to date: $<amount>
Expiring in <n> days: <n> cards ($<amount>)
Output: gift_card_balances_<date>.csv
══════════════════════════════════════════════
For format: json, emit:
{
"skill": "gift-card-balance-report",
"store": "<domain>",
"active_count": 0,
"total_outstanding_balance": 0,
"total_initial_value": 0,
"currency": "USD",
"expiring_soon_count": 0,
"expiring_soon_value": 0,
"output_file": "gift_card_balances_<date>.csv"
}
Output Format
CSV file gift_card_balances_<YYYY-MM-DD>.csv with columns:
gift_card_id, last_characters, status, initial_value, balance, currency, created_at, expires_on, customer_email, expiring_soon
Error Handling
| Error | Cause | Recovery |
|---|---|---|
THROTTLED |
API rate limit exceeded | Wait 2 seconds, retry up to 3 times |
| No gift cards | Store hasn't issued any | Exit with 0 total liability |
| Gift card with no customer | Issued without customer account | Show as "Anonymous" |
Best Practices
- The total outstanding balance is a deferred revenue liability on your balance sheet — include it in monthly financial close.
- Gift cards expiring within
expiring_within_daysrepresent imminent liability reduction — no action needed, but useful for forecasting. - For high-value outstanding balances, cross-reference with
customer-spend-tier-taggerto target high-balance card holders with reminder campaigns. - Pair with
gift-card-issuance(conversion-optimization skill) to track cards issued vs. redeemed over time.
More from 40rty-ai/shopify-admin-skills
shopify-admin-skills
Master skill collection for Shopify store operators. Provides access to all merchandising, marketing, support, and operations capabilities.
149shopify-store-skills
A brief description of what this skill does
16shopify-admin-variant-option-normalizer
Detects inconsistent variant option naming (Sm vs Small vs S) and bulk-corrects to a standard set.
5shopify-admin-discount-hygiene-cleanup
Finds expired, zero-usage, or duplicate discount codes and optionally deactivates or deletes them.
5shopify-admin-gift-card-issuance
Issue Shopify gift cards (store credit) to customers as a goodwill gesture, post-return incentive, or loyalty reward.
5shopify-admin-fulfillment-status-digest
Generate a daily fulfillment triage digest: all open orders segmented by fulfillment age and flagged for holds or exceptions.
5