AgentStack
SKILL verified MIT Self-run

Shopify Admin Publication Channel Audit

skill-40rty-ai-shopify-admin-skills-shopify-admin-publication-channel-audit · by 40RTY-ai

Read-only: shows which products are published to which sales channels and flags unpublished active products.

No reviews yet
0 installs
1 views
0.0% view→install

Install

$ agentstack add skill-40rty-ai-shopify-admin-skills-shopify-admin-publication-channel-audit

✓ 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 Publication Channel Audit? Claim this listing to set pricing, connect Stripe payouts, and keep 70% of every sale.

About

Purpose

Queries all active products and the publications (sales channels) they are visible on. Flags products that are active but missing from key channels (e.g., Online Store, Google Shopping, Meta). Prevents silent revenue loss from products that exist in the catalog but are invisible on sales channels. Read-only — no mutations.

Prerequisites

  • Authenticated Shopify CLI session: shopify store auth --store --scopes read_products,read_publications
  • API scopes: read_products, read_publications

Parameters

| Parameter | Type | Required | Default | Description | |-----------|------|----------|---------|-------------| | store | string | yes | — | Store domain (e.g., mystore.myshopify.com) | | required_channels | array | no | ["Online Store"] | Channel names that all active products should be on | | 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

  1. OPERATION: publications — query

Inputs: first: 50 Expected output: All available publications (sales channels) with id, name

  1. OPERATION: products — query

Inputs: query: "status:active", first: 250, select publishedOnCurrentPublication, resourcePublications { publication { name } }, pagination cursor Expected output: Active products with their channel publication status

  1. For each product: check if it appears in each required_channels — flag if missing from any

GraphQL Operations

# publications:query — validated against api_version 2025-01
query SalesChannels {
  publications(first: 50) {
    edges {
      node {
        id
        name
        supportsFuturePublishing
        app {
          title
        }
      }
    }
  }
}
# products:query — validated against api_version 2025-01
query ProductPublications($after: String) {
  products(first: 250, after: $after, query: "status:active") {
    edges {
      node {
        id
        title
        handle
        status
        resourcePublications(first: 20) {
          edges {
            node {
              publication {
                id
                name
              }
              publishDate
              isPublished
            }
          }
        }
      }
    }
    pageInfo {
      hasNextPage
      endCursor
    }
  }
}

Session Tracking

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

On start, emit:

╔══════════════════════════════════════════════╗
║  SKILL: Publication Channel Audit            ║
║  Store:                        ║
║  Started:              ║
╚══════════════════════════════════════════════╝

After each step, emit:

[N/TOTAL]   
          → Params: 
          → Result: 

On completion, emit:

For format: human (default):

══════════════════════════════════════════════
PUBLICATION CHANNEL AUDIT
  Active products:          
  Sales channels found:     
  Products missing channels: 

  Missing from "Online Store":
    ""  ()
  Output: publication_audit_.csv
══════════════════════════════════════════════

For format: json, emit:

{
  "skill": "publication-channel-audit",
  "store": "",
  "active_products": 0,
  "channels_found": 0,
  "missing_channel_count": 0,
  "output_file": "publication_audit_.csv"
}

Output Format

CSV file publication_audit_.csv with columns: product_id, title, handle, channel_name, is_published, publish_date, issue

Error Handling

| Error | Cause | Recovery | |-------|-------|----------| | THROTTLED | API rate limit exceeded | Wait 2 seconds, retry up to 3 times | | Channel not found | Required channel not installed or renamed | Report channel as missing in summary | | No active products | Empty catalog | Exit with 0 results |

Best Practices

  • Run after any bulk product import — products are not always published to all channels by default.
  • For multi-channel stores, add all critical channels to required_channels to catch products missing from any of them.
  • Products unpublished from a channel may be intentional (e.g., wholesale-only items) — review the flagged list before publishing.
  • Pair with product-data-completeness-score — products with low data completeness scores should be fixed before being published to additional channels.

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.