The most comprehensive MCP server for the Shopify GraphQL API
Shopify GraphQL MCP Server
A Model Context Protocol (MCP) server that provides comprehensive access to the Shopify Admin GraphQL API via cURL. This server exposes all major Shopify resources as MCP tools, allowing AI assistants like Claude to interact with your Shopify store programmatically.
🚧 Project Status: This project is currently in active development. New tools and features are being added regularly.
Created by: Students at Utah Valley University in Orem, UT
Prerequisites
- Node.js 18+
- npm or yarn
- A Shopify store with Admin API access
- Shopify Admin API access token
Installation
1. Clone or Create Project
git clone <repository-url>
cd shopify-graphql-mcp
2. Install Dependencies
npm install
3. Build the Server
npm run build
Configuration
Environment Variables
Create a .env file or set these environment variables:
SHOPIFY_ACCESS_TOKEN=shpat_xxxxx
SHOPIFY_STORE_URL=your-store.myshopify.com
SHOPIFY_STORE_API_URL=https://your-store.myshopify.com/admin/api/2025-01/graphql.json
Tool Categories (Recommended for IDE Compatibility)
This MCP server provides 150+ tools covering all Shopify operations. Some IDEs have limits on tool counts, so you can enable/disable tool categories via the ENABLED_TOOL_CATEGORIES environment variable:
| Category | Description | ~Tool Count | Modules |
|----------|-------------|-------------|---------|
| essential | Core e-commerce: products, orders, customers, inventory | ~35 | shop, products, orders, customers, inventory, collections, locations, draft-orders, discounts, fulfillments |
| commerce | Extended commerce: gift cards, returns, checkouts, B2B | ~25 | gift-cards, returns, checkouts, payment-terms, order-edits, companies, cash-tracking, fulfillment-constraints, delivery-customizations, delivery-option-generators, custom-fulfillment-services |
| marketing | Marketing: campaigns, markets, analytics, channels | ~20 | marketing-campaigns, markets, channels, discovery, price-rules, analytics, pixels, publications |
| content | Content: pages, themes, files, metaobjects | ~25 | pages, navigation, themes, files, metaobjects, translations, locales, legal-policies |
| advanced | Advanced: cart transforms, validations, scripts | ~20 | cart-transforms, validations, audit-events, custom-pixels, script-tags, customer-data-erasure, customer-merge, customer-payment-methods, privacy-settings, shipping, product-listings |
| reporting | Reports and feedback | ~15 | reports, resource-feedbacks, apps |
| automation | Inventory automation | ~15 | inventory-shipments, inventory-transfers, packing-slip-templates |
Recommended configurations:
// Minimal - Essential only (~35 tools) - Best for most users
{
"env": {
"ENABLED_TOOL_CATEGORIES": "essential"
}
}
// Standard - Essential + Commerce (~60 tools)
{
"env": {
"ENABLED_TOOL_CATEGORIES": "essential,commerce"
}
}
// Marketing Focus - Essential + Marketing (~55 tools)
{
"env": {
"ENABLED_TOOL_CATEGORIES": "essential,marketing"
}
}
// Full Power User (~105 tools)
{
"env": {
"ENABLED_TOOL_CATEGORIES": "essential,commerce,marketing,content"
}
}
// Everything (~155 tools) - May overwhelm some IDEs
{
"env": {
"ENABLED_TOOL_CATEGORIES": "all"
}
}
Default behavior: If ENABLED_TOOL_CATEGORIES is not set, all categories are enabled (backward compatible).
IDE Compatibility:
- Cursor: ~100-150 tools recommended
- Claude Desktop: ~200+ tools supported
- Zed: ~50-75 tools recommended
See TOOL_CATEGORIES.md for complete documentation.
Getting Your Access Token
Detailed OAuth Setup Instructions
- Go to Settings > Apps > Develop Apps > Build apps in Dev Dashboard
- Once in Dev Dashboard, click Create app and enter the app name (e.g., "Shopify GraphQL MCP"), then click Create
- Use
http://localhost:9292for the App URL - Add the following Scopes under Scopes > Access:
read_all_orders,read_analytics,read_app_proxy,write_app_proxy,read_apps,read_assigned_fulfillment_orders,write_assigned_fulfillment_orders,read_audit_events,read_customer_events,read_cart_transforms,write_cart_transforms,read_all_cart_transforms,read_validations,write_validations,read_cash_tracking,write_cash_tracking,read_channels,write_channels,read_checkout_branding_settings,write_checkout_branding_settings,write_checkouts,read_checkouts,read_companies,write_companies,read_custom_fulfillment_services,write_custom_fulfillment_services,read_custom_pixels,write_custom_pixels,read_customers,write_customers,read_customer_data_erasure,write_customer_data_erasure,read_customer_payment_methods,read_customer_merge,write_customer_merge,read_delivery_customizations,write_delivery_customizations,read_price_rules,write_price_rules,read_discounts,write_discounts,read_discounts_allocator_functions,write_discounts_allocator_functions,read_discovery,write_discovery,write_draft_orders,read_draft_orders,read_files,write_files,read_fulfillment_constraint_rules,write_fulfillment_constraint_rules,read_fulfillments,write_fulfillments,read_gift_card_transactions,write_gift_card_transactions,read_gift_cards,write_gift_cards,write_inventory,read_inventory,write_inventory_shipments,read_inventory_shipments,write_inventory_shipments_received_items,read_inventory_shipments_received_items,write_inventory_transfers,read_inventory_transfers,read_legal_policies,write_legal_policies,read_delivery_option_generators,write_delivery_option_generators,read_locales,write_locales,write_locations,read_locations,read_marketing_integrated_campaigns,write_marketing_integrated_campaigns,write_marketing_events,read_marketing_events,read_markets,write_markets,read_markets_home,write_markets_home,read_merchant_managed_fulfillment_orders,write_merchant_managed_fulfillment_orders,read_metaobject_definitions,write_metaobject_definitions,read_metaobjects,write_metaobjects,read_online_store_navigation,write_online_store_navigation,read_online_store_pages,write_online_store_pages,write_order_edits,read_order_edits,read_orders,write_orders,write_packing_slip_templates,read_packing_slip_templates,write_payment_mandate,read_payment_mandate,read_payment_terms,write_payment_terms,read_payment_customizations,write_payment_customizations,read_pixels,write_pixels,read_privacy_settings,write_privacy_settings,read_product_feeds,write_product_feeds,read_product_listings,write_product_listings,read_products,write_products,read_publications,write_publications,read_purchase_options,write_purchase_options,write_reports,read_reports,read_resource_feedbacks,write_resource_feedbacks,read_returns,write_returns,read_script_tags,write_script_tags,read_shopify_payments_provider_accounts_sensitive,read_shipping,write_shipping,read_shopify_payments_accounts,read_shopify_payments_payouts,read_shopify_payments_bank_accounts,read_shopify_payments_disputes,write_shopify_payments_disputes,read_content,write_content,read_store_credit_account_transactions,write_store_credit_account_transactions,read_store_credit_accounts,write_own_subscription_contracts,read_own_subscription_contracts,write_theme_code,read_themes,write_themes,read_third_party_fulfillment_orders,write_third_party_fulfillment_orders,read_translations,write_translations,customer_read_companies,customer_write_companies,customer_write_customers,customer_read_customers,customer_read_draft_orders,customer_read_markets,customer_read_metaobjects,customer_read_orders,customer_write_orders,customer_read_quick_sale,customer_write_quick_sale,customer_read_store_credit_account_transactions,customer_read_store_credit_accounts,customer_write_own_subscription_contracts,customer_read_own_subscription_contracts,unauthenticated_write_bulk_operations,unauthenticated_read_bulk_operations,unauthenticated_read_bundles,unauthenticated_write_checkouts,unauthenticated_read_checkouts,unauthenticated_write_customers,unauthenticated_read_customers,unauthenticated_read_customer_tags,unauthenticated_read_metaobjects,unauthenticated_read_product_pickup_locations,unauthenticated_read_product_inventory,unauthenticated_read_product_listings,unauthenticated_read_product_tags,unauthenticated_read_selling_plans,unauthenticated_read_shop_pay_installments_pricing,unauthenticated_read_content
- Use
http://localhost:9292/auth/callbackfor the Redirect URL - Click Release
- Once released, navigate to Settings for the app
- Using the Client ID and Secret credentials provided, open this URL in your browser:
https://admin.shopify.com/store/<STORE_ID>/oauth/authorize?client_id=<CLIENT_ID>&scope=<SCOPE>&redirect_uri=http%3A%2F%2Flocalhost:9292%2Fauth%2Fcallback&state=nonce-12345
This will return a URL like:
http://localhost:9292/auth/callback?code=<CODE>&hmac=<HMAC>&host=<HOST>&shop=<STORE_ID>.myshopify.com&state=nonce-12345×tamp=<TIMESTAMP>
- Copy the
<CODE>value from the returned URL, then run this command in your terminal:
curl -X POST "https://<STORE_ID>.myshopify.com/admin/oauth/access_token" \
-H "Content-Type: application/json" \
-d '{
"client_id": "<CLIENT_ID>",
"client_secret": "<SECRET>",
"code": "<CODE>"
}'
This will return the Shopify Access Token you will use in your MCP configuration file (e.g., mcp.json).
Quick Setup (Existing App)
If you already have an app with the required scopes:
- Log in to your Shopify Admin
- Go to Settings > Apps and sales channels > Develop apps
- Create a new app or use an existing one
- Click Configure Admin API scopes
- Select the required scopes (see Required Scopes section below)
- Install the app to your store
- Copy the Admin API access token
MCP Client Configuration
Add this server to your MCP client configuration (e.g., Claude Desktop, Cursor):
macOS/Linux (Recommended - Essential Tools Only):
{
"mcpServers": {
"shopify-graphql": {
"command": "node",
"args": ["/ABSOLUTE/PATH/TO/shopify-graphql-mcp/dist/index.js"],
"env": {
"SHOPIFY_ACCESS_TOKEN": "shpat_xxxxx",
"SHOPIFY_STORE_URL": "your-store.myshopify.com",
"SHOPIFY_STORE_API_URL": "https://your-store.myshopify.com/admin/api/2025-01/graphql.json",
"ENABLED_TOOL_CATEGORIES": "essential"
}
}
}
}
Windows:
{
"mcpServers": {
"shopify-graphql": {
"command": "node",
"args": ["C:\\PATH\\TO\\shopify-graphql-mcp\\dist\\index.js"],
"env": {
"SHOPIFY_ACCESS_TOKEN": "shpat_xxxxx",
"SHOPIFY_STORE_URL": "your-store.myshopify.com",
"SHOPIFY_STORE_API_URL": "https://your-store.myshopify.com/admin/api/2025-01/graphql.json",
"ENABLED_TOOL_CATEGORIES": "essential"
}
}
}
}
Available Tools
This MCP server provides 150+ tools organized into 7 categories. For a complete list of all available tools, see the TOOL_CATEGORIES.md file.
Tool Categories
| Category | Description | ~Tool Count | |----------|-------------|-------------| | Essential | Core e-commerce: products, orders, customers, inventory | ~35 | | Commerce | Extended commerce: gift cards, returns, checkouts, B2B | ~25 | | Marketing | Marketing: campaigns, markets, analytics, channels | ~20 | | Content | Content: pages, themes, files, metaobjects | ~25 | | Advanced | Advanced: cart transforms, validations, scripts | ~20 | | Reporting | Reports and feedback | ~15 | | Automation | Inventory automation | ~15 |
See TOOL_CATEGORIES.md for the complete tool reference.
Usage Examples
Get Orders
"Get the last 10 orders from my store"
Create Product
"Create a new product called 'Summer T-Shirt' with a $29.99 price"
Update Inventory
"Set the inventory for variant ID gid://shopify/ProductVariant/123 to 100 at location ID gid://shopify/Location/456"
Get Analytics
"Show me my store's total sales for last month using ShopifyQL"
Marketing Campaign
"Create a marketing event for our summer sale starting next week"
Content Management
"Create a new page called 'About Us' with our company story"
Development
Project Structure
shopify-graphql-mcp/
├── src/
│ ├── index.ts # Server entry point
│ ├── tools/ # Tool implementations organized by category
│ │ ├── index.ts # Tool registration and category management
│ │ ├── orders.ts
│ │ ├── products.ts
│ │ ├── customers.ts
│ │ └── ... (50+ tool modules)
│ ├── config/
│ │ └── tool-categories.ts # Category configuration
│ ├── utils/
│ │ ├── graphql-client.ts
│ │ └── scope-mapper.ts
│ └── types/
│ └── index.ts
├── dist/ # Compiled output
├── package.json
├── tsconfig.json
├── TOOL_CATEGORIES.md # Detailed category documentation
└── README.md
Adding New Tools
- Define the tool in the appropriate category file in
src/tools/ - Use the
server.registerTool()pattern - Include Zod schema validation for inputs
- Handle errors gracefully
- Add the tool to the category configuration in
src/config/tool-categories.ts
Example:
server.registerTool(
"my_new_tool",
{
description: "Description of what this tool does",
inputSchema: {
param1: z.string().describe("Parameter description"),
},
},
async ({ param1 }) => {
// Implementation
}
);
Building
npm run build
Type Checking
npm run typecheck
Troubleshooting
Environment Variables Not Found
Make sure all three environment variables are set:
SHOPIFY_ACCESS_TOKENSHOPIFY_STORE_URLSHOPIFY_STORE_API_URL
Tool Categories Not Working
Check the health_check tool output to see which categories are enabled:
"Run health check to see my server status"
GraphQL Errors
Check that your access token has the required scopes for the operations you're trying to perform.
cURL Not Found
Ensure cURL is installed on your system:
# macOS
brew install curl
# Ubuntu/Debian
sudo apt-get install curl
# Windows
curl is included in Windows 10+
Permission Denied (macOS/Linux)
Make sure the compiled file is executable:
chmod +x dist/index.js
Security Notes
- Never commit your
SHOPIFY_ACCESS_TOKENto version control - Use environment variables or a secure secrets manager
- The access token provides full API access to your store - keep it secure
- Consider using separate tokens for different environments (development, staging, production)
Required Shopify Admin API Scopes
Based on the tools you enable, the following scopes may be required:
Essential Category
read_orders,write_ordersread_products,write_productsread_customers,write_customersread_inventory,write_inventoryread_draft_orders,write_draft_ordersread_discounts,write_discountsread_locations,write_locationsread_fulfillments,write_fulfillments
Commerce Category
read_gift_cards,write_gift_cardsread_returns,write_returnsread_checkouts,write_checkoutsread_payment_terms,write_payment_termsread_order_edits,write_order_editsread_companies,write_companiesread_cash_tracking,write_cash_tracking
Marketing Category
read_marketing_events,write_marketing_eventsread_markets,write_marketsread_channels,write_channelsread_price_rules,write_price_rulesread_analyticsread_pixels,write_pixelsread_publications,write_publications
Content Category
read_metaobject_definitions,write_metaobject_definitionsread_metaobjects,write_metaobjectsread_themes,write_themesread_files,write_filesread_pages,write_pagesread_translations,write_translations
Advanced Category
read_cart_transforms,write_cart_transformsread_validations,write_validationsread_audit_eventsread_customer_eventsread_privacy_settings,write_privacy_settings
Reporting Category
read_reports,write_reportsread_apps,write_apps
Automation Category
read_inventory_shipments,write_inventory_shipmentsread_inventory_transfers,write_inventory_transfers
License
MIT
Contributing
Contributions are welcome! Please ensure:
- TypeScript strict mode compliance
- Zod schema validation for all tool inputs
- Error handling for all GraphQL operations
- Updated documentation for new tools
- Proper categorization in
TOOL_CATEGORIES.md
Support
For issues or questions:
- Check the troubleshooting section
- Verify your Shopify API credentials
- Ensure your access token has the required scopes
- Review the Shopify Admin GraphQL API documentation
- Check
TOOL_CATEGORIES.mdfor tool category configuration help