Shopify MCP Server
Interact with Shopify store data such as products, customers, and orders using the GraphQL API.
Shopify MCP Server
MCP Server for Shopify API, enabling interaction with store data (products, customers, orders, etc.) via GraphQL.
Features
Provides tools for product, customer, and order management, direct GraphQL integration, and clear error handling.
Prerequisites
- Node.js (v16+)
- Shopify Custom App Access Token
Installation
git clone https://github.com/pashpashpash/shopify-mcp-server.git
cd shopify-mcp-server
npm install
npm run build
Shopify Setup & Configuration
- Create Custom App: In Shopify admin > Settings > Apps and sales channels > Develop apps > Create an app.
- Configure Scopes: Grant
read/writepermissions forproducts,customers, andorders. - Install App & Get Token: Install the app and copy the Admin API access token.
- Create
.envfile in the project root:SHOPIFY_ACCESS_TOKEN=your_access_token MYSHOPIFY_DOMAIN=your-store.myshopify.com - Configure Claude Desktop (
claude_desktop_config.json):- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%/Claude/claude_desktop_config.json
Note: Use the correct path to the cloned repo and store your token securely.{ "mcpServers": { "shopify": { "command": "node", "args": ["path/to/shopify-mcp-server/dist/index.js"], "env": { "SHOPIFY_ACCESS_TOKEN": "your_access_token", "MYSHOPIFY_DOMAIN": "your-store.myshopify.com" } } } } - macOS:
Available Tools
Product Management
findProducts: Get all products or search by title.searchTitle(optional string): Filter by title.limit(number): Max products.
listProductsInCollection: Get products from a collection.collectionId(string): Collection ID.limit(optional number, default: 10): Max products.
getProductsByIds: Get products by IDs.productIds(array of strings): Product IDs.
getVariantsByIds: Get variants by IDs.variantIds(array of strings): Variant IDs.
Customer Management
listCustomers: Get customers with pagination.limit(optional number): Max customers.next(optional string): Next page cursor.
addCustomerTags: Add tags to a customer.customerId(string): Customer ID.tags(array of strings): Tags to add.
Order Management
findOrders: Get orders with advanced filtering/sorting.first(optional number): Limit orders.after(optional string): Next page cursor.query(optional string): Filter query.sortKey(optional enum): Sort field.reverse(optional boolean): Reverse sort.
getOrderById: Get a single order by ID.orderId(string): Order ID.
createDraftOrder: Create a draft order.lineItems(array): Items (variantId, quantity).email(string): Customer email.shippingAddress(object): Shipping details.note(optional string): Order note.
completeDraftOrder: Complete a draft order.draftOrderId(string): Draft order ID.variantId(string): Variant ID.
Discount Management
createDiscountCode: Create a basic discount code.title(string): Discount title.code(string): Discount code.valueType(enum): 'percentage' or 'fixed_amount'.value(number): Discount value.startsAt(string): Start date (ISO).endsAt(optional string): End date (ISO).appliesOncePerCustomer(boolean): Limit one use per customer.
Collection Management
listCollections: Get all collections.limit(optional number, default: 10): Max collections.name(optional string): Filter by name.
Shop Information
getShopDetails: Get basic shop details (No inputs).getExtendedShopDetails: Get extended shop details (No inputs).
Webhook Management
manageWebhooks: Manage webhooks.action(enum): 'subscribe', 'find', 'unsubscribe'.callbackUrl(string): Webhook URL.topic(enum): Webhook topic.webhookId(optional string): Required for unsubscribe.
Debugging Tools
debugGetVariantMetafield: Get variant &size_chart_jsonmetafield.variantId(string): Variant GID.
Developer Tools
introspect_admin_schema: Introspect Admin API GraphQL schema.query(string): Filter term.filter(optional array): Filter by 'types', 'queries', 'mutations', 'all'.
search_dev_docs: Search shopify.dev docs.prompt(string): Search query.
Debugging
Check Claude Desktop MCP logs:
tail -n 20 -f ~/Library/Logs/Claude/mcp*.log
Common issues:
- Authentication: Check token, domain format, API scopes.
- API Errors: Check rate limits, input formats, required fields.
Development
npm install
npm run build
npm test
Dependencies
- @modelcontextprotocol/sdk
- graphql-request
- zod
License
MIT
Note: Fork of original shopify-mcp-server repository
Server Terkait
My MCP
A remote MCP server deployable on Cloudflare Workers without authentication.
Dokploy
An AI-powered interface for managing the Dokploy infrastructure platform.
PayPal Account Updater Subscription Connector
Integrates with PayPal's Account Updater service to maintain fresh payment card information in e-commerce systems.
Remote MCP Server on Cloudflare
A remote MCP server deployable on Cloudflare Workers with OAuth login support, using Cloudflare KV for data storage.
Zen MCP Server
Access multiple AI models like Claude, Gemini, and OpenAI through a single server using your own API keys.
MCP Remote with Okta/Adobe IMS Authentication
A remote MCP server that uses Adobe IMS/Okta for authentication.
DeAI API MCP Server
Interact with the DeAI API for token analysis, holder tracking, and wallet portfolio analytics on Ethereum.
AWS Knowledge Base Retrieval
Retrieve information from an AWS Knowledge Base using the Bedrock Agent Runtime.
Remote MCP Server (Authless)
A remote, authentication-free MCP server deployable on Cloudflare Workers or locally via npm.
APISIX-MCP
APISIX Model Context Protocol (MCP) server is used to bridge large language models (LLMs) with the APISIX Admin API, supporting querying and managing all resources in Apache APISIX.