Anchor to webhookSubscriptionCreatewebhook
webhookSubscriptionCreate
mutation
Creates a new webhook subscription.
Building an app? If you only use app-specific webhooks, you won't need this. App-specific webhook subscriptions specified in your shopify.app.toml
may be easier. They are automatically kept up to date by Shopify & require less maintenance. Please read About managing webhook subscriptions.
Anchor to Arguments
Arguments
- Anchor to topictopic•Webhook
Subscription requiredTopic! The type of event that triggers the webhook.
- Anchor to webhookSubscriptionwebhook•
Subscription WebhookSubscription requiredInput! Specifies the input fields for a webhook subscription.
Was this section helpful?
Anchor to WebhookSubscriptionCreatePayload returnsWebhookSubscriptionCreatePayload returns
- Anchor to userErrorsuser•
Errors [UserError!]! non-null The list of errors that occurred from executing the mutation.
- Anchor to webhookSubscriptionwebhook•
Subscription The webhook subscription that was created.
Was this section helpful?
- Create a METAOBJECTS_CREATE webhook subscription for lookbook metaobjects
- Create a new Webhook
- Create an HTTP webhook subscription for APP_UNINSTALLED events
- Create an ORDERS_CREATE webhook subscription that includes metafields during serialization
- Create an ORDERS_CREATE webhook subscription with fewer resource fields during serialization
- webhookSubscriptionCreate reference
Examples
1const { admin } = await authenticate.admin(request);23const response = await admin.graphql(4 `#graphql5 mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) {6 webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) {7 webhookSubscription {8 id9 topic10 filter11 format12 endpoint {13 __typename14 ... on WebhookHttpEndpoint {15 callbackUrl16 }17 }18 }19 userErrors {20 field21 message22 }23 }24 }`,25 {26 variables: {27 "topic": "METAOBJECTS_CREATE",28 "webhookSubscription": {29 "callbackUrl": "https://example.org/endpoint",30 "format": "JSON",31 "filter": "type:lookbook"32 }33 },34 },35);3637const data = await response.json();38
mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) {
webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) {
webhookSubscription {
id
topic
filter
format
endpoint {
__typename
... on WebhookHttpEndpoint {
callbackUrl
}
}
}
userErrors {
field
message
}
}
}
curl -X POST \
https://your-development-store.myshopify.com/admin/api/2025-04/graphql.json \
-H 'Content-Type: application/json' \
-H 'X-Shopify-Access-Token: {access_token}' \
-d '{
"query": "mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) { webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) { webhookSubscription { id topic filter format endpoint { __typename ... on WebhookHttpEndpoint { callbackUrl } } } userErrors { field message } } }",
"variables": {
"topic": "METAOBJECTS_CREATE",
"webhookSubscription": {
"callbackUrl": "https://example.org/endpoint",
"format": "JSON",
"filter": "type:lookbook"
}
}
}'
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) {
webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) {
webhookSubscription {
id
topic
filter
format
endpoint {
__typename
... on WebhookHttpEndpoint {
callbackUrl
}
}
}
userErrors {
field
message
}
}
}`,
{
variables: {
"topic": "METAOBJECTS_CREATE",
"webhookSubscription": {
"callbackUrl": "https://example.org/endpoint",
"format": "JSON",
"filter": "type:lookbook"
}
},
},
);
const data = await response.json();
const client = new shopify.clients.Graphql({session});
const data = await client.query({
data: {
"query": `mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) {
webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) {
webhookSubscription {
id
topic
filter
format
endpoint {
__typename
... on WebhookHttpEndpoint {
callbackUrl
}
}
}
userErrors {
field
message
}
}
}`,
"variables": {
"topic": "METAOBJECTS_CREATE",
"webhookSubscription": {
"callbackUrl": "https://example.org/endpoint",
"format": "JSON",
"filter": "type:lookbook"
}
},
},
});
session = ShopifyAPI::Auth::Session.new(
shop: "your-development-store.myshopify.com",
access_token: access_token
)
client = ShopifyAPI::Clients::Graphql::Admin.new(
session: session
)
query = <<~QUERY
mutation webhookSubscriptionCreate($topic: WebhookSubscriptionTopic!, $webhookSubscription: WebhookSubscriptionInput!) {
webhookSubscriptionCreate(topic: $topic, webhookSubscription: $webhookSubscription) {
webhookSubscription {
id
topic
filter
format
endpoint {
__typename
... on WebhookHttpEndpoint {
callbackUrl
}
}
}
userErrors {
field
message
}
}
}
QUERY
variables = {
"topic": "METAOBJECTS_CREATE",
"webhookSubscription": {
"callbackUrl": "https://example.org/endpoint",
"format": "JSON",
"filter": "type:lookbook"
}
}
response = client.query(query: query, variables: variables)
Input variables
JSON1{2 "topic": "METAOBJECTS_CREATE",3 "webhookSubscription": {4 "callbackUrl": "https://example.org/endpoint",5 "format": "JSON",6 "filter": "type:lookbook"7 }8}
Response
JSON1{2 "webhookSubscriptionCreate": {3 "webhookSubscription": {4 "id": "gid://shopify/WebhookSubscription/8589934635",5 "topic": "METAOBJECTS_CREATE",6 "filter": "type:lookbook",7 "format": "JSON",8 "endpoint": {9 "__typename": "WebhookHttpEndpoint",10 "callbackUrl": "https://example.org/endpoint"11 }12 },13 "userErrors": []14 }15}