Skip to main content
object

Requires read_own_subscription_contracts access scope.

The SubscriptionDraft object represents a draft version of a subscription contract before it's committed. It serves as a staging area for making changes to an existing subscription or creating a new one. The draft allows you to preview and modify various aspects of a subscription before applying the changes.

Use the SubscriptionDraft object to:

  • Add, remove, or modify subscription lines and their quantities
  • Manage discounts (add, remove, or update manual and code-based discounts)
  • Configure delivery options and shipping methods
  • Set up billing and delivery policies
  • Manage customer payment methods
  • Add custom attributes and notes to generated orders
  • Configure billing cycles and next billing dates
  • Preview the projected state of the subscription

Each SubscriptionDraft object maintains a projected state that shows how the subscription will look after the changes are committed. This allows you to preview the impact of your modifications before applying them. The draft can be associated with an existing subscription contract (for modifications) or used to create a new subscription.

The draft remains in a draft state until it's committed, at which point the changes are applied to the subscription contract and the draft is no longer accessible.

Learn more about how subscription contracts work and how to build, update, and combine subscription contracts.

•SubscriptionBillingCycle

The billing cycle that the subscription contract will be associated with.

•SubscriptionBillingPolicy!
non-null

The billing policy for the subscription contract.

Anchor to concatenatedBillingCyclesconcatenatedBillingCycles
•SubscriptionBillingCycleConnection!
non-null

The billing cycles of the contracts that will be concatenated to the subscription contract.

•CurrencyCode!
non-null

The currency used for the subscription contract.

•[Attribute!]!
non-null

A list of the custom attributes to be added to the generated orders.

•Customer!
non-null

The customer to whom the subscription contract belongs.

Anchor to customerPaymentMethodcustomerPaymentMethod
•CustomerPaymentMethod

The customer payment method used for the subscription contract.

•SubscriptionDeliveryMethod

The delivery method for each billing of the subscription contract.

•SubscriptionDeliveryOptionResult

The available delivery options for a given delivery address. Returns null for pending requests.

•SubscriptionDeliveryPolicy!
non-null

The delivery policy for the subscription contract.

•MoneyV2

The delivery price for each billing the subscription contract.

•SubscriptionDiscountConnection!
non-null

The list of subscription discounts which will be associated with the subscription contract.

•SubscriptionDiscountConnection!
non-null

The list of subscription discounts to be added to the subscription contract.

•SubscriptionDiscountConnection!
non-null

The list of subscription discounts to be removed from the subscription contract.

•SubscriptionDiscountConnection!
non-null

The list of subscription discounts to be updated on the subscription contract.

•ID!
non-null

A globally-unique ID.

•SubscriptionLineConnection!
non-null

The list of subscription lines which will be associated with the subscription contract.

•SubscriptionLineConnection!
non-null

The list of subscription lines to be added to the subscription contract.

•SubscriptionLineConnection!
non-null

The list of subscription lines to be removed from the subscription contract.

•DateTime

The next billing date for the subscription contract.

•String

The note field that will be applied to the generated orders.

•SubscriptionContract

The original subscription contract.

•SubscriptionContractSubscriptionStatus

The current status of the subscription contract.

•SubscriptionShippingOptionResult
Deprecated

Was this section helpful?

•query

Returns a Subscription Draft resource by ID.


Was this section helpful?

•mutation

Concatenates a contract to a Subscription Draft.

•mutation

Edit the contents of a subscription contract for the specified billing cycle.

•mutation

Creates a Subscription Contract Draft. You can submit all the desired information for the draft using Subscription Draft Input object. You can also update the draft using the Subscription Contract Update mutation. The draft is not saved until you call the Subscription Draft Commit mutation.

•mutation

The subscriptionContractUpdate mutation allows you to create a draft of an existing subscription contract. This draft can be reviewed and modified as needed. Once the draft is committed with subscriptionDraftCommit, the changes are applied to the original subscription contract.

•mutation

Adds a subscription discount to a subscription draft.

•mutation

Applies a code discount on the subscription draft.

•mutation

Removes a subscription discount from a subscription draft.

•mutation

Updates a subscription discount on a subscription draft.

•mutation

Adds a subscription free shipping discount to a subscription draft.

•mutation

Updates a subscription free shipping discount on a subscription draft.

•mutation

Adds a subscription line to a subscription draft.

•mutation

Removes a subscription line from a subscription draft.

•mutation

Updates a subscription line on a subscription draft.

•mutation

Updates a Subscription Draft.


Was this section helpful?

•interface

Was this section helpful?