shopify-mcp
Provides comprehensive Shopify Admin API integration with tools for product management, inventory control, order fulfillment, customer management, collections, webhooks, metafields, draft orders, and analytics through ShopifyQL queries.
shopify-mcp
MCP server for Shopify — Admin API tooling plus AI-driven product creation via ComfyUI image generation.
Part of the MCP Server Series.
The pitch
Every other Shopify MCP is a plain Admin API wrapper. This one pairs with @miller-joe/comfyui-mcp so you can say things like:
"Create a product called 'Nebula Dreamer' — generate a cosmic abstract image for it, description matching the vibe, tagged astrology, status draft."
...and Claude runs ComfyUI → gets an image → creates the Shopify product → attaches the image, in one call.
Install
# npx — no install
npx @miller-joe/shopify-mcp \
--shopify-store your-store.myshopify.com \
--shopify-access-token shpat_xxx
# Docker
docker run -p 9110:9110 \
-e SHOPIFY_STORE=your-store.myshopify.com \
-e SHOPIFY_ACCESS_TOKEN=shpat_xxx \
-e COMFYUI_URL=http://comfyui:8188 \
ghcr.io/miller-joe/shopify-mcp:latestConnect an MCP client
claude mcp add --transport http shopify http://localhost:9110/mcpOr point your MCP gateway at the Streamable HTTP endpoint.
Configuration
CLI flag | Env var | Default | Notes |
|
| (required) |
|
|
| (required) | Admin API token ( |
|
|
| GraphQL Admin API version |
|
|
| Bind host |
|
|
| Bind port |
|
| (optional) | Enables bridge tools when set |
|
| same as | External URL used for image references passed to Shopify |
— |
|
| Default checkpoint for bridge tools |
Getting a Shopify access token
Easy path (existing dev store): Shopify Admin → Apps → Develop apps → Create custom app → enable relevant Admin API scopes (write_products, read_orders, write_inventory, read_customers) → install → copy the admin API access token (starts with shpat_).
For new apps (post-Jan 2026): legacy custom-app tokens are deprecated for freshly-created apps. Use the Dev Dashboard → token-exchange flow once to obtain a working token, then supply it here. Multi-tenant OAuth is on the roadmap (v0.2).
Tools
Core Admin
Tool | Description |
| Paginated product search with Shopify query syntax |
| Fetch one product with variants, images, media |
| Create a product (default DRAFT); optionally attach images |
| Update title, description, tags, status, etc. |
| Attach a public image URL to an existing product |
| List orders, newest first, with query filters |
| Fetch one order with line items |
| Set absolute on-hand inventory at a location |
| List store locations (for inventory ops) |
| List customers with query filters |
Metafields
Tool | Description |
| Upsert a metafield on any |
| List metafields for a resource, optionally filtered by namespace |
| Delete a metafield by (ownerId, namespace, key) |
Draft orders
Tool | Description |
| List draft orders with Shopify query filters |
| Fetch one draft order with its line items |
| Create a draft order; line items can be variant refs or custom (title + price) |
| Update customer, line items, tags, note, email |
| Convert a draft order to a real order; |
| Delete a non-completed draft order |
Webhooks
Tool | Description |
| List webhook subscriptions; filter by topic(s) |
| Fetch a single subscription |
| Subscribe an HTTPS callback URL to a topic (e.g. |
| Change callback URL, format, or field/metafield filters |
| Delete a subscription |
Metaobjects
Tool | Description |
| Discover metaobject types (schemas) on the store, including field definitions |
| List metaobjects of a given type |
| Fetch one metaobject with all its fields |
| Create a metaobject (type must already exist as a definition); supports |
| Upsert fields, change handle, toggle publishable status |
| Delete a metaobject |
Fulfillment
Tool | Description |
| List an order's fulfillment orders (one per shipping location), with remaining quantities per line item |
| Fetch a single fulfillment order |
| Fetch a single fulfillment (shipment record) with tracking info |
| Mark fulfillment orders (or specific quantities) as fulfilled; optionally attach tracking + notify customer |
| Update carrier/number/url on an existing fulfillment |
| Cancel a fulfillment by ID |
Partial fulfillment is supported — pass specific fulfillmentOrderLineItems with quantity per line; omit the array to fulfill everything on the fulfillment order.
Variants & product options
Tool | Description |
| List all variants of a product with their selected options, price, SKU, inventory |
| Bulk-create variants (up to 100) with option values, price, SKU, compareAtPrice, initial inventory |
| Bulk-update variant price, compareAtPrice, SKU, barcode, taxable, inventoryPolicy, option values |
| Bulk-delete variants from a product |
| Set 1-indexed positions for variants |
| Add options (Size/Color/…) with their possible values; up to 3 options per product |
For an entirely new product, creating the first real variant requires strategy="REMOVE_STANDALONE_VARIANT" to replace the auto-generated "Default Title" variant.
Collections & tagging
Tool | Description |
| List collections with query filters |
| Fetch one collection with its products |
| Create a manual collection, optionally seeded with products |
| Update title, description, or handle |
| Delete a collection |
| Add products to a manual collection (async job on Shopify's side) |
| Remove products from a manual collection |
| Add tags to any taggable resource (Product, Order, Customer, DraftOrder, Collection) |
| Remove tags from a taggable resource |
Analytics (ShopifyQL)
Tool | Description |
| Run a ShopifyQL query and render the result as an ASCII table. Pass |
Examples:
FROM sales SHOW total_sales BY day SINCE -30d TIMESERIESFROM products SHOW product_title, quantity_sold BY product_id SINCE -7d ORDER BY quantity_sold DESC LIMIT 10
ComfyUI bridge (when COMFYUI_URL is configured)
Tool | Description |
| Generate an image and create a product with it, in one call. Title/description derive from the prompt if not given. |
| Generate an image and attach it to an existing product. |
| Run img2img on a product's featured image (or an explicit URL) and attach the refined result. Tune |
| For all products matching a query, run the generator with a templated prompt and attach fresh images. |
Template placeholders for bulk_regenerate_images: {title}, {handle}.
Example — the whole pitch in one call
Claude, use generate_and_create_product:
prompt: "minimalist sunset mountain silhouette, warm gradient, vector style"
title: "Mountain Sunset Poster"
status: DRAFT
tags: ["posters", "nature", "minimalist"]Result: ComfyUI generates the image → Shopify product created with image attached → you get back the product ID and image URL. One prompt, one call, real listing.
Architecture
┌────────────────┐ ┌──────────────────┐ ┌─────────────────┐
│ MCP client │────▶│ shopify-mcp │────▶│ Shopify Admin │
│ (Claude etc.) │◀────│ (this server) │◀────│ GraphQL API │
└────────────────┘ └────────┬─────────┘ └─────────────────┘
│
│ (bridge tools only)
▼
┌──────────────────┐
│ ComfyUI │
│ (txt2img) │
└──────────────────┘Bridge tools call ComfyUI directly over HTTP, get an image URL, and pass it to Shopify's productCreateMedia mutation — Shopify fetches and hosts the image on its CDN.
Development
git clone https://github.com/miller-joe/shopify-mcp
cd shopify-mcp
npm install
npm run dev # hot reload via tsx watch
npm run build
npm run typecheck
npm testRequires Node 20+.
Roadmap
Core products CRUD + image attach
Orders read
Inventory set + locations
Customers read
ComfyUI bridge:
generate_and_create_product,generate_product_image,bulk_regenerate_imagesMetafields:
set_metafield,list_metafields,delete_metafieldDraft orders: create/update/complete/delete + list/get
Collections + tagging: CRUD, product add/remove,
add_tags/remove_tagsVariants + product options: bulk create/update/delete/reorder +
add_product_optionsFulfillment: list/get fulfillment orders, create fulfillment (partial supported), update tracking, cancel
Webhooks: list/get/create/update/delete subscriptions
Metaobjects: definitions list + metaobject CRUD (create, update, delete)
ShopifyQL analytics:
run_shopifyql_querywith ASCII-table renderingImage refinement bridge:
refine_product_image(ComfyUI img2img on product images)OAuth token-exchange flow for new-app auth
License
MIT © Joe Miller
Support
If this saves you time, consider supporting development:
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/miller-joe/shopify-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server