Anchor to subscriptionBillingAttemptsubscription
subscriptionBillingAttempt
query
Returns a SubscriptionBillingAttempt by ID.
Anchor to Possible returnsPossible returns
- Anchor to SubscriptionBillingAttemptSubscription•
Billing Attempt A record of an execution of the subscription billing process. Billing attempts use idempotency keys to avoid duplicate order creation. A successful billing attempt will create an order.
Was this section helpful?
- Query for a billing attempt with a processing error
- Query for a subscription billing attempt
Examples
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
query findBillingAttempt($subscriptionBillingAttempt: ID!) {
subscriptionBillingAttempt(id: $subscriptionBillingAttempt) {
id
nextActionUrl
idempotencyKey
ready
order {
id
}
subscriptionContract {
id
}
processingError {
__typename
code
message
... on SubscriptionBillingAttemptInsufficientStockProductVariantsError {
insufficientStockProductVariants(first: 3) {
edges {
node {
id
query findBillingAttempt($subscriptionBillingAttempt: ID!) {
subscriptionBillingAttempt(id: $subscriptionBillingAttempt) {
id
nextActionUrl
idempotencyKey
ready
order {
id
}
subscriptionContract {
id
}
processingError {
__typename
code
message
... on SubscriptionBillingAttemptInsufficientStockProductVariantsError {
insufficientStockProductVariants(first: 3) {
edges {
node {
id
title
}
}
}
}
}
}
}
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": "query findBillingAttempt($subscriptionBillingAttempt: ID!) { subscriptionBillingAttempt(id: $subscriptionBillingAttempt) { id nextActionUrl idempotencyKey ready order { id } subscriptionContract { id } processingError { __typename code message ... on SubscriptionBillingAttemptInsufficientStockProductVariantsError { insufficientStockProductVariants(first: 3) { edges { node { id title } } } } } } }",
"variables": {
"subscriptionBillingAttempt": "gid://shopify/SubscriptionBillingAttempt/693432113"
}
}'
const { admin } = await authenticate.admin(request);
const response = await admin.graphql(
`#graphql
query findBillingAttempt($subscriptionBillingAttempt: ID!) {
subscriptionBillingAttempt(id: $subscriptionBillingAttempt) {
id
nextActionUrl
idempotencyKey
ready
order {
id
}
subscriptionContract {
id
}
processingError {
__typename
code
message
... on SubscriptionBillingAttemptInsufficientStockProductVariantsError {
insufficientStockProductVariants(first: 3) {
edges {
node {
id
title
}
}
}
}
}
}
}`,
{
variables: {
"subscriptionBillingAttempt": "gid://shopify/SubscriptionBillingAttempt/693432113"
},
},
);
const data = await response.json();
const client = new shopify.clients.Graphql({session});
const data = await client.query({
data: {
"query": `query findBillingAttempt($subscriptionBillingAttempt: ID!) {
subscriptionBillingAttempt(id: $subscriptionBillingAttempt) {
id
nextActionUrl
idempotencyKey
ready
order {
id
}
subscriptionContract {
id
}
processingError {
__typename
code
message
... on SubscriptionBillingAttemptInsufficientStockProductVariantsError {
insufficientStockProductVariants(first: 3) {
edges {
node {
id
title
}
}
}
}
}
}
}`,
"variables": {
"subscriptionBillingAttempt": "gid://shopify/SubscriptionBillingAttempt/693432113"
},
},
});
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
query findBillingAttempt($subscriptionBillingAttempt: ID!) {
subscriptionBillingAttempt(id: $subscriptionBillingAttempt) {
id
nextActionUrl
idempotencyKey
ready
order {
id
}
subscriptionContract {
id
}
processingError {
__typename
code
message
... on SubscriptionBillingAttemptInsufficientStockProductVariantsError {
insufficientStockProductVariants(first: 3) {
edges {
node {
id
title
}
}
}
}
}
}
}
QUERY
variables = {
"subscriptionBillingAttempt": "gid://shopify/SubscriptionBillingAttempt/693432113"
}
response = client.query(query: query, variables: variables)
Input variables
JSON{
"subscriptionBillingAttempt": "gid://shopify/SubscriptionBillingAttempt/693432113"
}
Response
JSON{
"subscriptionBillingAttempt": {
"id": "gid://shopify/SubscriptionBillingAttempt/693432113",
"nextActionUrl": null,
"idempotencyKey": "unique-token",
"ready": true,
"order": {
"id": "gid://shopify/Order/148977776"
},
"subscriptionContract": {
"id": "gid://shopify/SubscriptionContract/593791907"
},
"processingError": {
"__typename": "SubscriptionBillingAttemptInsufficientStockProductVariantsError",
"code": "INSUFFICIENT_INVENTORY",
"message": "Insufficient inventory.",
"insufficientStockProductVariants": {
"edges": [
{
"node": {
"id": "gid://shopify/ProductVariant/43729076",