Install
$ agentstack add skill-40rty-ai-shopify-admin-skills-shopify-admin-shipping-rate-audit ✓ scanned · ✓ verified — works with Claude Code, Cursor, and more.
Security review
✓ PassedNo 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
About
Purpose
Audits the shipping configuration for every delivery profile on the store. Surfaces (a) zones with zero shipping rates configured (causing checkout failures), (b) zones with only manual flat rates (no carrier-calculated rates, often a missed setup step), and (c) profiles with no zone coverage for known sales geographies. A misconfigured zone silently drops checkout conversions — this skill catches it before customers do. Read-only — no mutations.
Prerequisites
- Authenticated Shopify CLI session:
shopify store auth --store --scopes read_shipping - API scopes:
read_shipping
Parameters
| Parameter | Type | Required | Default | Description | |-----------|------|----------|---------|-------------| | store | string | yes | — | Store domain (e.g., mystore.myshopify.com) | | profilefilter | string | no | — | Optional delivery profile name to scope the audit | | flagmanualonly | bool | no | true | Flag zones that have only manual rates (no carrier-calculated rates) | | flaghigh_price | float | no | — | Optional: flag any rate above this price (likely typo or stale) | | format | string | no | human | Output format: human or json |
Safety
> ℹ️ Read-only skill — no mutations are executed. Safe to run at any time. The skill reads delivery configuration only; it does not change any shipping behavior.
Workflow Steps
- OPERATION:
deliveryProfiles— query
Inputs: first: 50, select profileLocationGroups, profileItems, name, default, pagination cursor Expected output: All delivery profiles, including the default, with location groups and product associations; paginate until hasNextPage: false
- For each profile, walk every
profileLocationGroups[].locationGroupZones. For each zone, capture: zone name, country codes, method definitions (rates).
- Flag zones with: zero
methodDefinitions, OR only manualpriceConditions-based rates (no carrier-calculated method whenflag_manual_only: true), OR a method whoseprice.amount > flag_high_priceif the threshold is set.
- Aggregate findings per profile, then build a global summary of misconfigured zones across the store.
GraphQL Operations
# deliveryProfiles:query — validated against api_version 2025-01
query DeliveryProfilesAudit($after: String) {
deliveryProfiles(first: 50, after: $after) {
edges {
node {
id
name
default
profileItems(first: 1) {
edges {
node {
id
}
}
}
profileLocationGroups {
locationGroup {
id
locations(first: 50) {
edges {
node {
id
name
address {
countryCode
}
}
}
}
}
locationGroupZones(first: 50) {
edges {
node {
zone {
id
name
countries {
code {
countryCode
}
provinces {
code
}
}
}
methodDefinitions(first: 50) {
edges {
node {
id
name
active
rateProvider {
__typename
... on DeliveryRateDefinition {
price {
amount
currencyCode
}
}
... on DeliveryParticipant {
carrierService {
id
name
}
fixedFee {
amount
currencyCode
}
percentageOfRateFee
}
}
}
}
}
}
}
}
}
}
}
pageInfo {
hasNextPage
endCursor
}
}
}
Session Tracking
Claude MUST emit the following output at each stage. This is mandatory.
On start, emit:
╔══════════════════════════════════════════════╗
║ SKILL: Shipping Rate Audit ║
║ Store: ║
║ Started: ║
╚══════════════════════════════════════════════╝
After each step, emit:
[N/TOTAL]
→ Params:
→ Result:
On completion, emit:
For format: human (default):
══════════════════════════════════════════════
SHIPPING RATE AUDIT
Profiles inspected:
Zones inspected:
Zones with no rates:
Zones manual-only:
Rates above threshold:
Critical issues (zero-rate zones):
Profile: Zone: Countries:
Output: shipping_rate_audit_.csv
══════════════════════════════════════════════
For format: json, emit:
{
"skill": "shipping-rate-audit",
"store": "",
"profiles_inspected": 0,
"zones_inspected": 0,
"zones_no_rates": 0,
"zones_manual_only": 0,
"rates_above_threshold": 0,
"issues": [],
"output_file": "shipping_rate_audit_.csv"
}
Output Format
CSV file shipping_rate_audit_.csv with columns: profile_name, zone_name, countries, rate_count, manual_rate_count, carrier_rate_count, min_rate, max_rate, currency, flag
Error Handling
| Error | Cause | Recovery | |-------|-------|----------| | THROTTLED | API rate limit exceeded | Wait 2 seconds, retry up to 3 times | | Profile has no products | Empty profile | Note in output, do not flag as critical | | Zone has only DeliveryRateDefinition (no carrier) | Manual rates only | Flag if flag_manual_only: true | | Country list is null on a zone | Rest-of-world catch-all zone | Treat as wildcard, do not flag for missing countries |
Best Practices
- Run after any major shipping change (new region launch, carrier switch) to confirm zone coverage matches the rollout plan.
- Zero-rate zones cause silent checkout failures — customers from that geography see "no shipping available" and abandon. Treat these as P0.
- Manual-only zones are not always wrong — flat-rate domestic shipping is a deliberate choice. Use
flag_manual_only: falseif your store is intentionally flat-rate. - Cross-reference flagged country codes with
customers:queryfiltered by country to estimate revenue at risk. - Run quarterly to catch zones added by app integrations or staff that drift from the documented configuration.
Source & license
This open-source skill is cataloged on AgentStack and links to its original source — we do not rehost the code.
- Author: 40RTY-ai
- Source: 40RTY-ai/shopify-admin-skills
- License: MIT
- Homepage: http://skills.40rty.ai
Install and usage instructions live in the source repository linked above.
Reviews
No reviews yet — be the first.
Write a review
Versions
- v0.1.0 Imported from the upstream source.