Anchor to appSubscriptionCancelapp
appSubscriptionCancel
mutation
Cancels an app subscription on a store.
Anchor to Arguments
Arguments
- •ID!required
The ID of the app subscription to be cancelled.
- Anchor to prorateprorate•BooleanDefault:false
Whether to issue prorated credits for the unused portion of the app subscription. There will be a corresponding deduction (based on revenue share) to your Partner account. For example, if a $10.00 app subscription (with 0% revenue share) is cancelled and prorated half way through the billing cycle, then the merchant will be credited $5.00 and that amount will be deducted from your Partner account.
Was this section helpful?
Anchor to AppSubscriptionCancelPayload returnsAppSubscriptionCancelPayload returns
- Anchor to appSubscriptionapp•
Subscription The cancelled app subscription.
- Anchor to userErrorsuser•
Errors [UserError!]! non-null The list of errors that occurred from executing the mutation.
Was this section helpful?
- Cancel an app subscription on a shop and issue prorated credits
- Cancels a recurring application charge
- appSubscriptionCancel reference
Examples
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
mutation AppSubscriptionCancel($id: ID!, $prorate: Boolean) {
appSubscriptionCancel(id: $id, prorate: $prorate) {
userErrors {
field
message
}
appSubscription {
id
status
}
}
}`,
{
variables: {
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
},
},
);
const data = await response.json();
mutation AppSubscriptionCancel($id: ID!, $prorate: Boolean) {
appSubscriptionCancel(id: $id, prorate: $prorate) {
userErrors {
field
message
}
appSubscription {
id
status
}
}
}
curl -X POST \
https://your-development-store.myshopify.com/admin/api/2025-01/graphql.json \
-H 'Content-Type: application/json' \
-H 'X-Shopify-Access-Token: {access_token}' \
-d '{
"query": "mutation AppSubscriptionCancel($id: ID!, $prorate: Boolean) { appSubscriptionCancel(id: $id, prorate: $prorate) { userErrors { field message } appSubscription { id status } } }",
"variables": {
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
}
}'
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
mutation AppSubscriptionCancel($id: ID!, $prorate: Boolean) {
appSubscriptionCancel(id: $id, prorate: $prorate) {
userErrors {
field
message
}
appSubscription {
id
status
}
}
}`,
{
variables: {
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
},
},
);
const data = await response.json();
const client = new shopify.clients.Graphql({session});
const data = await client.query({
data: {
"query": `mutation AppSubscriptionCancel($id: ID!, $prorate: Boolean) {
appSubscriptionCancel(id: $id, prorate: $prorate) {
userErrors {
field
message
}
appSubscription {
id
status
}
}
}`,
"variables": {
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
},
},
});
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 AppSubscriptionCancel($id: ID!, $prorate: Boolean) {
appSubscriptionCancel(id: $id, prorate: $prorate) {
userErrors {
field
message
}
appSubscription {
id
status
}
}
}
QUERY
variables = {
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
}
response = client.query(query: query, variables: variables)
Input variables
JSON{
"id": "gid://shopify/AppSubscription/1029266957",
"prorate": true
}
Response
JSON{
"appSubscriptionCancel": {
"userErrors": [],
"appSubscription": {
"id": "gid://shopify/AppSubscription/1029266957",
"status": "CANCELLED"
}
}
}