Product object
Represents a product, including information about related collections and product variants.
Required access
read_products
access scope.
On this page
Connections
- collections (
[CollectionConnection!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/collection)
)
A list of the collections that include the product.
Argument | Description |
---|---|
after ( [String](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01) ) |
Returns the elements that come after the specified cursor. |
before ( [String](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01) ) |
Returns the elements that come before the specified cursor. |
first ( [Int](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01) ) |
Returns up to the first n elements from the list. |
last ( [Int](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01) ) |
Returns up to the last n elements from the list. |
query ( [String](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01) ) |
Supported filter parameters: + collection_type + publishable_status + published_status + title + updated_at See the detailed search syntax for more information about using filters. |
reverse ( [Boolean](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01) ) |
Reverse the order of the underlying list. Default value: false |
sortKey ( [CollectionSortKeys](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/collectionsortkeys) ) |
Sort the underlying list by the given key. Default value: ID |
- images (
[ImageConnection!](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/imageconnection)
)
The images associated with the product.
- media (
[MediaConnection!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/media)
)
The media associated with the product.
- metafields (
[MetafieldConnection!](https://shopify.dev/docs/admin-api/graphql/reference/metafields/metafieldconnection)
)
A paginated list of metafields associated with the resource.
- privateMetafields (
[PrivateMetafieldConnection!](https://shopify.dev/docs/admin-api/graphql/reference/metafields/privatemetafieldconnection)
)
List of private metafields.
- resourcePublications (
[ResourcePublicationConnection!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/resourcepublication)
)
The list of resources that are published to a publication.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores.
- resourcePublicationsV2 (
[ResourcePublicationV2Connection!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/resourcepublicationv2)
)
The list of resources that are either published or staged to be published to a publication.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores.
- unpublishedPublications (
[PublicationConnection!](https://shopify.dev/docs/admin-api/graphql/reference/apps/publicationconnection)
)
The list of publications that the resource is not published to.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores.
- variants (
[ProductVariantConnection!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productvariant)
)
A list of variants associated with the product.
Fields
- availablePublicationCount (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
The number of publications a resource is published to without feedback errors.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores. - createdAt (
[DateTime!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#datetime-2021-01)
)
The date and time (ISO 8601 format) when the product was created. - defaultCursor (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
A default cursor for use in pagination. - description (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
A stripped description of the product, single line with HTML tags removed.
Argument | Description |
---|---|
truncateAt ( [Int](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01) ) |
Truncates string after the given length. |
- descriptionHtml (
[HTML!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#html-2021-01)
)
The description of the product, complete with HTML formatting. - featuredImage (
[Image](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/image)
)
The featured image for the product. - featuredMedia (
[Media](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/media)
)
The featured media for the product. - feedback (
[ResourceFeedback](https://shopify.dev/docs/admin-api/graphql/reference/apps/resourcefeedback)
)
Information about the product that’s provided through resource feedback. - giftCardTemplateSuffix (
[String](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
The theme template used when viewing the gift card in a store. - handle (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
A unique human-friendly string of the product’s title. - hasOnlyDefaultVariant (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether the product has only a single variant with the default option and value. - hasOutOfStockVariants (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether the product has out of stock variants. - id (
[ID!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#id-2021-01)
)
Globally unique identifier. - inCollection (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether the product is in a given collection.
Argument | Description |
---|---|
id ( [ID!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#id-2021-01) ) REQUIRED |
The ID of the collection to check. |
- isGiftCard (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether the product is a gift card. - legacyResourceId (
[UnsignedInt64!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#unsignedint64-2021-01)
)
The ID of the corresponding resource in the REST Admin API. - mediaCount (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
Total count of media belonging to a product. - metafield (
[Metafield](https://shopify.dev/docs/admin-api/graphql/reference/metafields/metafield)
)
The metafield associated with the resource.
- onlineStorePreviewUrl (
[URL](https://shopify.dev/docs/admin-api/graphql/reference/scalar#url-2021-01)
)
The online store preview URL. - onlineStoreUrl (
[URL](https://shopify.dev/docs/admin-api/graphql/reference/scalar#url-2021-01)
)
The online store URL for the product. A value ofnull
indicates that the product is not published to the Online Store sales channel. - options (
[[ProductOption!]!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productoption)
)
A list of product options. The limit is specified by Shop.resourceLimits.maxProductOptions.
Argument | Description |
---|---|
first ( [Int](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01) ) |
Truncate the array result to this size. |
- priceRangeV2 (
[ProductPriceRangeV2!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productpricerangev2)
)
The price range of the product with prices formatted as decimals. - privateMetafield (
[PrivateMetafield](https://shopify.dev/docs/admin-api/graphql/reference/metafields/privatemetafield)
)
Returns a private metafield found by namespace and key.
- productType (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
The product type specified by the merchant. - publicationCount (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
The number of publications a resource is published on.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores.
- publishedAt (
[DateTime](https://shopify.dev/docs/admin-api/graphql/reference/scalar#datetime-2021-01)
)
The date and time (ISO 8601 format) when the product was published to the Online Store. - publishedOnCurrentPublication (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Check to see whether the resource is published to the calling app’s publication.
Required accessread_product_listings
access scope. - publishedOnPublication (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Check to see whether the resource is published to a given publication.
Required accessread_publications
access scope. This scope is currently available only to private apps installed on Shopify Plus stores.
Argument | Description |
---|---|
publicationId ( [ID!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#id-2021-01) ) REQUIRED |
The ID of the publication to check. |
- requiresSellingPlan (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether the product can only be purchased with a selling plan. - sellingPlanGroupCount (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
Count of selling plan groups associated with the product. - seo (
[SEO!](https://shopify.dev/docs/admin-api/graphql/reference/online-store/seo)
)
SEO information of the product. - status (
[ProductStatus!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productstatus)
)
The product status. - storefrontId (
[StorefrontID!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#storefrontid-2021-01)
)
The storefront ID of the product. - tags (
[[String!]!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
A comma separated list of tags associated with the product. Updatingtags
overwrites any existing tags that were previously added to the product. To add new tags without overwriting existing tags, use the tagsAdd mutation. - templateSuffix (
[String](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
The theme template used when viewing the product in a store. - title (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
The title of the product. - totalInventory (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
The quantity of inventory in stock. - totalVariants (
[Int!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#int-2021-01)
)
The number of variants that are associated with the product. - tracksInventory (
[Boolean!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#boolean-2021-01)
)
Whether inventory tracking has been enabled for the product. - translations (
[[PublishedTranslation!]!](https://shopify.dev/docs/admin-api/graphql/reference/translations/publishedtranslation)
)
The translations associated with the resource.
Argument | Description |
---|---|
locale ( [String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01) ) REQUIRED |
Filters translations locale. |
- updatedAt (
[DateTime!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#datetime-2021-01)
)
The date and time when the product was last modified. A product’supdatedAt
value can change for different reasons. For example, if an order is placed for a product that has inventory tracking set up, then the inventory adjustment is counted as an update. - vendor (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
The name of the product’s vendor.
Types that return Product
[CalculatedDraftOrderLineItem.product](https://shopify.dev/docs/admin-api/graphql/reference/orders/calculateddraftorderlineitem#product-2021-01)
[Channel.products](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/channel#products-2021-01)
[Collection.products](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/collection#products-2021-01)
[DeliveryProfileItem.product](https://shopify.dev/docs/admin-api/graphql/reference/shipping-and-fulfillment/deliveryprofileitem#product-2021-01)
[DiscountProducts.products](https://shopify.dev/docs/admin-api/graphql/reference/discounts-and-marketing/discountproducts#products-2021-01)
[DraftOrderLineItem.product](https://shopify.dev/docs/admin-api/graphql/reference/orders/draftorderlineitem#product-2021-01)
[LineItem.product](https://shopify.dev/docs/admin-api/graphql/reference/orders/lineitem#product-2021-01)
[LineItemMutable.product](https://shopify.dev/docs/admin-api/graphql/reference/orders/lineitemmutable#product-2021-01)
[PriceRuleItemEntitlements.products](https://shopify.dev/docs/admin-api/graphql/reference/discounts-and-marketing/priceruleitementitlements#products-2021-01)
[PriceRuleLineItemPrerequisites.products](https://shopify.dev/docs/admin-api/graphql/reference/discounts-and-marketing/pricerulelineitemprerequisites#products-2021-01)
[ProductPublication.product](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productpublication#product-2021-01)
[ProductVariant.product](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/productvariant#product-2021-01)
[Publication.products](https://shopify.dev/docs/admin-api/graphql/reference/apps/publication#products-2021-01)
[QueryRoot.product](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/queryroot#product-2021-01)
[QueryRoot.productByHandle](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/queryroot#productbyhandle-2021-01)
[QueryRoot.products](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/queryroot#products-2021-01)
[SellingPlanGroup.products](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/sellingplangroup#products-2021-01)
Mutations for Product
- productAppendImages
Appends images to a product. - productChangeStatus
Change status of a product. - productCreate
Creates a product. Products that are sold exclusively on subscription (requiresSellingPlan: true
) can only be created on online stores. - productCreateMedia
Creates media for a product. - productDelete
Deletes a product. - productDeleteImages
Removes a product images from the product. - productDeleteMedia
Deletes media for a product. - productDuplicate
Duplicates a product. - productImageUpdate
Updates an image of a product. - productJoinSellingPlanGroups
Adds multiple selling plan groups to a product. - productLeaveSellingPlanGroups
Removes multiple groups from a product. - productReorderImages
Asynchronously reorders a set of images for a given product. - productReorderMedia
Asynchronously Reoders the media attached to a product. - productUpdate
Updates a product. Products that are sold exclusively on subscription (requiresSellingPlan: true
) can be updated only on online stores. If you update a product to be sold only on a subscription, then the product is unpublished from all channels except the online store. - productUpdateMedia
Updates media for a product.
Implements
[HasMetafields](https://shopify.dev/docs/admin-api/graphql/reference/metafields/hasmetafields)
[HasPublishedTranslations](https://shopify.dev/docs/admin-api/graphql/reference/translations/haspublishedtranslations)
[LegacyInteroperability](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/legacyinteroperability)
[Navigable](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/navigable)
[Node](https://shopify.dev/docs/admin-api/graphql/reference/common-objects/node)
[OnlineStorePreviewable](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/onlinestorepreviewable)
[Publishable](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/publishable)
Deprecated fields
Show/Hide
An auto-generated type for paginating through multiple Products.
On this page
Fields
- edges (
[[ProductEdge!]!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/product)
)
A list of edges. - pageInfo (
[PageInfo!](https://shopify.dev/docs/admin-api/graphql/reference/pageinfo)
)
Information to aid in pagination.
An auto-generated type which holds one Product and a cursor during pagination.
On this page
Fields
- cursor (
[String!](https://shopify.dev/docs/admin-api/graphql/reference/scalar#string-2021-01)
)
A cursor for use in pagination. - node (
[Product!](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/product)
)
The item at the end of ProductEdge.
Types that return ProductEdge
[ProductConnection.edges](https://shopify.dev/docs/admin-api/graphql/reference/products-and-collections/product#edges-2021-01)