2024-10 release notes
Release date | Date version is no longer supported |
---|---|
October 1, 2024 | October 1, 2025 |
The 2024-10 version of Shopify's APIs include the following highlights:
- Abandoned checkouts: We've added new types that are associated with the
AbandonedCheckout
object. This object replaces theAbandoned checkouts
resource in the REST Admin API. app_scopes/update
webhook: Apps can now subscribe to theapp/scopes_update
webhook topic. This webhook is triggered when the granted access scopes for the installed app on a shop have been modified.- Cart warnings: Storefront API cart mutations now include warnings to show automatic changes that occurred while executing a mutation.
- Fulfillment constraints: You can now associate a fulfillment constraint function to one or multiple delivery methods, such as
SHIPPING
andPICKUP
. The function will only run under the context of the specified delivery methods. - Gift cards: You can now use new gift cards and gift card transaction types in all apps and shops, with no additional approval scopes or flags required.
- Metafield capabilities: Create an automated collection based on metafield values for a given definition. Then, filter products based on metafield values for that definition.
Products
query attributes: We've added new attributes to theproducts
query, which includepublication_ids
,variant_id
, andvariant_title
.StaffMember
improvements: We've made several improvements to theStaffMember
object. These improvements enable apps using the REST Admin API'sUser
resource to migrate to using the GraphQL Admin API'sStaffMember
object.- Subscription contracts: New types for subscription contracts are now available in the Customer Account API.
Breaking changes
Anchor link to section titled "Breaking changes"These changes require special attention. If your app uses these API resources, and you don’t adjust your usage of the resources according to the following instructions, then your app might break when you update to this API version.
Cart warnings
Anchor link to section titled "Cart warnings"Inventory errors about stock levels are no longer included in the userErrors
of cart mutations in the Storefront API. Inventory errors are now available in the warnings
return field, and contain the following explicit values:
MERCHANDISE_NOT_ENOUGH_STOCK
MERCHANDISE_OUT_OF_STOCK
Warnings are available on all cart mutations to show automatic changes that occurred while executing the mutation. You can use warnings to manage items in your cart or display information to a buyer. For example, you can remove out-of-stock lines from a cart by using the target
field included in the warning
as the input to the cartLinesRemove
mutation.
Learn more about cart warnings.
Changed enum value for OrderDisplayFulfillmentStatus
Anchor link to section titled "Changed enum value for OrderDisplayFulfillmentStatus"The OrderDisplayFulfillmentStatus
enum now returns a REQUEST_DECLINED
value for an order that has had its fulfillment request rejected by a third-party fulfillment service. In API versions prior to 2024-10, orders in the request rejected state return an UNFULFILLED
status.
Event query enhancements
Anchor link to section titled "Event query enhancements"We've made the CommentEvent.subject
field nullable. null
is returned when the subject's underlying data has been deleted. You must update your code to handle cases where subject
might return null
. For example, revise existing logic that assumes the field will always contain data, and implement checks or fallback mechanisms to manage situations where the subject
data has been deleted.
We've also deprecated the deletionEvents
query in favour of events that indicate deletion. Update your code to remove any reliance on deletionEvents
, and use the new event structure. To support querying events, we've added the following types:
Name | Type | Change |
---|---|---|
action |
field | Added to Event interface |
event |
Query | Added |
events |
Query | Added |
eventsCount |
Query | Added |
events |
Connection | Added to Article , Blog , Comment , Page , Product , and ProductVariant objects |
EventSubjectType |
Enum | Added |
arguments |
field | Added to BasicEvent object |
subject |
field | Added to BasicEvent object |
subjectID |
field | Added to BasicEvent object |
subjectType |
field | Added to BasicEvent object |
Fulfillment by Amazon
Anchor link to section titled "Fulfillment by Amazon"As of API version 2024-10, the shippingMethods
field on the FulfillmentService
object has been deprecated. The shippingMethods
argument on the fulfillmentOrderSubmitFulfillmentRequest
mutation has also been deprecated.
The shipping method associated with the fulfillment service provider applied only to the Fulfill By Amazon fulfillment service. The Fulfillment by Amazon feature isn't supported as of March 30, 2023. To continue using Amazon fulfillment, merchants need to set up a multi-channel fulfillment solution, as recommended by Amazon.
Fulfillment holds
Anchor link to section titled "Fulfillment holds"As of API version 2024-10, apps can't release fulfillment holds unless they have write access to them. You need to request the following access scopes for your app:
write_merchant_managed_fulfillment_orders
: Allows your app to release holds on fulfillment orders assigned to a merchant-managed locationwrite_third_party_fulfillment_orders
: Allows your app to release holds on fulfillment orders assigned to a third-party locationwrite_marketplace_fulfillment_orders
: Allows your app to release holds on fulfillment orders which belong to one of your marketplace's orders
If your app doesn't have sufficient access scopes to release a hold, then a user error with the INVALID_ACCESS
code is returned and the hold isn't released.
We've deprecated the fulfillmentOrdersReleaseHolds
mutation. Use the fulfillmentOrderReleaseHold
mutation instead.
We've also deprecated the GREATER_THAN_ZERO
and INVALID_LINE_ITEM_QUANTITY
error codes on the fulfillmentOrderReleaseHold
mutation.
We've also added the heldByRequestingApp
field to the FulfillmentHold
object. If you have the read_apps
scope enabled on your app, then you'll only be able to read the heldBy
field on the FulfillmentHold
object. Use the heldByRequestingApp
field instead if you need to confirm whether your app created the fulfillment hold.
Additionally, the fulfillmentOrderHold
mutation now returns the fulfillment hold that was created in a new fulfillmentHold
return field.
We've improved the GiftCard
types and have introduced several new types for working with gift cards. The gift card types are now open to all apps and shops, with no additional approval scopes or flags required.
Developer action required
- The
giftCardDisable
mutation has been removed. UsegiftCardDeactivate
instead. - The
disabledAt
field on theGiftCard
object has been removed. Use thedeactivatedAt
field instead.
The following types for gift cards are now available:
Name | Type | Change |
---|---|---|
CUSTOMER_NOT_FOUND |
Value | Added to GiftCardErrorCode enum |
deactivatedAt |
Field | Added to GiftCard object |
GiftCardCreateInput |
Input object | Added |
giftCardCredit |
Mutation | Added |
GiftCardCreditInput |
Input object | Added |
GiftCardCreditTransaction |
Object | Added |
giftCardDebit |
Mutation | Added |
GiftCardDebitInput |
Input object | Added |
GiftCardDebitTransaction |
Object | Added |
giftCardDeactivate |
Mutation | Added |
GiftCardRecipient |
Object | Added |
GiftCardRecipientInput |
Input object | Added |
giftCardSendNotificationToCustomer |
Mutation | Added |
giftCardSendNotificationToRecipient |
Mutation | Added |
GiftCardTransaction |
Interface | Added |
GiftCardTransactionUserError |
Object | Added |
recipientAttributes |
Field | Added to GiftCard object |
recipientAttributes |
Field | Added to GiftCardCreateInput input object |
recipientAttributes |
Field | Added to GiftCardUpdateInput input object |
RECIPIENT_NOT_FOUND |
Value | Added to GiftCardErrorCode enum |
transactions |
Connection | Added to GiftCard object |
updatedAt |
Field | Added to GiftCard object |
Improvements to the StaffMember
type
Anchor link to section titled "Improvements to the StaffMember type"Shop.staffMembers
has been deprecated. Use the staffMembers
query instead.
Location error codes
Anchor link to section titled "Location error codes"We've removed the HAS_OPEN_TRANSFERS_ERROR
and FAILED_TO_RELOCATE_OPEN_TRANSFERS
error codes from the LocationDeactivateUserErrorCode
enum. If you're explicitly checking for either of these error codes in your app, then you should remove references to them.
Location resource
Anchor link to section titled "Location resource"If your app retrieves a Location
resource using the REST Admin API, then you need to request the read_locations
access scope.
If your app reads a Location
resource without the read_locations
access scope, then a 403 Forbidden error is returned.
Metafield definitions
Anchor link to section titled "Metafield definitions"We've deprecated the definitions.visibleToStorefrontApi
argument on the standardMetafieldDefinitionEnable
and standardMetafieldDefinitionsEnable
mutations. Use the definitions.access
argument on these mutations instead.
Online store
Anchor link to section titled "Online store"We've deprecated the OnlineStorePage
, OnlineStoreArticle
, and OnlineStoreBlog
objects. Use the Page
, Article
, and Blog
objects instead.
You can now read and modify pages, articles, blogs, and comments. The following types are now available:
Name | Type | Change |
---|---|---|
pageCreateInput |
Input object | Added |
pageUpdateInput |
Input object | Added |
pageCreate |
Mutation | Added |
pageUpdate |
Mutation | Added |
pageDelete |
Mutation | Added |
page |
Query | Added |
pages |
Query | Added |
pagesCount |
Query | Added |
PAGE |
Value | Added to TranslatableResourceType enum |
ArticleAuthor |
Object | Added |
ArticleBlogInput |
Input object | Added |
ArticleCreateInput |
Input object | Added |
ArticleImageInput |
Input object | Added |
ArticleUpdateInput |
Input object | Added |
articleCreate |
Mutation | Added |
articleUpdate |
Mutation | Added |
articleDelete |
Mutation | Added |
article |
Query | Added |
articles |
Query | Added |
ARTICLE |
Value | Added to TranslatableResourceType enum |
AuthorInput |
Input object | Added |
BlogCreateInput |
Input object | Added |
BlogUpdateInput |
Input object | Added |
BlogFeed |
Object | Added |
blogCreate |
Mutation | Added |
blogUpdate |
Mutation | Added |
blogDelete |
Mutation | Added |
blog |
Query | Added |
blogs |
Query | Added |
blogsCount |
Query | Added |
BLOG |
Value | Added to TranslatableResourceType enum |
Comment |
Object | Added |
CommentAuthor |
Object | Added |
commentApprove |
Mutation | Added |
commentSpam |
Mutation | Added |
commentNotSpam |
Mutation | Added |
commentDelete |
Mutation | Added |
comment |
Query | Added |
comments |
Query | Added |
CommentStatus |
Enum | Added |
CommentPolicy |
Enum | Added |
MENU |
Value | Added to TranslatableResourceType enum |
Order line items
Anchor link to section titled "Order line items"We've removed the lineItemsMutable
connection on the Order
object. Use the lineItems
connection on the Order
object instead.
Order management apps
Anchor link to section titled "Order management apps"The write_third_party_fulfillment_orders
access scope no longer allows order management apps to fulfill fulfillment orders assigned to locations that are owned by other fulfillment service apps. Order management apps will still be able to access and manage these orders, but fulfillment creation will be prohibited.
The write_assigned_fulfillment_orders
and write_merchant_managed_fulfillment_orders
access scopes remain unchanged. Fulfillment service apps can still fulfill orders that are assigned to them, as long as they're granted the write_assigned_fulfillment_orders
access scope. Fulfillment orders that are assigned to merchant-managed locations are still fulfillable by order management apps, as long as they're granted the write_merchant_managed_fulfillment_orders
access scope.
Apps can confirm whether fulfillment creation is possible by querying supported actions using the GraphQL Admin API. If the fulfillment order is assigned to a merchant-managed location or to the fulfillment service performing the query and it's in a fulfillable state, then the CREATE_FULFILLMENT
action is returned as a possible option.
Pickup locations
Anchor link to section titled "Pickup locations"You can now use the destination
field on the fulfillmentOrder
object to retrieve the pickup location for a fulfillment order.
As of API version 2024-10, the destination
field returns a FulfillmentOrderDestination
object instead of null
for fulfillment orders that don't have an associated shipping address. If the fulfillment order doesn't have a shipping address, then the address-related fields within the FulfillmentOrderDestination
object are set to null
.
PriceRule types removed
Anchor link to section titled "PriceRule types removed"As of API version 2024-10, we've removed PriceRule
types from the GraphQL Admin API. The associated queries and mutations have been deprecated since API version 2023-03. Use the discountNode
query instead.
The following types have been removed:
PriceRuleUserError
objectPriceRuleCustomerSelectionInput
input objectPriceRuleDiscountCodeInput
input objectPriceRuleEntitlementToPrerequisiteQuantityRatioInput
input objectPriceRuleInput
input objectPriceRuleItemEntitlementsInput
input objectPriceRuleItemPrerequisitesInput
input objectPriceRuleMoneyRangeInput
input objectPriceRulePrerequisiteToEntitlementQuantityRatioInput
input objectPriceRuleQuantityRangeInput
input objectPriceRuleShippingEntitlementsInput
input objectPriceRuleValidityPeriodInput
input objectPriceRuleValueInput
input objectpriceRuleSavedSearches
queryPriceRuleActivate
mutationPriceRuleCreate
mutationPriceRuleDeactivate
mutationPriceRuleDelete
mutationPriceRuleDiscountCodeCreate
mutationPriceRuleDiscountCodeUpdate
mutationPriceRuleUpdate
mutationpriceRule
field on theQueryRoot
objectpriceRules
connection on theQueryRoot
objectpriceRules
connection on theShop
objectpriceRuleSavedSearches
connection on theShop
object
Product duplications
Anchor link to section titled "Product duplications"The productDuplicateAsyncV2
mutation has been removed. We've added the synchronous
argument to the productDuplicate
mutation, allowing you to choose whether the product duplication should be processed synchronously or asynchronously.
- Asynchronous duplication: By setting the
synchronous
field tofalse
in theproductDuplicate
mutation, the operation operates asynchronously, and returns aProductDuplicateOperation
object. - Operation tracking: You can track the status of the asynchronous duplication by querying the operation ID through the
productOperation
query.
Product input
Anchor link to section titled "Product input"We've removed the input
argument on the productCreate
and productUpdate
mutations.
Use the following product
arguments instead:
ProductCreateInput
on theproductCreate
mutationProductUpdateInput
on theproductUpdate
mutation
Product media
Anchor link to section titled "Product media"We've made changes to how you work with product media by replacing the current media ID inputs with file inputs and expanding media capabilities:
The
mediaIds
field on theProductSetInput
input object has been removed. Use thefiles
field instead to associate files to a product.The
mediaId
field on theProductVariantSetInput
input object has been removed. Use thefile
field instead to associate a file with the product variant.The
FileSetInput
input object is now available for working with existing media and creating new files. This input object is a derivative of theFileCreateInput
input object, with an addedid
field.
Product mutations
Anchor link to section titled "Product mutations"We've removed the following deprecated product mutations from the GraphQL Admin API:
productAppendImages
is removed. Use theproductCreateMedia
mutation instead.productDeleteImages
is removed. Use theproductDeleteMedia
mutation instead.productImageUpdate
is removed. Use theproductDeleteMedia
. Use theproductUpdateMedia
mutation instead.productReorderImages
is removed. Use theproductReorderMedia
mutation instead.
Product variant mutations
Anchor link to section titled "Product variant mutations"We've deprecated the following singular product variant mutations in favor of their equivalent bulk versions:
productVariantCreate
is deprecated. Use theproductVariantsBulkCreate
mutation instead.productVariantUpdate
is deprecated. Use theproductVariantsBulkUpdate
mutation instead.productVariantDelete
is deprecated. Use theproductVariantsBulkDelete
mutation instead.
ProductImage value removed
Anchor link to section titled "ProductImage value removed"The PRODUCTIMAGE
value has been removed from the MetafieldOwnerType
enum. Use MEDIA_IMAGE
instead.
ProductInput fields removed
Anchor link to section titled "ProductInput fields removed"We've removed the following deprecated ProductInput
fields from the GraphQL Admin API:
bodyHTML
is removed. Use thedescriptionHtml
field instead.privateMetaFields
is removed. Use theproductOptions
field instead.standardizedProductType
is removed. Use thecategory
field instead.productCategory
is removed. Use thecategory
field instead.customProductType
is removed. Use thecategory
field instead.
Removed fields on ShopFeatures
object
Anchor link to section titled "Removed fields on ShopFeatures object"The following deprecated fields on the ShopFeatures
object have been removed:
avalaraAvatax
branding
captcha
dynamicRemarketing
harmonizedSystemCode
liveView
onboardingVisual
reports
showMetrics
Instead of the branding
field, use Shop.plan.shopifyPlus
instead.
Removed V2
on Fulfillment mutations
Anchor link to section titled "Removed V2 on Fulfillment mutations"We've deprecated the fulfillmentCreateV2
and fulfillmentTrackingInfoUpdateV2
mutations. Use the fulfillmentCreate
and fulfillmentTrackingInfoUpdate
mutations instead.
The behavior of the new mutations remains the same as the previous ones. The only change is the removal of V2
to ensure consistent naming across all mutations.
Reverse fulfillment orders
Anchor link to section titled "Reverse fulfillment orders"The reverseDeliveryDispose
mutation is deprecated. Use the reverseFulfillmentOrderDispose
mutation instead.
The fulfillmentLineItem
field on the ReverseFulfillmentOrderLineItem
object is now nullable. A ReverseFulfillmentOrderLineItem
object won't always be associated with a FulfillmentLineItem
object. The non-null fulfillmentLineItem
field on API versions prior to 2024-10 returns an error when the fulfillment line item doesn't exist.
Learn more about managing reverse fulfillment orders.
Setting available inventory quantity
Anchor link to section titled "Setting available inventory quantity"We've deprecated the ability to set the available quantity on the inventoryActivate
mutation for inventory items that are already in an active state. Use the inventorySetQuantities
mutation instead.
We've also added the INVALID_QUANTITY_TOO_LOW
value to the InventorySetQuantitiesUserErrorCode
enum. The error code is returned if you run the inventorySetQuantities
mutation and a quantity is less than negative one billion.
GraphQL Admin API changes
Anchor link to section titled "GraphQL Admin API changes"The following changes are introduced in the 2024-10 version of the GraphQL Admin API.
Abandoned checkouts
We've added new types that are associated with the AbandonedCheckout
object. This object replaces the Abandoned checkouts
resource in the REST Admin API.
The following new types are available:
Name | Type | Change |
---|---|---|
UnitPriceMeasurement |
Object | Added |
abandonedCheckouts |
Query | Added |
abandonedCheckoutsCount |
Query | Added |
totalWeight |
Field | Added to AbandonedCheckout object |
referringSite |
Field | Added to AbandonedCheckout object |
landingSite |
Field | Added to AbandonedCheckout object |
gateway |
Field | Added to AbandonedCheckout object |
currencyCode |
Field | Added to AbandonedCheckout object |
presentmentCurrencyCode |
Field | Added to AbandonedCheckout object |
token |
Field | Added to AbandonedCheckout object |
cartToken |
Field | Added to AbandonedCheckout object |
customAttributes |
Field | Added to AbandonedCheckout object |
note |
Field | Added to AbandonedCheckout object |
totalLineItemsPriceSet |
Field | Added to AbandonedCheckout object |
subtotalPriceSet |
Field | Added to AbandonedCheckout object |
discountCodes |
Field | Added to AbandonedCheckout object |
totalDiscountSet |
Field | Added to AbandonedCheckout object |
totalTaxSet |
Field | Added to AbandonedCheckout object |
totalDutiesSet |
Field | Added to AbandonedCheckout object |
taxLines |
Field | Added to AbandonedCheckout object |
taxesIncluded |
Field | Added to AbandonedCheckout object |
closedAt |
Field | Added to AbandonedCheckout object |
completedAt |
Field | Added to AbandonedCheckout object |
updatedAt |
Field | Added to AbandonedCheckout object |
createdAt |
Field | Added to AbandonedCheckout object |
shippingLines |
Field | Added to AbandonedCheckout object |
billingAddress |
Field | Added to AbandonedCheckout object |
shippingAddress |
Field | Added to AbandonedCheckout object |
customer |
Field | Added to AbandonedCheckout object |
name |
Field | Added to AbandonedCheckout object |
AbandonedCheckoutShippingLine |
Object | Added |
taxLines |
Field | Added to AbandonedCheckoutLineItem object |
discountAllocations |
Field | Added to AbandonedCheckoutLineItem object |
requiresShipping |
Field | Added to AbandonedCheckoutLineItem object |
weight |
Field | Added to AbandonedCheckoutLineItem object |
fulfillmentService |
Field | Added to AbandonedCheckoutLineItem object |
presentmentVariantTitle |
Field | Added to AbandonedCheckoutLineItem object |
presentmentTitle |
Field | Added to AbandonedCheckoutLineItem object |
source |
Field | Added to TaxLines object |
unitPriceMeasurement |
Field | Added to ProductVariant object |
Adding page links in navigation menus
You can now add links to the Orders, Customer profiles, and Settings pages in navigation menus.
You can use the GraphQL Admin API to update menus that include these pages, and add activated full page extensions to menus, when customer account UI extensions are available for general release. Merchants will also be able to customize their customer account navigation menu. For more information, refer to the product roadmap.
To learn more, refer to the following GraphQL reference documentation:
menuCreate
mutationmenuUpdate
mutationmenu
query
App feedback
We've added the feedbackGeneratedAt
and state
fields to the AppFeedback
object. This field represents the date and time when the app feedback was generated. It conveys the state of the feedback and whether it requires merchant action.
App scopes webhook
Apps can now subscribe to the app/scopes_update
webhook topic. This webhook is triggered when the granted access scopes for the installed app on a shop have been modified. It allows apps to keep track of the granted access scopes of their installations.
Automatic app discounts
We've added the recurringCycleLimit
and appliesOnSubscription
fields on the DiscountAutomaticApp
object and DiscountAutomaticAppInput
input object.
The fields enable merchants to use automatic app discounts for subscriptions, and apply the discounts for a pre-determined number of cycles. Developers can use the fields in their automatic app discount functions.
Business entities
Large merchants with an established international presence need to be able to specify which of their business entities handles sales for a given buyer context. You can now use the GraphQL Admin API to query fields related to the business entities that are enabled on a store.
The following new types are available:
Name | Type | Change |
---|---|---|
businessEntities |
Query | Added |
businessEntity |
Query | Added |
BusinessEntity |
Object | Added |
BusinessEntityAddress |
Object | Added |
businessEntity |
Field | Added to Payout object |
merchantBusinessEntity |
Field | Added to Order object |
Cart and checkout validations
We've added the MAX_VALIDATIONS_ACTIVATED
error code to the ValidationUserErrorCode
enum. The error code is returned when your app exceeds the maximum of five validation functions in checkout.
Cash transactions on POS
We've added the totalCashRoundingAdjustment
field to the Order
object, which allows you to query the total rounding adjustment applied on cash payments or refund transactions in an order on Point of Sale (POS).
Cash transactions on POS are now automatically rounded to the nearest denominations for the some currencies and countries, like CAD (Canada), AUD (Australia), NZD (New Zealand), EUR (Switzerland, Belgium, Finland), DKK (Denmark), Sweden (SEK) and Norway (NOK).
Changed enum value for OrderDisplayFulfillmentStatus
The OrderDisplayFulfillmentStatus
enum now returns a REQUEST_DECLINED
value for an order that has had its fulfillment request rejected by a third-party fulfillment service. In API versions prior to 2024-10, orders in the request rejected state return an UNFULFILLED
status.
Collections count
We've added the collectionsCount
query, which enables you to retrieve a count of all collections in a shop. This includes published and unpublished collections, and custom and smart collections.
Company location staff members
We've added the CompanyLocationStaffMemberAssignment
object, which allows you to retrieve staff members assigned to a company location.
You can assign and remove staff members for a company location using the CompanyLocationAssignStaffMembers
and CompanyLocationRemoveStaffMembers
mutations.
Customer account invite
You can now use the customerSendAccountInvite
mutation to send an email invitation to a customer so that they can create a classic customer account.
We've also added the CustomerSendAccountInviteEmailUserError
that defines errors for the customerSendAccountInvite
mutation.
Customer addresses pagination
We've added the addressesV2
connection to the Customer
object. The addressesV2
connection supports paginating through a customer's addresses, which enables you to retrieve a subset of results at a time.
Customer payment methods
We've added the FAILED_TO_RETRIEVE_BILLING_ADDRESS
value on the CustomerPaymentMethodRevocationReason
enum. The value is returned when a customer payment method is missing the billing address field.
Deleting a fulfillment service
We've introduced the inventoryAction
argument on the fulfillmentServiceDelete
mutation. You can use the argument to specify how to handle inventory when you delete a fulfillment service. Valid values:
KEEP
: Converts a fulfillment service's locations to be merchant-owned. The inventory at the locations becomes the merchant's responsibility. IfKEEP
is provided, then the merchant must have a sufficient remaining quota of locations on their Shopify plan for the operation to succeed. Otherwise, an error is returned.DELETE
: Deletes the inventory at the location and then the location itself. You can only use this option when there are no outstanding fulfillments.TRANSFER
: Relocates the inventory to a specifieddestinationLocationId
. If you specify eitherKEEP
orDELETE
, then you can't also specify adestinationLocationId
.
Delivery options
The presentedName
field has been added to the DeliveryMethod
object. The presentedName
field represents the name of the delivery option that was presented to the customer during checkout.
Deposits for payment terms
You can now set up a percentage-based deposit requirement for your payment terms using the DepositInput
input object. Set up payment terms on company locations using the CompanyCreate
, CompanyLocationCreate
, and CompanyLocationUpdate
mutations.
Discount totals
You can now query the total number of discounts on a shop, automatic and code-based, using the discountNodesCount
query.
Duties on orders
We've added the dutiesIncluded
field to Order
object.
Event query enhancements
We've made the CommentEvent.subject
field nullable. null
is returned when the subject's underlying data has been deleted. You must update your code to handle cases where subject
might return null
. For example, revise existing logic that assumes the field will always contain data, and implement checks or fallback mechanisms to manage situations where the subject
data has been deleted.
We've also deprecated the deletionEvents
query in favour of events that indicate deletion. Update your code to remove any reliance on deletionEvents
, and use the new event structure. To support querying events, we've added the following types:
Name | Type | Change |
---|---|---|
action |
field | Added to Event interface |
event |
Query | Added |
events |
Query | Added |
eventsCount |
Query | Added |
events |
Connection | Added to Article , Blog , Comment , Page , Product , and ProductVariant objects |
EventSubjectType |
Enum | Added |
arguments |
field | Added to BasicEvent object |
subject |
field | Added to BasicEvent object |
subjectID |
field | Added to BasicEvent object |
subjectType |
field | Added to BasicEvent object |
Filtering orders
You can now filter orders by the number of items they contain using the subtotalLineItemsQuantity
field on the Order
object.
You can also filter by an exact number of items, or within a specified range, using the subtotal_line_items_quantity
query filter.
Filtering products
We've added new attributes to the products
query. You can now filter products by the following attributes:
publication_ids
: The IDs of product publications.variant_id
: The ID of the product variant.variant_title
: The title of the product variant.
Fulfillment by Amazon
As of API version 2024-10, the shippingMethods
field on the FulfillmentService
object has been deprecated. The shippingMethods
argument on the fulfillmentOrderSubmitFulfillmentRequest
mutation has also been deprecated.
The shipping method associated with the fulfillment service provider applied only to the Fulfill By Amazon fulfillment service. The Fulfillment by Amazon feature isn't supported as of March 30, 2023. To continue using Amazon fulfillment, merchants need to set up a multi-channel fulfillment solution, as recommended by Amazon.
Fulfillment holds
As of API version 2024-10, apps can't release fulfillment holds unless they have write access to them. You need to request the following access scopes for your app:
write_merchant_managed_fulfillment_orders
: Allows your app to release holds on fulfillment orders assigned to a merchant-managed locationwrite_third_party_fulfillment_orders
: Allows your app to release holds on fulfillment orders assigned to a third-party locationwrite_marketplace_fulfillment_orders
: Allows your app to release holds on fulfillment orders which belong to one of your marketplace's orders
If your app doesn't have sufficient access scopes to release a hold, then a user error with the INVALID_ACCESS
code is returned and the hold isn't released.
We've deprecated the fulfillmentOrdersReleaseHolds
mutation. Use the fulfillmentOrderReleaseHold
mutation instead.
We've also deprecated the GREATER_THAN_ZERO
and INVALID_LINE_ITEM_QUANTITY
error codes on the fulfillmentOrderReleaseHold
mutation.
We've added the id
field to the FulfillmentHold
object. We've also added an optional holdIds
argument to the fulfillmentOrderReleaseHold
mutation. The holdIds
argument enables apps to release a hold by ID, ensuring that only the intended hold is released.
The heldByRequestingApp
field is now available on the FulfillmentHold
object. As of API version 2024-10, you'll only be able to read the heldBy
field on the FulfillmentHold
object if you have the read_apps
scope enabled on your app. Use the heldByRequestingApp
field instead if you need to confirm whether your app created the fulfillment hold.
Additionally, the fulfillmentOrderHold
mutation now returns the fulfillment hold that was created in a new fulfillmentHold
return field.
As well, we've added a localized, displayReason
field to the FulfillmentHold
object. You can use this field to query a human-readable reason when a fulfillment is on hold.
Fulfillment orders webhook
You can now use the created_fulfillment_hold
field on the fulfillment_orders/placed_on_hold
webhook to retrieve the fulfillment hold that was created.
A fulfillment hold is deleted when a hold is released. As a result, it's possible that FulfillmentOrder.FulfillmentHolds
is empty by the time the subscriber receives the webhook. The new created_fulfillment_hold
field always shows the hold that was created, regardless of whether it has already been released and deleted.
Gift cards
We've improved the GiftCard
types and have introduced several new types for working with gift cards. The gift card types are now open to all apps and shops, with no additional approval scopes or flags required.
Developer action required
- The
giftCardDisable
mutation has been removed. UsegiftCardDeactivate
instead. - The
disabledAt
field on theGiftCard
object has been removed. Use thedeactivatedAt
field instead.
The following types for gift cards are now available:
Name | Type | Change |
---|---|---|
CUSTOMER_NOT_FOUND |
Value | Added to GiftCardErrorCode enum |
deactivatedAt |
Field | Added to GiftCard object |
GiftCardCreateInput |
Input object | Added |
giftCardCredit |
Mutation | Added |
GiftCardCreditInput |
Input object | Added |
GiftCardCreditTransaction |
Object | Added |
giftCardDebit |
Mutation | Added |
GiftCardDebitInput |
Input object | Added |
GiftCardDebitTransaction |
Object | Added |
giftCardDeactivate |
Mutation | Added |
GiftCardRecipient |
Object | Added |
GiftCardRecipientInput |
Input object | Added |
giftCardSendNotificationToCustomer |
Mutation | Added |
giftCardSendNotificationToRecipient |
Mutation | Added |
GiftCardTransaction |
Interface | Added |
GiftCardTransactionUserError |
Object | Added |
recipientAttributes |
Field | Added to GiftCard object |
recipientAttributes |
Field | Added to GiftCardCreateInput input object |
recipientAttributes |
Field | Added to GiftCardUpdateInput input object |
RECIPIENT_NOT_FOUND |
Value | Added to GiftCardErrorCode enum |
transactions |
Connection | Added to GiftCard object |
updatedAt |
Field | Added to GiftCard object |
Improvements to the Shop object
We've added the accountOwner
field to the Shop
object. You can use the field to retrieve information about the account owner of a shop. The accountOwner
field returns a StaffMember
object.
Improvements to the StaffMember type
We've made several improvements to the StaffMember
object. These improvements enable apps using the REST Admin API's User
resource to migrate to using the GraphQL Admin API's StaffMember
object.
Shop.staffMembers
has been deprecated. Use thestaffMembers
query instead.- We've added the following new fields to the
StaffMember
object: - You can retrieve the staff member making the API request with the
currentStaffMember
query.
Inventory items
You can now use the optional stockAtLegacyLocation
argument on the inventoryActivate
mutation. Setting the argument to true
allows inventory to be activated if the location ID that's provided is associated with a fulfillment service that doesn't permit SKU sharing.
If an item is activated at a location that doesn't permit SKU sharing, then the item will be deactivated at all other locations.
If an item is currently active at a location that doesn't permit SKU sharing, and you want to activate that item at another location, then you need to set the
stockAtLegacyLocation
argument totrue
.
Inventory quantities
You can use the ProductSetInventoryInput
input object to specify inventory quantities for individual product variants and set available
or on_hand
quantities for new and existing product variants on locations specified.
Linked metafield value error code
We've added the LINKED_METAFIELD_VALUE_WITHOUT_LINKED_OPTION
error code to the ProductOptionsCreateUserError
enum. This error code is returned when the linkedMetafieldValue
can't be specified for an option that isn't linked to a metafield.
Local payment methods
We've added the LocalPaymentMethodsPaymentDetails
object, which allows you to query the details of a local payment method that's related to a transaction.
Location error codes
We've removed the HAS_OPEN_TRANSFERS_ERROR
and FAILED_TO_RELOCATE_OPEN_TRANSFERS
error codes from theLocationDeactivateUserErrorCode
enum. If you're explicitly checking for either of these error codes in your app, then you should remove references to them.
Metafield capabilities
Metafield capabilities provide a way to include logic with your metafields. When you create a metafield definition, you can now enable capabilities
that provide additional behaviors.
You can enable the following capabilities:
- Smart collection: Create an automated collection based on metafield values for a given definition.
- Admin filterable: Filter products based on metafield values for a definition.
Metafield definitions
We've deprecated the definitions.visibleToStorefrontApi
argument on the standardMetafieldDefinitionEnable
and standardMetafieldDefinitionsEnable
mutations. Use the definitions.access
argument on these mutations instead.
Metafield definition webhooks
You can subscribe to MetafieldDefinition
webhook changes under the webhook topics:
Metafield-linked product options
In the 2024-04 API version release, we introduced the ability to use the productOptionsCreate
, productCreate
, and productOptionUpdate
mutations to create metafield-linked product options.
As of API version 2024-10, we've added more fields and error codes to support linking metafields to product options.
Available types
Name | Type | Change |
---|---|---|
linkedMetafield |
Field | Added to OptionSetInput input object |
linkedMetafieldValue |
Field | Added to VariantOptionValueInput input object |
CANNOT_COMBINE_LINKED_AND_NONLINKED_OPTION_VALUES |
Error code | Added to ProductSetUserErrorCode enum |
INVALID_METAFIELD_VALUE_FOR_LINKED_OPTION |
Error code | Added to ProductSetUserErrorCode enum |
DUPLICATE_LINKED_OPTION |
Error code | Added to ProductSetUserErrorCode enum |
LINKED_OPTIONS_NOT_SUPPORTED_FOR_SHOP |
Error code | Added to ProductSetUserErrorCode enum |
LINKED_METAFIELD_DEFINITION_NOT_FOUND |
Error code | Added to ProductSetUserErrorCode enum |
Metafields support for the cartTransformCreate mutation
We've added the metafields
argument to the cartTransformCreate
mutation. You can use the argument to set metafields for a CartTransform
object at creation without needing to call the metafieldsSet
mutation in a subsequent call.
Online store
We've deprecated the OnlineStorePage
, OnlineStoreArticle
, and OnlineStoreBlog
objects. Use the Page
, Article
, and Blog
objects instead.
You can now read and modify pages, articles, blogs, and comments. The following types are now available:
Name | Type | Change |
---|---|---|
pageCreateInput |
Input object | Added |
pageUpdateInput |
Input object | Added |
pageCreate |
Mutation | Added |
pageUpdate |
Mutation | Added |
pageDelete |
Mutation | Added |
page |
Query | Added |
pages |
Query | Added |
pagesCount |
Query | Added |
PAGE |
Value | Added to TranslatableResourceType enum |
ArticleAuthor |
Object | Added |
ArticleBlogInput |
Input object | Added |
ArticleCreateInput |
Input object | Added |
ArticleImageInput |
Input object | Added |
ArticleUpdateInput |
Input object | Added |
articleCreate |
Mutation | Added |
articleUpdate |
Mutation | Added |
articleDelete |
Mutation | Added |
article |
Query | Added |
articles |
Query | Added |
ARTICLE |
Value | Added to TranslatableResourceType enum |
AuthorInput |
Input object | Added |
BlogCreateInput |
Input object | Added |
BlogUpdateInput |
Input object | Added |
BlogFeed |
Object | Added |
blogCreate |
Mutation | Added |
blogUpdate |
Mutation | Added |
blogDelete |
Mutation | Added |
blog |
Query | Added |
blogs |
Query | Added |
blogsCount |
Query | Added |
BLOG |
Value | Added to TranslatableResourceType enum |
Comment |
Object | Added |
CommentAuthor |
Object | Added |
commentApprove |
Mutation | Added |
commentSpam |
Mutation | Added |
commentNotSpam |
Mutation | Added |
commentDelete |
Mutation | Added |
comment |
Query | Added |
comments |
Query | Added |
CommentStatus |
Enum | Added |
CommentPolicy |
Enum | Added |
MENU |
Value | Added to TranslatableResourceType enum |
Optional access scopes
We've added the optionalAccessScopes
field to the App
object so that apps can declare some scopes as optional within their configuration. This field allows merchants to progressively grant apps access to data in their store.
Order adjustments
We've added the OrderAdjustment
object, which represents the difference between a calculated and an actual refund amount. We've also added the orderAdjustment
connection on the Refund
object, allowing you to retrieve order adjustments that are attached to a refund.
Order create
You can now use the orderCreate
mutation to create an order.
Order line items
We've removed the lineItemsMutable
connection on the Order
object. Use the lineItems
connection on the Order
object instead.
Order management apps
The write_third_party_fulfillment_orders
access scope no longer allows order management apps to fulfill fulfillment orders assigned to locations that are owned by other fulfillment service apps. Order management apps will still be able to access and manage these orders, but fulfillment creation will be prohibited.
The write_assigned_fulfillment_orders
and write_merchant_managed_fulfillment_orders
access scopes remain unchanged. Fulfillment service apps can still fulfill orders that are assigned to them, as long as they're granted the write_assigned_fulfillment_orders
access scope. Fulfillment orders that are assigned to merchant-managed locations are still fulfillable by order management apps, as long as they're granted the write_merchant_managed_fulfillment_orders
access scope.
Apps can confirm whether fulfillment creation is possible by querying supported actions using the GraphQL Admin API. If the fulfillment order is assigned to a merchant-managed location or to the fulfillment service performing the query and it's in a fulfillable state, then the CREATE_FULFILLMENT
action is returned as a possible option.
Order status
We've added the statusPageUrl
field to the Order
object, allowing you to retrieve the URL where the customer can check the order's current status.
Pickup locations
You can now use the destination
field on the fulfillmentOrder
object to retrieve the pickup location for a fulfillment order.
As of API version 2024-10, the destination
field returns a FulfillmentOrderDestination
object instead of null
for fulfillment orders that don't have an associated shipping address. If the fulfillment order doesn't have a shipping address, then the address-related fields within the FulfillmentOrderDestination
object are set to null
.
PriceRule types removed
As of API version 2024-10, we've removed PriceRule
types from the GraphQL Admin API. The associated queries and mutations have been deprecated since API version 2023-03. Use the discountNode
query instead.
The following types have been removed:
PriceRuleUserError
objectPriceRuleCustomerSelectionInput
input objectPriceRuleDiscountCodeInput
input objectPriceRuleEntitlementToPrerequisiteQuantityRatioInput
input objectPriceRuleInput
input objectPriceRuleItemEntitlementsInput
input objectPriceRuleItemPrerequisitesInput
input objectPriceRuleMoneyRangeInput
input objectPriceRulePrerequisiteToEntitlementQuantityRatioInput
input objectPriceRuleQuantityRangeInput
input objectPriceRuleShippingEntitlementsInput
input objectPriceRuleValidityPeriodInput
input objectPriceRuleValueInput
input objectpriceRuleSavedSearches
queryPriceRuleActivate
mutationPriceRuleCreate
mutationPriceRuleDeactivate
mutationPriceRuleDelete
mutationPriceRuleDiscountCodeCreate
mutationPriceRuleDiscountCodeUpdate
mutationPriceRuleUpdate
mutationpriceRule
field on theQueryRoot
objectpriceRules
connection on theQueryRoot
objectpriceRules
connection on theShop
objectpriceRuleSavedSearches
connection on theShop
object
ProductImage value removed
The PRODUCTIMAGE
value has been removed from the MetafieldOwnerType
enum. Use MEDIA_IMAGE
instead.
ProductInput fields removed
We've removed the following deprecated ProductInput
fields from the GraphQL Admin API:
bodyHTML
is removed. Use thedescriptionHtml
field instead.privateMetaFields
is removed. Use theproductOptions
field instead.standardizedProductType
is removed. Use thecategory
field instead.productCategory
is removed. Use thecategory
field instead.customProductType
is removed. Use thecategory
field instead.
Product deletions
We've added the synchronous
argument to the productDelete
mutation. The field allows you to choose whether a product should be deleted synchronously or asynchronously.
- Asynchronous deletion: By setting the
synchronous
field tofalse
in theproductDelete
mutation, the operation proceeds asynchronously, and returns aProductDeleteOperation
object. - Operation tracking: You can track the status of the asynchronous deletion by querying the operation ID through the
productOperation
query.
Product duplications
The productDuplicateAsyncV2
mutation has been removed. We've added the synchronous
argument to the productDuplicate
mutation, allowing you to choose whether the product duplication should be processed synchronously or asynchronously.
- Asynchronous duplication: By setting the
synchronous
field tofalse
in theproductDuplicate
mutation, the operation operates asynchronously, and returns aProductDuplicateOperation
object. - Operation tracking: You can track the status of the asynchronous duplication by querying the operation ID through the
productOperation
query.
Product input
We've removed the input
argument on the productCreate
and productUpdate
mutations.
Use the following product
arguments instead:
ProductCreateInput
on theproductCreate
mutationProductUpdateInput
on theproductUpdate
mutation
Product media
We've made changes to how you work with product media by replacing the current media ID inputs with file inputs and expanding media capabilities:
The
mediaIds
field on theProductSetInput
input object has been removed. Use thefiles
field instead to associate files to a product.The
mediaId
field on theProductVariantSetInput
input object has been removed. Use thefile
field instead to associate a file with the product variant.The
FileSetInput
input object is now available for working with existing media and creating new files. This input object is a derivative of theFileCreateInput
input object, with an addedid
field.
Product mutations
We've removed the following deprecated product mutations from the GraphQL Admin API:
productAppendImages
is removed. Use theproductCreateMedia
mutation instead.productDeleteImages
is removed. Use theproductDeleteMedia
mutation instead.productImageUpdate
is removed. Use theproductDeleteMedia
. Use theproductUpdateMedia
mutation instead.productReorderImages
is removed. Use theproductReorderMedia
mutation instead.
Product restrictions
We've added the restrictedForResource
field to the Product
object. The field allows you to query product restrictions for a given CalculatedOrder
object, and returns both the restricted status and the reason for the restriction.
Product taxonomy
We've deprecated the PRODUCT_TAXONOMY_NODE_ID
value on the CollectionRuleColumn
enum, which is used when creating automated collections. Use the PRODUCT_CATEGORY_ID
value instead.
For more information, refer to the developer changelog.
Product variant mutations
We've deprecated the following singular product variant mutations in favor of their equivalent bulk versions:
productVariantCreate
is deprecated. Use theproductVariantsBulkCreate
mutation instead.productVariantUpdate
is deprecated. Use theproductVariantsBulkUpdate
mutation instead.productVariantDelete
is deprecated. Use theproductVariantsBulkDelete
mutation instead.
Product variants count
We've added the productVariantsCount
query to the GraphQL Admin API to provide parity with the REST Admin API's ProductVariant
count endpoint.
Product variants strategy
We've added the variantStrategy
argument to the productOptionsCreate
mutation, which enables more precise control over product variant configuration and inventory management.
The variantStrategy
argument includes the following input fields:
CREATE
: Generates new product variants for all possible combinations of option values.LEAVE_AS_IS
: Updates existing variants to include new option values, without creating new variants.
Products webhook topics
The PRODUCTS_CREATE
and PRODUCTS_UPDATE
webhook payloads now contain the following fields:
has_variants_that_requires_components
: Indicates whether a product has a variant that's a product bundle. The field mirrors thehasVariantsThatRequiresComponents
field on theProduct
object.category
: Information about the product category associated with a product. Thecategory
field exposes a trimmed version of fields that are available on theProduct
object.
Redirects count
You can now use the urlRedirectsCount
query to retrieve a count of redirects. Previously, this functionality was only available using the REST Admin API.
Refunding multiple shipping lines
You can now refund multiple shipping lines using the shipping
field on the RefundInput
input object or refundShipping
field on the ReturnRefundInput
input object.
For more information, refer to the developer changelog.
Removed fields on ShopFeatures object
The following deprecated fields on the ShopFeatures
object have been removed:
avalaraAvatax
branding
captcha
dynamicRemarketing
harmonizedSystemCode
liveView
onboardingVisual
reports
showMetrics
Instead of the branding
field, use Shop.plan.shopifyPlus
instead.
Removed V2 on Fulfillment mutations
We've deprecated the fulfillmentCreateV2
and fulfillmentTrackingInfoUpdateV2
mutations. Use the fulfillmentCreate
and fulfillmentTrackingInfoUpdate
mutations instead.
The behavior of the new mutations remains the same as the previous ones. The only change is the removal of V2
to ensure consistent naming across all mutations.
Return approvals and rejections
We've added the notifyCustomer
field on the ReturnApproveRequestInput
input object and the ReturnDeclineRequestInput
input object.
We've also added the declineNote
field on the ReturnDeclineRequestInput
input object, which represents the notification message that's sent to a customer about their declined return request.
Reverse fulfillment orders
The reverseDeliveryDispose
mutation is deprecated. Use the reverseFulfillmentOrderDispose
mutation instead.
The fulfillmentLineItem
field on the ReverseFulfillmentOrderLineItem
object is now nullable. A ReverseFulfillmentOrderLineItem
object won't always be associated with a FulfillmentLineItem
object. The non-null fulfillmentLineItem
field on API versions prior to 2024-10 returns an error when the fulfillment line item doesn't exist.
Rounding adjustments on cash amounts
We've added the amountRounding
field on the OrderTransaction
object. The amountRounding
field represents the rounding adjustment applied on a cash amount in presentment currency.
Setting available inventory quantity
We've deprecated the ability to set the available quantity on the inventoryActivate
mutation for inventory items that are already in an active state. Use the inventorySetQuantities
mutation instead.
We've also added the INVALID_QUANTITY_TOO_LOW
value to the InventorySetQuantitiesUserErrorCode
enum. The error code is returned if you run the inventorySetQuantities
mutation and a quantity is less than negative one billion.
Shop owner name
We've added the shopOwnerName
field to the Shop
object. The field returns the shop owner's first and last name.
Shopify Payments disputes
You can now use the ShopifyPaymentsDispute
object to query all Shopify Payments disputes that are associated with a store.
We've also added the ADVANCE
and ADVANCE_FUNDING
values to the ShopifyPaymentsTransactionType
enum.
Shopify Payments payouts
We've added the advanceFees
and advanceGross
fields to the ShopifyPaymentsPayoutSummary
object.
Subscription billing attempts
We've added the transactions
connection to the SubscriptionBillingAttempt
object. The connection returns the transactions that are created by billing attempts.
Subscription contracts
We've added the lastBillingAttemptErrorType
field to the SubscriptionContract
object. You can use this field to determine the billing error type when a billing attempt fails.
Tender transactions
We've added the order
field to the TenderTransaction
object. You can use the field to retrieve an order that's related to a transaction with financial impact on a store's balance sheet. If the order has been deleted, then the value is null
.
Translatable resources
We've added the ONLINE_STORE_THEME_APP_EMBED
value to the TranslatableResourceType
enum. You can use this value to query the translatable content for an embedded app.
REST Admin API changes
Anchor link to section titled "REST Admin API changes"The following changes are introduced in the 2024-10 version of the REST Admin API.
Business entities
Large merchants with an established international presence need to be able to specify which of their business entities handles sales for a given buyer context. You can now use the REST Admin API to request the business entity ID (merchant_business_entity_id
) associated with an order.
Comment events
On the Event
resource, we now return null
when underlying subject data has been deleted. You must update your code to handle null
cases. For example, revise existing logic that assumes the field will always contain data, and implement checks or fallback mechanisms to manage situations where subject data has been deleted.
Delivery options
The presented_name
property has been added to the FulfillmentOrder
resource. The presented_name
property represents the name of the delivery option that was presented to the customer during checkout.
Location resource
If your app retrieves a Location
resource, then you need to request the read_locations
access scope.
If your app reads a Location
resource without the read_locations
access scope, then a 403 Forbidden error is returned.
Products webhook topics
The products/create
and products/update
webhook payloads now contain the following properties:
has_variants_that_requires_components
: Indicates whether a product has a variant that's a product bundlecategory
: Information about the product category that's associated with a product
Refunding multiple shipping lines
You can now refund multiple shipping lines using the Refunds
resource in the REST Admin API.
For more information, refer to the developer changelog.
Rounding adjustments on cash amounts
We've added the amount_rounding
property on the Transaction
resource. The amount_rounding
property represents the rounding adjustment applied on a cash amount in presentment currency.
Storefront API changes
Anchor link to section titled "Storefront API changes"The following changes are introduced in the 2024-10 version of the Storefront API.
Cart warnings
Inventory errors about stock levels are no longer included in the userErrors
of cart mutations. Inventory errors are now available in the warnings
return field, and contain the following explicit values:
MERCHANDISE_NOT_ENOUGH_STOCK
MERCHANDISE_OUT_OF_STOCK
Warnings are available on all cart mutations to show automatic changes that occurred while executing the mutation. You can use warnings to manage items in your cart or display information to a buyer. For example, you can remove out-of-stock lines from a cart by using the target
field included in the warning
as the input to the cartLinesRemove
mutation.
Shop Pay installments pricing
We've added ShopPayInstallmentsPricing
fields to the Shop
and ProductVariant
types. In the future, Hydrogen will support using these fields to display the Shop Pay installments banner on the product page. These require the unauthenticated_read_shop_pay_installments_pricing
access scope.
Combined listings support
You can now query combined listings products.
The options
field on the Product
object returns options and values for both parent and child products. We've also added the following fields to simplify working with complex products:
Product.adjacentVariants
Product.selectedOrFirstAvailableVariant
Product.encodedVariantAvailability
Product.encodedVariantExistence
ProductOptionValue.firstSelectableVariant
In the future, you'll be able to use these fields in Hydrogen to build option pickers and display combined listings and other complex products on a storefront.
Shopify Function APIs changes
Anchor link to section titled "Shopify Function APIs changes"The following changes are introduced in the 2024-10 version of Shopify Function APIs.
Fulfillment constraints
You can now associate a fulfillment constraint function to one or multiple delivery methods, such as SHIPPING
and PICKUP
. The function will only run under the context of the specified delivery methods.
We've added the deliveryMethodTypes
field to the FulfillmentConstraintRule
object. You can use the fulfillmentConstraintRuleCreate
mutation to register your fulfillment constraint function and associate it with one or more delivery methods.
Use the fulfillmentConstraintRuleUpdate
mutation to update delivery methods for an existing registered function.
Metafields support for the cartTransformCreate mutation
We've added the metafields
argument to the cartTransformCreate
mutation. You can use the argument to set metafields for a CartTransform
object at creation without needing to call the metafieldsSet
mutation in a subsequent call.
Customer Account API changes
Anchor link to section titled "Customer Account API changes"The following changes are introduced in the 2024-10 version of the Customer Account API.
Deposits for payment terms
You can now query the percentage-based deposit requirement for your payment terms on company locations.
Subscription contracts
We've added new types for subscription contracts. The customer_read_own_subscription_contracts
permission is now required to query subscription contracts and the customer_write_own_subscription_contracts
permission is required to run subscription contracts mutations.
The following new types for managing subscription contracts are available: