---
title: Publication - GraphQL Admin
description: >-
  A group of
  [products](https://shopify.dev/docs/api/admin-graphql/latest/objects/Product)
  and
  [collections](https://shopify.dev/docs/api/admin-graphql/latest/objects/Collection)

  that are published to an app.


  Each publication manages which products and collections display on its
  associated

  [`Channel`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Channel).

  Merchants can automatically publish products when they're created if
  [`autoPublish`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication#field-Publication.fields.autoPublish)

  is enabled, or manually control publication through publication records.


  Publications support scheduled publishing through future publish dates for

  online store channels, allowing merchants to coordinate product launches and

  promotional campaigns. The
  [`catalog`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication#field-Publication.fields.catalog)

  field links to pricing and availability rules specific to that publication's
  context.
api_version: 2026-04
source_url:
  html: 'https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication'
  md: 'https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication.md'
api_name: admin
api_type: graphql
type: object
metadata:
  domain: admin
---

# Publication

object

A group of [products](https://shopify.dev/docs/api/admin-graphql/latest/objects/Product) and [collections](https://shopify.dev/docs/api/admin-graphql/latest/objects/Collection) that are published to an app.

Each publication manages which products and collections display on its associated [`Channel`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Channel). Merchants can automatically publish products when they're created if [`autoPublish`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication#field-Publication.fields.autoPublish) is enabled, or manually control publication through publication records.

Publications support scheduled publishing through future publish dates for online store channels, allowing merchants to coordinate product launches and promotional campaigns. The [`catalog`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication#field-Publication.fields.catalog) field links to pricing and availability rules specific to that publication's context.

## Fields

* auto​Publish

  [Boolean!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

  non-null

  Whether new products are automatically published to this publication.

* catalog

  [Catalog](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Catalog)

  The catalog associated with the publication.

* channels

  [Channel​Connection](https://shopify.dev/docs/api/admin-graphql/latest/connections/ChannelConnection)

  The channels associated with the publication.

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  ***

* collection​Publications​V3

  [Resource​Publication​Connection!](https://shopify.dev/docs/api/admin-graphql/latest/connections/ResourcePublicationConnection)

  non-null

  The list of collection publication records, each representing the publication status and details for a collection published to this publication (typically channel).

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  ***

* collections

  [Collection​Connection!](https://shopify.dev/docs/api/admin-graphql/latest/connections/CollectionConnection)

  non-null

  The list of collections published to the publication.

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  ***

* has​Collection

  [Boolean!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

  non-null

  Whether the collection is available to the publication.

  * id

    [ID!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    required

    ### Arguments

    Collection ID to check.

  ***

* id

  [ID!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

  non-null

  A globally-unique ID.

* included​Products

  [Product​Connection!](https://shopify.dev/docs/api/admin-graphql/latest/connections/ProductConnection)

  non-null

  The list of products included, but not necessarily published, in the publication.

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * query

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    A filter made up of terms, connectives, modifiers, and comparators.

    | name | type | description | acceptable\_values | default\_value | example\_use |
    | - | - | - | - | - | - |
    | default | string | Filter by a case-insensitive search of multiple fields | | | |
    | in a document. | | | - `query=Bob Norman` - `query=title:green hoodie` | | |
    | barcode | string | Filter by the product variant [`barcode`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-barcode) | | | |
    | field. | | | - `barcode:ABC-abc-1234` | | |
    | bundles | boolean | Filter by a \[product | | | |
    | bundle]\(<https://shopify.dev/docs/apps/build/product-merchandising/bundles>). | | | | | |
    | A product bundle is a set of two or more related products, which are | | | | | |
    | commonly offered at a discount. | | | - `bundles:true` | | |
    | category\_id | string | Filter by the product [category ID](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-category) | | | |
    | (`product.category.id`). A product category is the category of a product | | | | | |
    | from [Shopify's Standard Product Taxonomy](https://shopify.github.io/product-taxonomy/releases/unstable/?categoryId=sg-4-17-2-17). | | | | | |
    | | | - `category_id:sg-4-17-2-17` | | | |
    | collection\_id | id | Filter by the collection [`id`](https://shopify.dev/api/admin-graphql/latest/objects/Collection#field-id) | | | |
    | field. | | | - `collection_id:108179161409` | | |
    | combined\_listing\_role | string | Filter by the role of the product in a [combined listing](https://shopify.dev/apps/build/product-merchandising/combined-listings). | | | |
    | - `parent` - `child` - `no_role` | | - | | | |
    | `combined_listing_role:parent` | | | | | |
    | created\_at | time | Filter by the date and time when the product was | | | |
    | created. | | | - `created_at:>'2020-10-21T23:39:20Z'` - | | |
    | `created_at:<now` - `created_at:<='2024'` | | | | | |
    | delivery\_profile\_id | id | Filter by the delivery profile [`id`](https://shopify.dev/api/admin-graphql/latest/objects/DeliveryProfile#field-id) | | | |
    | field. | | | - `delivery_profile_id:108179161409` | | |
    | error\_feedback | string | Filter by products with publishing errors. | | | |
    | gift\_card | boolean | Filter by the product [`isGiftCard`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-isgiftcard) | | | |
    | field. | | | - `gift_card:true` | | |
    | handle | string | Filter by a comma-separated list of product [handles](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-handle). | | | |
    | | | - `handle:the-minimal-snowboard` | | | |
    | has\_only\_composites | boolean | Filter by products that have only | | | |
    | composite variants. | | | - `has_only_composites:true` | | |
    | has\_only\_default\_variant | boolean | Filter by products that have only a | | | |
    | default variant. A default variant is the only variant if no other variants | | | | | |
    | are specified. | | | - `has_only_default_variant:true` | | |
    | has\_variant\_with\_components | boolean | Filter by products that have | | | |
    | variants with associated components. | | | - | | |
    | `has_variant_with_components:true` | | | | | |
    | id | id | Filter by `id` range. | | | - `id:1234` - `id:>=1234` - `id:<=1234` |
    | inventory\_total | integer | Filter by inventory count. | | | - |
    | `inventory_total:0` - `inventory_total:>150` - | | | | | |
    | `inventory_total:>=200` | | | | | |
    | is\_price\_reduced | boolean | Filter by products that have a reduced price. | | | |
    | For more information, refer to the [`CollectionRule`](https://shopify.dev/api/admin-graphql/latest/objects/CollectionRule) | | | | | |
    | object. | | | - `is_price_reduced:true` | | |
    | metafields.{namespace}.{key} | mixed | Filters resources by metafield | | | |
    | value. Format: `metafields.{namespace}.{key}:{value}`. Learn more about | | | | | |
    | [querying by metafield value](https://shopify.dev/apps/build/custom-data/metafields/query-by-metafield-value). | | | | | |
    | | | - `metafields.custom.on_sale:true` - | | | |
    | `metafields.product.material:"gid://shopify/Metaobject/43458085"` | | | | | |
    | out\_of\_stock\_somewhere | boolean | Filter by products that are out of | | | |
    | stock in at least one location. | | | - `out_of_stock_somewhere:true` | | |
    | price | bigdecimal | Filter by the product variant [`price`](https://shopify.dev/api/admin-graphql/latest/objects/Productvariant#field-price) | | | |
    | field. | | | - `price:100.57` | | |
    | product\_configuration\_owner | string | Filter by the app | | | |
    | [`id`](https://shopify.dev/api/admin-graphql/latest/objects/App#field-id) | | | | | |
    | field. | | | - `product_configuration_owner:10001` | | |
    | product\_publication\_status | string | Filter by channel approval process | | | |
    | status of the resource on a channel, such as the online store. The value is | | | | | |
    | a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#field-Channel.fields.app) | | | | | |
    | (`Channel.app.id`) and one of the valid values. For simple visibility checks, use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) | | | | | |
    | instead. | - `* {channel_app_id}-approved` - \`\* | | | | |
    | {channel\_app\_id}-rejected`<br/> - `\* {channel\_app\_id}-needs\_action\` - | | | | | |
    | `* {channel_app_id}-awaiting_review` - \`\* | | | | | |
    | {channel\_app\_id}-published`<br/> - `\* {channel\_app\_id}-demoted`<br/> - `\* | | | | | |
    | {channel\_app\_id}-scheduled`<br/> - `\* | | | | | |
    | {channel\_app\_id}-provisionally\_published\` | | - | | | |
    | `product_publication_status:189769876-approved` | | | | | |
    | product\_type | string | Filter by a comma-separated list of \[product | | | |
    | types]\(<https://help.shopify.com/manual/products/details/product-type>). | | | | | |

    * `product_type:snowboard` | | publication\_ids | string | Filter by a comma-separated list of publication IDs that are associated with the product. | | | - `publication_ids:184111530305,184111694145` | | publishable\_status | string | **Deprecated:** This parameter is deprecated as of 2025-12 and will be removed in a future API version. Use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) for visibility checks. Filter by the publishable status of the resource on a channel. The value is a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`) and one of the valid status values. | - `* {channel_app_id}-unset`\
      \- `* {channel_app_id}-pending`\
      \- `* {channel_app_id}-approved`\
      \- `* {channel_app_id}-not_approved` | | - `publishable_status:580111-unset`\
      \- `publishable_status:580111-pending` | | published\_at | time | Filter by the date and time when the product was published to the online store and other sales channels. | | | - `published_at:>2020-10-21T23:39:20Z`\
      \- `published_at:<now`\
      \- `published_at:<=2024` | | published\_status | string | Filter resources by their visibility and publication state on a channel. Online store channel filtering: - `online_store_channel`: Returns all resources in the online store channel, regardless of publication status. - `published`/`visible`: Returns resources that are published to the online store. - `unpublished`: Returns resources that are not published to the online store. Channel-specific filtering using a channel ID, channel handle, [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`), or app handle with suffixes: - `{id_or_handle}-published`: Returns resources published to the specified channel. - `{id_or_handle}-visible`: Same as `{id_or_handle}-published` (kept for backwards compatibility). - `{id_or_handle}-intended`: Returns resources added to the channel but not yet published. - `{id_or_handle}-hidden`: Returns resources not added to the channel or not published. Other: - `unavailable`: Returns resources not published to any channel. | - `online_store_channel`\
      \- `published`\
      \- `visible`
    * `unpublished`\
      \- `* {channel_id_or_handle}-published`\
      \- `* {channel_id_or_handle}-visible`\
      \- `* {channel_id_or_handle}-intended`\
      \- `* {channel_id_or_handle}-hidden`\
      \- `* {channel_app_id_or_handle}-published`\
      \- `* {channel_app_id_or_handle}-visible`\
      \- `* {channel_app_id_or_handle}-intended`\
      \- `* {channel_app_id_or_handle}-hidden`\
      \- `unavailable` | | - `published_status:online_store_channel`\
      \- `published_status:published`\
      \- `published_status:580111-published`
    * `published_status:580111-hidden`\
      \- `published_status:my-channel-handle-published`\
      \- `published_status:unavailable` | | sku | string | Filter by the product variant [`sku`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-sku) field. [Learn more about SKUs](https://help.shopify.com/manual/products/details/sku). | | | - `sku:XYZ-12345` | | status | string | Filter by a comma-separated list of statuses. You can use statuses to manage inventory. Shopify only displays products with an `ACTIVE` status in online stores, sales channels, and apps. | - `active`\
      \- `archived`\
      \- `draft` | `active` | - `status:active,draft` | | tag | string | Filter objects by the `tag` field. | | | - `tag:my_tag` | | tag\_not | string | Filter by objects that don’t have the specified tag. | | | - `tag_not:my_tag` | | title | string | Filter by the product [`title`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-title) field. | | | - `title:The Minimal Snowboard` | | tracks\_inventory | boolean | Filter by products that have [inventory tracking](https://help.shopify.com/manual/products/inventory/getting-started-with-inventory/set-up-inventory-tracking) enabled. | | | - `tracks_inventory:true` | | updated\_at | time | Filter by the date and time when the product was last updated. | | | - `updated_at:>'2020-10-21T23:39:20Z'`\
      \- `updated_at:<now`\
      \- `updated_at:<='2024'` | | variant\_id | id | Filter by the product variant [`id`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-id) field. | | | - `variant_id:45779434701121` | | variant\_title | string | Filter by the product variant [`title`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-title) field. | | | - `variant_title:'Special ski wax'` | | vendor | string | Filter by the origin or source of the product. Learn more about [vendors and managing vendor information](https://help.shopify.com/manual/products/managing-vendor-info). | | | - `vendor:Snowdevil`\
      \- `vendor:Snowdevil OR vendor:Icedevil` | You can apply one or more filters to a query. Learn more about [Shopify API search syntax](https://shopify.dev/api/usage/search-syntax).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  * saved​Search​Id

    [ID](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    The ID of a [saved search](https://shopify.dev/api/admin-graphql/latest/objects/savedsearch#field-id). The search’s query string is used as the query argument.

  * sort​Key

    [Product​Sort​Keys](https://shopify.dev/docs/api/admin-graphql/latest/enums/ProductSortKeys)

    Default:ID

    Sort the underlying list using a key. If your query is slow or returns an error, then [try specifying a sort key that matches the field used in the search](https://shopify.dev/api/usage/pagination-graphql#search-performance-considerations).

  ***

* included​Products​Count

  [Count](https://shopify.dev/docs/api/admin-graphql/latest/objects/Count)

  The count of products included in the publication. Limited to a maximum of 10000 by default.

  * limit

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    Default:10000

    ### Arguments

    The upper bound on count value before returning a result. Use `null` to have no limit.

  * query

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    A filter made up of terms, connectives, modifiers, and comparators.

    | name | type | description | acceptable\_values | default\_value | example\_use |
    | - | - | - | - | - | - |
    | default | string | Filter by a case-insensitive search of multiple fields | | | |
    | in a document. | | | - `query=Bob Norman` - `query=title:green hoodie` | | |
    | barcode | string | Filter by the product variant [`barcode`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-barcode) | | | |
    | field. | | | - `barcode:ABC-abc-1234` | | |
    | bundles | boolean | Filter by a \[product | | | |
    | bundle]\(<https://shopify.dev/docs/apps/build/product-merchandising/bundles>). | | | | | |
    | A product bundle is a set of two or more related products, which are | | | | | |
    | commonly offered at a discount. | | | - `bundles:true` | | |
    | category\_id | string | Filter by the product [category ID](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-category) | | | |
    | (`product.category.id`). A product category is the category of a product | | | | | |
    | from [Shopify's Standard Product Taxonomy](https://shopify.github.io/product-taxonomy/releases/unstable/?categoryId=sg-4-17-2-17). | | | | | |
    | | | - `category_id:sg-4-17-2-17` | | | |
    | collection\_id | id | Filter by the collection [`id`](https://shopify.dev/api/admin-graphql/latest/objects/Collection#field-id) | | | |
    | field. | | | - `collection_id:108179161409` | | |
    | combined\_listing\_role | string | Filter by the role of the product in a [combined listing](https://shopify.dev/apps/build/product-merchandising/combined-listings). | | | |
    | - `parent` - `child` - `no_role` | | - | | | |
    | `combined_listing_role:parent` | | | | | |
    | created\_at | time | Filter by the date and time when the product was | | | |
    | created. | | | - `created_at:>'2020-10-21T23:39:20Z'` - | | |
    | `created_at:<now` - `created_at:<='2024'` | | | | | |
    | delivery\_profile\_id | id | Filter by the delivery profile [`id`](https://shopify.dev/api/admin-graphql/latest/objects/DeliveryProfile#field-id) | | | |
    | field. | | | - `delivery_profile_id:108179161409` | | |
    | error\_feedback | string | Filter by products with publishing errors. | | | |
    | gift\_card | boolean | Filter by the product [`isGiftCard`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-isgiftcard) | | | |
    | field. | | | - `gift_card:true` | | |
    | handle | string | Filter by a comma-separated list of product [handles](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-handle). | | | |
    | | | - `handle:the-minimal-snowboard` | | | |
    | has\_only\_composites | boolean | Filter by products that have only | | | |
    | composite variants. | | | - `has_only_composites:true` | | |
    | has\_only\_default\_variant | boolean | Filter by products that have only a | | | |
    | default variant. A default variant is the only variant if no other variants | | | | | |
    | are specified. | | | - `has_only_default_variant:true` | | |
    | has\_variant\_with\_components | boolean | Filter by products that have | | | |
    | variants with associated components. | | | - | | |
    | `has_variant_with_components:true` | | | | | |
    | id | id | Filter by `id` range. | | | - `id:1234` - `id:>=1234` - `id:<=1234` |
    | inventory\_total | integer | Filter by inventory count. | | | - |
    | `inventory_total:0` - `inventory_total:>150` - | | | | | |
    | `inventory_total:>=200` | | | | | |
    | is\_price\_reduced | boolean | Filter by products that have a reduced price. | | | |
    | For more information, refer to the [`CollectionRule`](https://shopify.dev/api/admin-graphql/latest/objects/CollectionRule) | | | | | |
    | object. | | | - `is_price_reduced:true` | | |
    | metafields.{namespace}.{key} | mixed | Filters resources by metafield | | | |
    | value. Format: `metafields.{namespace}.{key}:{value}`. Learn more about | | | | | |
    | [querying by metafield value](https://shopify.dev/apps/build/custom-data/metafields/query-by-metafield-value). | | | | | |
    | | | - `metafields.custom.on_sale:true` - | | | |
    | `metafields.product.material:"gid://shopify/Metaobject/43458085"` | | | | | |
    | out\_of\_stock\_somewhere | boolean | Filter by products that are out of | | | |
    | stock in at least one location. | | | - `out_of_stock_somewhere:true` | | |
    | price | bigdecimal | Filter by the product variant [`price`](https://shopify.dev/api/admin-graphql/latest/objects/Productvariant#field-price) | | | |
    | field. | | | - `price:100.57` | | |
    | product\_configuration\_owner | string | Filter by the app | | | |
    | [`id`](https://shopify.dev/api/admin-graphql/latest/objects/App#field-id) | | | | | |
    | field. | | | - `product_configuration_owner:10001` | | |
    | product\_publication\_status | string | Filter by channel approval process | | | |
    | status of the resource on a channel, such as the online store. The value is | | | | | |
    | a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#field-Channel.fields.app) | | | | | |
    | (`Channel.app.id`) and one of the valid values. For simple visibility checks, use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) | | | | | |
    | instead. | - `* {channel_app_id}-approved` - \`\* | | | | |
    | {channel\_app\_id}-rejected`<br/> - `\* {channel\_app\_id}-needs\_action\` - | | | | | |
    | `* {channel_app_id}-awaiting_review` - \`\* | | | | | |
    | {channel\_app\_id}-published`<br/> - `\* {channel\_app\_id}-demoted`<br/> - `\* | | | | | |
    | {channel\_app\_id}-scheduled`<br/> - `\* | | | | | |
    | {channel\_app\_id}-provisionally\_published\` | | - | | | |
    | `product_publication_status:189769876-approved` | | | | | |
    | product\_type | string | Filter by a comma-separated list of \[product | | | |
    | types]\(<https://help.shopify.com/manual/products/details/product-type>). | | | | | |

    * `product_type:snowboard` | | publication\_ids | string | Filter by a comma-separated list of publication IDs that are associated with the product. | | | - `publication_ids:184111530305,184111694145` | | publishable\_status | string | **Deprecated:** This parameter is deprecated as of 2025-12 and will be removed in a future API version. Use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) for visibility checks. Filter by the publishable status of the resource on a channel. The value is a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`) and one of the valid status values. | - `* {channel_app_id}-unset`\
      \- `* {channel_app_id}-pending`\
      \- `* {channel_app_id}-approved`\
      \- `* {channel_app_id}-not_approved` | | - `publishable_status:580111-unset`\
      \- `publishable_status:580111-pending` | | published\_at | time | Filter by the date and time when the product was published to the online store and other sales channels. | | | - `published_at:>2020-10-21T23:39:20Z`\
      \- `published_at:<now`\
      \- `published_at:<=2024` | | published\_status | string | Filter resources by their visibility and publication state on a channel. Online store channel filtering: - `online_store_channel`: Returns all resources in the online store channel, regardless of publication status. - `published`/`visible`: Returns resources that are published to the online store. - `unpublished`: Returns resources that are not published to the online store. Channel-specific filtering using a channel ID, channel handle, [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`), or app handle with suffixes: - `{id_or_handle}-published`: Returns resources published to the specified channel. - `{id_or_handle}-visible`: Same as `{id_or_handle}-published` (kept for backwards compatibility). - `{id_or_handle}-intended`: Returns resources added to the channel but not yet published. - `{id_or_handle}-hidden`: Returns resources not added to the channel or not published. Other: - `unavailable`: Returns resources not published to any channel. | - `online_store_channel`\
      \- `published`\
      \- `visible`
    * `unpublished`\
      \- `* {channel_id_or_handle}-published`\
      \- `* {channel_id_or_handle}-visible`\
      \- `* {channel_id_or_handle}-intended`\
      \- `* {channel_id_or_handle}-hidden`\
      \- `* {channel_app_id_or_handle}-published`\
      \- `* {channel_app_id_or_handle}-visible`\
      \- `* {channel_app_id_or_handle}-intended`\
      \- `* {channel_app_id_or_handle}-hidden`\
      \- `unavailable` | | - `published_status:online_store_channel`\
      \- `published_status:published`\
      \- `published_status:580111-published`
    * `published_status:580111-hidden`\
      \- `published_status:my-channel-handle-published`\
      \- `published_status:unavailable` | | sku | string | Filter by the product variant [`sku`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-sku) field. [Learn more about SKUs](https://help.shopify.com/manual/products/details/sku). | | | - `sku:XYZ-12345` | | status | string | Filter by a comma-separated list of statuses. You can use statuses to manage inventory. Shopify only displays products with an `ACTIVE` status in online stores, sales channels, and apps. | - `active`\
      \- `archived`\
      \- `draft` | `active` | - `status:active,draft` | | tag | string | Filter objects by the `tag` field. | | | - `tag:my_tag` | | tag\_not | string | Filter by objects that don’t have the specified tag. | | | - `tag_not:my_tag` | | title | string | Filter by the product [`title`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-title) field. | | | - `title:The Minimal Snowboard` | | tracks\_inventory | boolean | Filter by products that have [inventory tracking](https://help.shopify.com/manual/products/inventory/getting-started-with-inventory/set-up-inventory-tracking) enabled. | | | - `tracks_inventory:true` | | updated\_at | time | Filter by the date and time when the product was last updated. | | | - `updated_at:>'2020-10-21T23:39:20Z'`\
      \- `updated_at:<now`\
      \- `updated_at:<='2024'` | | variant\_id | id | Filter by the product variant [`id`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-id) field. | | | - `variant_id:45779434701121` | | variant\_title | string | Filter by the product variant [`title`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-title) field. | | | - `variant_title:'Special ski wax'` | | vendor | string | Filter by the origin or source of the product. Learn more about [vendors and managing vendor information](https://help.shopify.com/manual/products/managing-vendor-info). | | | - `vendor:Snowdevil`\
      \- `vendor:Snowdevil OR vendor:Icedevil` | You can apply one or more filters to a query. Learn more about [Shopify API search syntax](https://shopify.dev/api/usage/search-syntax).

  * saved​Search​Id

    [ID](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    The ID of an existing saved search. The search’s query string is used as the query argument. Refer to the [`SavedSearch`](https://shopify.dev/api/admin-graphql/latest/objects/savedsearch) object.

  ***

* operation

  [Publication​Operation](https://shopify.dev/docs/api/admin-graphql/latest/unions/PublicationOperation)

  A background operation associated with this publication.

* product​Publications​V3

  [Resource​Publication​Connection!](https://shopify.dev/docs/api/admin-graphql/latest/connections/ResourcePublicationConnection)

  non-null

  The product publications for the list of products published to the publication.

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  ***

* products

  [Product​Connection!](https://shopify.dev/docs/api/admin-graphql/latest/connections/ProductConnection)

  non-null

  The list of products published to the publication.

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * query

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    A filter made up of terms, connectives, modifiers, and comparators.

    | name | type | description | acceptable\_values | default\_value | example\_use |
    | - | - | - | - | - | - |
    | default | string | Filter by a case-insensitive search of multiple fields | | | |
    | in a document. | | | - `query=Bob Norman` - `query=title:green hoodie` | | |
    | barcode | string | Filter by the product variant [`barcode`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-barcode) | | | |
    | field. | | | - `barcode:ABC-abc-1234` | | |
    | bundles | boolean | Filter by a \[product | | | |
    | bundle]\(<https://shopify.dev/docs/apps/build/product-merchandising/bundles>). | | | | | |
    | A product bundle is a set of two or more related products, which are | | | | | |
    | commonly offered at a discount. | | | - `bundles:true` | | |
    | category\_id | string | Filter by the product [category ID](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-category) | | | |
    | (`product.category.id`). A product category is the category of a product | | | | | |
    | from [Shopify's Standard Product Taxonomy](https://shopify.github.io/product-taxonomy/releases/unstable/?categoryId=sg-4-17-2-17). | | | | | |
    | | | - `category_id:sg-4-17-2-17` | | | |
    | collection\_id | id | Filter by the collection [`id`](https://shopify.dev/api/admin-graphql/latest/objects/Collection#field-id) | | | |
    | field. | | | - `collection_id:108179161409` | | |
    | combined\_listing\_role | string | Filter by the role of the product in a [combined listing](https://shopify.dev/apps/build/product-merchandising/combined-listings). | | | |
    | - `parent` - `child` - `no_role` | | - | | | |
    | `combined_listing_role:parent` | | | | | |
    | created\_at | time | Filter by the date and time when the product was | | | |
    | created. | | | - `created_at:>'2020-10-21T23:39:20Z'` - | | |
    | `created_at:<now` - `created_at:<='2024'` | | | | | |
    | delivery\_profile\_id | id | Filter by the delivery profile [`id`](https://shopify.dev/api/admin-graphql/latest/objects/DeliveryProfile#field-id) | | | |
    | field. | | | - `delivery_profile_id:108179161409` | | |
    | error\_feedback | string | Filter by products with publishing errors. | | | |
    | gift\_card | boolean | Filter by the product [`isGiftCard`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-isgiftcard) | | | |
    | field. | | | - `gift_card:true` | | |
    | handle | string | Filter by a comma-separated list of product [handles](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-handle). | | | |
    | | | - `handle:the-minimal-snowboard` | | | |
    | has\_only\_composites | boolean | Filter by products that have only | | | |
    | composite variants. | | | - `has_only_composites:true` | | |
    | has\_only\_default\_variant | boolean | Filter by products that have only a | | | |
    | default variant. A default variant is the only variant if no other variants | | | | | |
    | are specified. | | | - `has_only_default_variant:true` | | |
    | has\_variant\_with\_components | boolean | Filter by products that have | | | |
    | variants with associated components. | | | - | | |
    | `has_variant_with_components:true` | | | | | |
    | id | id | Filter by `id` range. | | | - `id:1234` - `id:>=1234` - `id:<=1234` |
    | inventory\_total | integer | Filter by inventory count. | | | - |
    | `inventory_total:0` - `inventory_total:>150` - | | | | | |
    | `inventory_total:>=200` | | | | | |
    | is\_price\_reduced | boolean | Filter by products that have a reduced price. | | | |
    | For more information, refer to the [`CollectionRule`](https://shopify.dev/api/admin-graphql/latest/objects/CollectionRule) | | | | | |
    | object. | | | - `is_price_reduced:true` | | |
    | metafields.{namespace}.{key} | mixed | Filters resources by metafield | | | |
    | value. Format: `metafields.{namespace}.{key}:{value}`. Learn more about | | | | | |
    | [querying by metafield value](https://shopify.dev/apps/build/custom-data/metafields/query-by-metafield-value). | | | | | |
    | | | - `metafields.custom.on_sale:true` - | | | |
    | `metafields.product.material:"gid://shopify/Metaobject/43458085"` | | | | | |
    | out\_of\_stock\_somewhere | boolean | Filter by products that are out of | | | |
    | stock in at least one location. | | | - `out_of_stock_somewhere:true` | | |
    | price | bigdecimal | Filter by the product variant [`price`](https://shopify.dev/api/admin-graphql/latest/objects/Productvariant#field-price) | | | |
    | field. | | | - `price:100.57` | | |
    | product\_configuration\_owner | string | Filter by the app | | | |
    | [`id`](https://shopify.dev/api/admin-graphql/latest/objects/App#field-id) | | | | | |
    | field. | | | - `product_configuration_owner:10001` | | |
    | product\_publication\_status | string | Filter by channel approval process | | | |
    | status of the resource on a channel, such as the online store. The value is | | | | | |
    | a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#field-Channel.fields.app) | | | | | |
    | (`Channel.app.id`) and one of the valid values. For simple visibility checks, use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) | | | | | |
    | instead. | - `* {channel_app_id}-approved` - \`\* | | | | |
    | {channel\_app\_id}-rejected`<br/> - `\* {channel\_app\_id}-needs\_action\` - | | | | | |
    | `* {channel_app_id}-awaiting_review` - \`\* | | | | | |
    | {channel\_app\_id}-published`<br/> - `\* {channel\_app\_id}-demoted`<br/> - `\* | | | | | |
    | {channel\_app\_id}-scheduled`<br/> - `\* | | | | | |
    | {channel\_app\_id}-provisionally\_published\` | | - | | | |
    | `product_publication_status:189769876-approved` | | | | | |
    | product\_type | string | Filter by a comma-separated list of \[product | | | |
    | types]\(<https://help.shopify.com/manual/products/details/product-type>). | | | | | |

    * `product_type:snowboard` | | publication\_ids | string | Filter by a comma-separated list of publication IDs that are associated with the product. | | | - `publication_ids:184111530305,184111694145` | | publishable\_status | string | **Deprecated:** This parameter is deprecated as of 2025-12 and will be removed in a future API version. Use [published\_status](https://shopify.dev/api/admin-graphql/latest/queries/products#argument-query-filter-publishable_status) for visibility checks. Filter by the publishable status of the resource on a channel. The value is a composite of the [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`) and one of the valid status values. | - `* {channel_app_id}-unset`\
      \- `* {channel_app_id}-pending`\
      \- `* {channel_app_id}-approved`\
      \- `* {channel_app_id}-not_approved` | | - `publishable_status:580111-unset`\
      \- `publishable_status:580111-pending` | | published\_at | time | Filter by the date and time when the product was published to the online store and other sales channels. | | | - `published_at:>2020-10-21T23:39:20Z`\
      \- `published_at:<now`\
      \- `published_at:<=2024` | | published\_status | string | Filter resources by their visibility and publication state on a channel. Online store channel filtering: - `online_store_channel`: Returns all resources in the online store channel, regardless of publication status. - `published`/`visible`: Returns resources that are published to the online store. - `unpublished`: Returns resources that are not published to the online store. Channel-specific filtering using a channel ID, channel handle, [channel `app` ID](https://shopify.dev/api/admin-graphql/latest/objects/Channel#app-price) (`Channel.app.id`), or app handle with suffixes: - `{id_or_handle}-published`: Returns resources published to the specified channel. - `{id_or_handle}-visible`: Same as `{id_or_handle}-published` (kept for backwards compatibility). - `{id_or_handle}-intended`: Returns resources added to the channel but not yet published. - `{id_or_handle}-hidden`: Returns resources not added to the channel or not published. Other: - `unavailable`: Returns resources not published to any channel. | - `online_store_channel`\
      \- `published`\
      \- `visible`
    * `unpublished`\
      \- `* {channel_id_or_handle}-published`\
      \- `* {channel_id_or_handle}-visible`\
      \- `* {channel_id_or_handle}-intended`\
      \- `* {channel_id_or_handle}-hidden`\
      \- `* {channel_app_id_or_handle}-published`\
      \- `* {channel_app_id_or_handle}-visible`\
      \- `* {channel_app_id_or_handle}-intended`\
      \- `* {channel_app_id_or_handle}-hidden`\
      \- `unavailable` | | - `published_status:online_store_channel`\
      \- `published_status:published`\
      \- `published_status:580111-published`
    * `published_status:580111-hidden`\
      \- `published_status:my-channel-handle-published`\
      \- `published_status:unavailable` | | sku | string | Filter by the product variant [`sku`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-sku) field. [Learn more about SKUs](https://help.shopify.com/manual/products/details/sku). | | | - `sku:XYZ-12345` | | status | string | Filter by a comma-separated list of statuses. You can use statuses to manage inventory. Shopify only displays products with an `ACTIVE` status in online stores, sales channels, and apps. | - `active`\
      \- `archived`\
      \- `draft` | `active` | - `status:active,draft` | | tag | string | Filter objects by the `tag` field. | | | - `tag:my_tag` | | tag\_not | string | Filter by objects that don’t have the specified tag. | | | - `tag_not:my_tag` | | title | string | Filter by the product [`title`](https://shopify.dev/api/admin-graphql/latest/objects/Product#field-title) field. | | | - `title:The Minimal Snowboard` | | tracks\_inventory | boolean | Filter by products that have [inventory tracking](https://help.shopify.com/manual/products/inventory/getting-started-with-inventory/set-up-inventory-tracking) enabled. | | | - `tracks_inventory:true` | | updated\_at | time | Filter by the date and time when the product was last updated. | | | - `updated_at:>'2020-10-21T23:39:20Z'`\
      \- `updated_at:<now`\
      \- `updated_at:<='2024'` | | variant\_id | id | Filter by the product variant [`id`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-id) field. | | | - `variant_id:45779434701121` | | variant\_title | string | Filter by the product variant [`title`](https://shopify.dev/api/admin-graphql/latest/objects/ProductVariant#field-title) field. | | | - `variant_title:'Special ski wax'` | | vendor | string | Filter by the origin or source of the product. Learn more about [vendors and managing vendor information](https://help.shopify.com/manual/products/managing-vendor-info). | | | - `vendor:Snowdevil`\
      \- `vendor:Snowdevil OR vendor:Icedevil` | You can apply one or more filters to a query. Learn more about [Shopify API search syntax](https://shopify.dev/api/usage/search-syntax).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  * saved​Search​Id

    [ID](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    The ID of a [saved search](https://shopify.dev/api/admin-graphql/latest/objects/savedsearch#field-id). The search’s query string is used as the query argument.

  * sort​Key

    [Product​Sort​Keys](https://shopify.dev/docs/api/admin-graphql/latest/enums/ProductSortKeys)

    Default:ID

    Sort the underlying list using a key. If your query is slow or returns an error, then [try specifying a sort key that matches the field used in the search](https://shopify.dev/api/usage/pagination-graphql#search-performance-considerations).

  ***

* supports​Future​Publishing

  [Boolean!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

  non-null

  Whether the publication supports future publishing.

### Deprecated fields

* app

  [App!](https://shopify.dev/docs/api/admin-graphql/latest/objects/App)

  non-nullDeprecated

* name

  [String!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

  non-nullDeprecated

***

## Map

### Fields and connections with this object

* [AppCatalog.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/AppCatalog#field-AppCatalog.fields.publication)
* [Catalog.publication](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Catalog#fields-publication)
* [Collection.unpublishedPublications](https://shopify.dev/docs/api/admin-graphql/latest/objects/Collection#field-Collection.fields.unpublishedPublications)
* [CollectionPublication.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/CollectionPublication#field-CollectionPublication.fields.publication)
* [CompanyLocationCatalog.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/CompanyLocationCatalog#field-CompanyLocationCatalog.fields.publication)
* [MarketCatalog.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/MarketCatalog#field-MarketCatalog.fields.publication)
* [Order.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/Order#field-Order.fields.publication)
* [Product.unpublishedPublications](https://shopify.dev/docs/api/admin-graphql/latest/objects/Product#field-Product.fields.unpublishedPublications)
* [PublicationConnection.nodes](https://shopify.dev/docs/api/admin-graphql/latest/connections/PublicationConnection#returns-nodes)
* [PublicationEdge.node](https://shopify.dev/docs/api/admin-graphql/latest/objects/PublicationEdge#field-PublicationEdge.fields.node)
* [Publishable.unpublishedPublications](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Publishable#fields-unpublishedPublications)
* [ResourcePublication.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/ResourcePublication#field-ResourcePublication.fields.publication)
* [ResourcePublicationV2.publication](https://shopify.dev/docs/api/admin-graphql/latest/objects/ResourcePublicationV2#field-ResourcePublicationV2.fields.publication)

***

## Queries

* [publication](https://shopify.dev/docs/api/admin-graphql/latest/queries/publication)

  query

  Retrieves a [`Publication`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication) by [`ID`](https://shopify.dev/docs/api/usage/gids).

  Returns `null` if the publication doesn't exist.

  * id

    [ID!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    required

    ### Arguments

    The ID of the Publication to return.

  ***

* [publications](https://shopify.dev/docs/api/admin-graphql/latest/queries/publications)

  query

  Returns a paginated list of [`Publication`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication).

  Filter publications by [`CatalogType`](https://shopify.dev/docs/api/admin-graphql/latest/enums/CatalogType).

  * after

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    ### Arguments

    The elements that come after the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * before

    [String](https://shopify.dev/docs/api/admin-graphql/latest/scalars/String)

    The elements that come before the specified [cursor](https://shopify.dev/api/usage/pagination-graphql).

  * catalog​Type

    [Catalog​Type](https://shopify.dev/docs/api/admin-graphql/latest/enums/CatalogType)

    Filter publications by catalog type.

  * first

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The first `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * last

    [Int](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Int)

    The last `n` elements from the [paginated list](https://shopify.dev/api/usage/pagination-graphql).

  * reverse

    [Boolean](https://shopify.dev/docs/api/admin-graphql/latest/scalars/Boolean)

    Default:false

    Reverse the order of the underlying list.

  ***

***

## Publication Queries

### Queried by

* [publication](https://shopify.dev/docs/api/admin-graphql/latest/queries/publication)
* [publications](https://shopify.dev/docs/api/admin-graphql/latest/queries/publications)

***

## Mutations

* [publication​Create](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationCreate)

  mutation

  Creates a [`Publication`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication) that controls which [`Product`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Product) and [`Collection`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Collection) customers can access through a [`Catalog`](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Catalog).

  ### When to create a publication

  Publications are **optional** for catalogs. Only create a publication if you need to control which products are visible in a specific catalog context. When a publication isn't associated with a catalog, product availability is determined by the sales channel.

  **Create a publication if you need to:**

  * Restrict product visibility to a subset of your inventory for a specific market or company location
  * Publish different product selections to different contexts

  **Do NOT create a publication if:**

  * You want product availability determined by the sales channel
  * You only need custom pricing (use a price list on the catalog instead)

  ### Configuration options

  You can create an empty publication and add products later, or prepopulate it with all existing products. The [`autoPublish`](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationCreate#arguments-input.fields.autoPublish) field determines whether the publication automatically adds newly created products.

  * input

    [Publication​Create​Input!](https://shopify.dev/docs/api/admin-graphql/latest/input-objects/PublicationCreateInput)

    required

    ### Arguments

    The input fields to use when creating the publication.

  ***

* [publication​Update](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationUpdate)

  mutation

  Updates a [`Publication`](https://shopify.dev/docs/api/admin-graphql/latest/objects/Publication).

  You can add or remove [products](https://shopify.dev/docs/api/admin-graphql/latest/objects/Product) from the publication, with a maximum of 50 items per operation. The [`autoPublish`](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationUpdate#arguments-input.fields.autoPublish) field determines whether new products automatically display in this publication.

  * id

    [ID!](https://shopify.dev/docs/api/admin-graphql/latest/scalars/ID)

    required

    ### Arguments

    The ID of the publication to update.

  * input

    [Publication​Update​Input!](https://shopify.dev/docs/api/admin-graphql/latest/input-objects/PublicationUpdateInput)

    required

    The input fields to use when updating the publication.

  ***

***

## Publication Mutations

### Mutated by

* [publication​Create](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationCreate)
* [publication​Update](https://shopify.dev/docs/api/admin-graphql/latest/mutations/publicationUpdate)

***

## Interfaces

* [Node](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Node)

  interface

***

## Publication Implements

### Implements

* [Node](https://shopify.dev/docs/api/admin-graphql/latest/interfaces/Node)
