# ProductInput - admin-graphql - INPUT_OBJECT Version: 2025-01 ## Description The input fields for creating or updating a product. ### Access Scopes ## Fields * [category](/docs/api/admin-graphql/2025-01/scalars/ID): ID - The ID of the [category](https://shopify.github.io/product-taxonomy/releases/unstable/?categoryId=sg-4-17-2-17) that's associated with the product. * [claimOwnership](/docs/api/admin-graphql/2025-01/input-objects/ProductClaimOwnershipInput): ProductClaimOwnershipInput - The input field to enable an app to provide additional product features. For example, you can specify [`bundles: true`](https://shopify.dev/docs/api/admin-graphql/latest/input-objects/ProductClaimOwnershipInput#field-bundles) in the `claimOwnership` field to let an app add a [product configuration extension](https://shopify.dev/docs/apps/build/product-merchandising/bundles/add-merchant-config-ui). * [collectionsToJoin](/docs/api/admin-graphql/2025-01/scalars/ID): ID - A list of collection IDs to associate with the product. * [collectionsToLeave](/docs/api/admin-graphql/2025-01/scalars/ID): ID - The collection IDs to disassociate from the product. * [combinedListingRole](/docs/api/admin-graphql/2025-01/enums/CombinedListingsRole): CombinedListingsRole - The role of the product in a [combined listing](https://shopify.dev/apps/build/product-merchandising/combined-listings). You can specify this field only when you create a product. * [descriptionHtml](/docs/api/admin-graphql/2025-01/scalars/String): String - The description of the product, with HTML tags. For example, the description might include bold `<strong></strong>` and italic `<i></i>` text. * [giftCard](/docs/api/admin-graphql/2025-01/scalars/Boolean): Boolean - Whether the product is a gift card. * [giftCardTemplateSuffix](/docs/api/admin-graphql/2025-01/scalars/String): String - The [theme template](https://shopify.dev/docs/storefronts/themes/architecture/templates) that's used when customers view a gift card in a store. * [handle](/docs/api/admin-graphql/2025-01/scalars/String): String - A unique, human-readable string of the product's title. A handle can contain letters, hyphens (`-`), and numbers, but no spaces. The handle is used in the online store URL for the product. For example, if a product is titled "Black Sunglasses", then the handle is `black-sunglasses`. * [id](/docs/api/admin-graphql/2025-01/scalars/ID): ID - The product's ID. If you're creating a product, then you don't need to pass the `id` as input to the [`productCreate`](https://shopify.dev/docs/api/admin-graphql/latest/mutations/productCreate) mutation. If you're updating a product, then you do need to pass the `id` as input to the [`productUpdate`](https://shopify.dev/docs/api/admin-graphql/latest/mutations/productUpdate) mutation to identify which product you want to update. * [metafields](/docs/api/admin-graphql/2025-01/input-objects/MetafieldInput): MetafieldInput - The [custom fields](https://shopify.dev/docs/apps/build/custom-data) to associate with the product for the purposes of adding and storing additional information. * [productOptions](/docs/api/admin-graphql/2025-01/input-objects/OptionCreateInput): OptionCreateInput - A list of product options and option values. Maximum product options: three. There's no limit on the number of option values. This input is supported only with the [`productCreate`](https://shopify.dev/docs/api/admin-graphql/latest/mutations/productCreate) mutation. * [productPublications](/docs/api/admin-graphql/2025-01/input-objects/ProductPublicationInput): ProductPublicationInput - A list of the channels where the product is published. * [productType](/docs/api/admin-graphql/2025-01/scalars/String): String - The [product type](https://help.shopify.com/manual/products/details/product-type) that merchants define. * [publications](/docs/api/admin-graphql/2025-01/input-objects/ProductPublicationInput): ProductPublicationInput - A list of the channels where the product is published. * [publishDate](/docs/api/admin-graphql/2025-01/scalars/DateTime): DateTime - Only products with an active status can be published. * [publishOn](/docs/api/admin-graphql/2025-01/scalars/DateTime): DateTime - Only products with an active status can be published. * [published](/docs/api/admin-graphql/2025-01/scalars/Boolean): Boolean - Only products with an active status can be published. * [publishedAt](/docs/api/admin-graphql/2025-01/scalars/DateTime): DateTime - Only products with an active status can be published. * [redirectNewHandle](/docs/api/admin-graphql/2025-01/scalars/Boolean): Boolean - Whether a redirect is required after a new handle has been provided. If `true`, then the old handle is redirected to the new one automatically. * [requiresSellingPlan](/docs/api/admin-graphql/2025-01/scalars/Boolean): Boolean - Whether the product can only be purchased with a [selling plan](https://shopify.dev/docs/apps/build/purchase-options/subscriptions/selling-plans). Products that are sold on subscription (`requiresSellingPlan: true`) can be updated only for online stores. If you update a product to be subscription-only (`requiresSellingPlan:false`), then the product is unpublished from all channels except the online store. * [seo](/docs/api/admin-graphql/2025-01/input-objects/SEOInput): SEOInput - The [SEO title and description](https://help.shopify.com/manual/promoting-marketing/seo/adding-keywords) that are associated with a product. * [status](/docs/api/admin-graphql/2025-01/enums/ProductStatus): ProductStatus - The [product status](https://help.shopify.com/manual/products/details/product-details-page#product-status), which controls visibility across all sales channels. * [tags](/docs/api/admin-graphql/2025-01/scalars/String): String - A comma-separated list of searchable keywords that are associated with the product. For example, a merchant might apply the `sports` and `summer` tags to products that are associated with sportwear for summer. Updating `tags` overwrites any existing tags that were previously added to the product. To add new tags without overwriting existing tags, use the [`tagsAdd`](https://shopify.dev/api/admin-graphql/latest/mutations/tagsadd) mutation. * [templateSuffix](/docs/api/admin-graphql/2025-01/scalars/String): String - The [theme template](https://shopify.dev/docs/storefronts/themes/architecture/templates) that's used when customers view a product in a store. * [title](/docs/api/admin-graphql/2025-01/scalars/String): String - The name for the product that displays to customers. The title is used to construct the product's handle. For example, if a product is titled "Black Sunglasses", then the handle is `black-sunglasses`. * [vendor](/docs/api/admin-graphql/2025-01/scalars/String): String - The name of the product's vendor. ## Input objects with this input object * [productCreate](/docs/api/admin-graphql/2025-01/mutations/productCreate) * [productUpdate](/docs/api/admin-graphql/2025-01/mutations/productUpdate) ## Examples