docs/ai-agents/connectors/shopify/README.md
The Shopify agent connector is a Python package that equips AI agents to interact with Shopify through strongly typed, well-documented tools. It's ready to use directly in your Python app, in an agent framework, or exposed through an MCP.
Shopify is an e-commerce platform that enables businesses to create online stores, manage products, process orders, and handle customer relationships. This connector provides access to Shopify Admin REST API for reading store data including customers, orders, products, inventory, and more.
The Shopify connector is optimized to handle prompts like these.
The Shopify connector isn't currently able to handle prompts like these.
uv pip install airbyte-agent-shopify
Connectors can run in open source or hosted mode.
In open source mode, you provide API credentials directly to the connector.
from airbyte_agent_shopify import ShopifyConnector
from airbyte_agent_shopify.models import ShopifyAuthConfig
connector = ShopifyConnector(
auth_config=ShopifyAuthConfig(
api_key="<Your Shopify Admin API access token>"
)
)
@agent.tool_plain # assumes you're using Pydantic AI
@ShopifyConnector.tool_utils
async def shopify_execute(entity: str, action: str, params: dict | None = None):
return await connector.execute(entity, action, params or {})
In hosted mode, API credentials are stored securely in Airbyte Cloud. You provide your Airbyte credentials instead.
If your Airbyte client can access multiple organizations, also set organization_id.
This example assumes you've already authenticated your connector with Airbyte. See Authentication to learn more about authenticating. If you need a step-by-step guide, see the hosted execution tutorial.
from airbyte_agent_shopify import ShopifyConnector, AirbyteAuthConfig
connector = ShopifyConnector(
auth_config=AirbyteAuthConfig(
customer_name="<your_customer_name>",
organization_id="<your_organization_id>", # Optional for multi-org clients
airbyte_client_id="<your-client-id>",
airbyte_client_secret="<your-client-secret>"
)
)
@agent.tool_plain # assumes you're using Pydantic AI
@ShopifyConnector.tool_utils
async def shopify_execute(entity: str, action: str, params: dict | None = None):
return await connector.execute(entity, action, params or {})
This connector supports the following entities and actions. For more details, see this connector's full reference documentation.
| Entity | Actions |
|---|---|
| Customers | List, Get |
| Orders | List, Get |
| Products | List, Get |
| Product Variants | List, Get |
| Product Images | List, Get |
| Abandoned Checkouts | List |
| Locations | List, Get |
| Inventory Levels | List |
| Inventory Items | List, Get |
| Shop | Get |
| Price Rules | List, Get |
| Discount Codes | List, Get |
| Custom Collections | List, Get |
| Smart Collections | List, Get |
| Collects | List, Get |
| Draft Orders | List, Get |
| Fulfillments | List, Get |
| Order Refunds | List, Get |
| Transactions | List, Get |
| Tender Transactions | List |
| Countries | List, Get |
| Metafield Shops | List, Get |
| Metafield Customers | List |
| Metafield Products | List |
| Metafield Orders | List |
| Metafield Draft Orders | List |
| Metafield Locations | List |
| Metafield Product Variants | List |
| Metafield Smart Collections | List |
| Metafield Product Images | List |
| Customer Address | List, Get |
| Fulfillment Orders | List, Get |
For all authentication options, see the connector's authentication documentation.
See the official Shopify API reference.