Products
Products represent the sellable goods in a commerce project.
Products contain ProductVariants, which represent a single sellable product (often an individual SKU). Efficiently mapping your goods to Products and ProductVariants is an important part of working with the API. For more information, see the Product Modeling Module.
Learn more about Products in our self-paced Product data modeling module.
Representations
Product
An abstract sellable good with a set of Attributes defined by a Product Type. Products themselves are not sellable. Instead, they act as a parent structure for Product Variants. Each Product must have at least one Product Variant, which is called the Master Variant. A single Product representation contains the current and the staged representation of its product data.
id String | Unique identifier of the Product. |
version Int | Current version of the Product. |
key String | User-defined unique identifier of the Product. This is different from the |
productType | The Product Type defining the Attributes of the Product. Cannot be changed. |
masterData | Contains the current and the staged representation of the product information. |
taxCategory | The TaxCategory of the Product. |
state | State of the Product. |
reviewRatingStatistics | Review statistics of the Product. |
priceMode | Type of Price to be used when looking up a price for the Product. Default:Embedded |
createdAt | Date and time (UTC) the Product was initially created. |
createdBy BETA | IDs and references that created the Product. |
lastModifiedAt | Date and time (UTC) the Product was last updated. |
lastModifiedBy BETA | IDs and references that last modified the Product. |
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
ProductDraft
key String | User-defined unique identifier for the Product. To update a Product using the Import API, the Product |
productType | The Product Type defining the Attributes for the Product. Cannot be changed later. |
name | Name of the Product. |
slug | User-defined identifier used in a deep-link URL for the Product.
It must be unique across a Project, but a Product can have the same slug in different Locales.
It must match the pattern |
description | Description of the Product. |
categories Array of CategoryResourceIdentifier | Categories assigned to the Product. |
categoryOrderHints | Numerical values to allow ordering of Products within a specified Category. |
metaTitle | Title of the Product displayed in search results. |
metaDescription | Description of the Product displayed in search results. |
metaKeywords | Keywords that give additional information about the Product to search engines. |
masterVariant | The Product Variant to be the Master Variant for the Product. Required if |
variants Array of ProductVariantDraft | The additional Product Variants for the Product. |
taxCategory | The Tax Category to be assigned to the Product. |
searchKeywords | Used by Product Suggestions, but is also considered for a full text search. |
state | State to be assigned to the Product. |
publish Boolean | If false |
priceMode | Specifies the type of prices used when looking up a price for the Product. Default:Embedded |
{"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"categories": [{"typeId": "category","id": "24f510c3-f334-4099-94e2-d6224a8eb919"}],"name": {"en": "Some Product"},"slug": {"en": "product_slug_<random-uuid>"},"masterVariant": {"sku": "SKU-1","prices": [{"value": {"currencyCode": "EUR","centAmount": 4200}}],"images": [{"url": "http://my.custom.cdn.net/master.png","label": "Master Image","dimensions": {"w": 303,"h": 197}}]},"variants": [{"images": [{"url": "http://my.custom.cdn.net/variant.png","label": "Variant Image","dimensions": {"w": 303,"h": 197}}]}]}
ProductPagedQueryResponse
PagedQueryResult with results
containing an array of Product.
limit Int | Number of results requested. |
offset Int | Number of elements skipped. |
count Int | Actual number of results returned. |
total Int | Total number of results matching the query.
This number is an estimation that is not strongly consistent.
This field is returned by default.
For improved performance, calculating this field can be deactivated by using the query parameter |
results Array of Product | Products matching the query. |
ProductReference
ProductResourceIdentifier
ResourceIdentifier to a Product. Either id
or key
is required. If both are set, an InvalidJsonInput error is returned.
ProductCatalogData
Contains the current
and staged
ProductData.
published Boolean |
|
current | Current (published) data of the Product. |
staged | Staged (unpublished) data of the Product. |
hasStagedChanges Boolean |
|
ProductData
Contains all the data of a Product and its Product Variants.
name | Name of the Product. |
categories Array of CategoryReference | Categories assigned to the Product. |
categoryOrderHints | Numerical values to allow ordering of Products within a specified Category. |
description | Description of the Product. |
slug | User-defined identifier used in a deep-link URL for the Product.
Must be unique across a Project, but can be the same for Products in different Locales.
Matches the pattern |
metaTitle | Title of the Product displayed in search results. |
metaDescription | Description of the Product displayed in search results below the meta title. |
metaKeywords | Keywords that give additional information about the Product to search engines. |
masterVariant | The Master Variant of the Product. |
variants Array of ProductVariant | Additional Product Variants. |
searchKeywords | Used by Product Suggestions, but is also considered for a full text search. |
CategoryOrderHints
JSON object where the key is a Category id
and the value is an order hint.
Allows controlling the order of Products and how they appear in Categories. Products with no order hint have an order score below 0
. Order hints are non-unique.
If a subset of Products have the same value for order hint in a specific category, the behavior is undetermined.
/[0-9].[0-9]*[1-9]/ Any string property matching this regular expression | A string representing a number between 0 and 1 that must start with |
{"categoryOrderHints": {"7bcd33e6-c1c7-4b96-8d70-9b9b18b19b70": "0.992"}}
SearchKeywords
Search keywords are primarily used by Product Suggestions, but are also considered for a full-text search. SearchKeywords is a JSON object where the keys are of type Locale and the values are an array of SearchKeyword.
{"en": [{ "text": "Multi tool" },{ "text": "Swiss Army Knife", "suggestTokenizer": { "type": "whitespace" } }],"de": [{"text": "Schweizer Messer","suggestTokenizer": {"type": "custom","inputs": ["schweizer messer", "offiziersmesser", "sackmesser"]}}]}
SearchKeyword
text String | Text to return in the SuggestionResult. |
suggestTokenizer | If no tokenizer is defined, the |
SuggestTokenizer
Defines tokens that are used to match against the suggest query input. Can be differentiated by the type
field.
Whitespace Tokenizer
Creates tokens by splitting the text
field in SearchKeyword by whitespaces.
type String | "whitespace" |
Custom Tokenizer
Define arbitrary tokens that are used to match the input.
type String | "custom" |
inputs Array of String | Contains custom tokens. |
ProductVariant
A concrete sellable good for which inventory can be tracked. Product Variants are generally mapped to specific SKUs.
id Int | A unique, sequential identifier of the Product Variant within the Product. |
key String | User-defined unique identifier of the ProductVariant. This is different from Product |
sku String | User-defined unique SKU of the Product Variant. |
prices Array of Price | The Embedded Prices of the Product Variant.
Cannot contain two Prices of the same Price scope (with same currency, country, Customer Group, Channel, |
attributes Array of Attribute | Attributes of the Product Variant. |
price | Only available when price selection is used. Cannot be used in a Query Predicate. |
images Array of Image | Images of the Product Variant. |
assets Array of Asset | Media assets of the Product Variant. |
availability | Set if the Product Variant is tracked by Inventory. Can be used as an optimization to reduce calls to the Inventory service. May not contain the latest Inventory State (it is eventually consistent). |
isMatchingVariant Boolean |
|
scopedPrice | Only available in response to a Product Projection Search request with Product price selection. Can be used to sort, filter, and facet. |
scopedPriceDiscounted Boolean | Only available in response to a Product Projection Search request with Product price selection. |
ProductVariantDraft
Creates a Product Variant when included in the masterVariant
and variants
fields of the ProductDraft.
key String | User-defined unique identifier for the ProductVariant. |
sku String | User-defined unique SKU of the Product Variant. |
prices Array of PriceDraft | The Embedded Prices for the Product Variant.
Each Price must have its unique Price scope (with same currency, country, Customer Group, Channel, 100 |
attributes Array of Attribute | Attributes according to the respective AttributeDefinition. |
images Array of Image | Images for the Product Variant. |
assets Array of AssetDraft | Media assets for the Product Variant. |
Attribute
When using attributes with GraphQL API mutations, you must escape any strings in the value
field: "value" : "\"A value\""
.
name String | Name of the Attribute. |
value Any | The AttributeType determines the format of the Attribute
|
Image
Product images can be uploaded using the image upload endpoint or the Merchant Center. An image uploaded to commercetools Composable Commerce is stored in a Content Delivery Network and is available in several pre-defined sizes.
If you already have an image stored on an external service, you can save the URL when creating a new Product or adding a ProductVariant, or you can add it later. An image is represented in the following way:
url String | URL of the image in its original size that must be unique within a single ProductVariant. If the Project is hosted in the China (AWS, Ningxia) Region, verify that the URL is not blocked due to firewall restrictions. |
dimensions | Dimensions of the original image. |
label String | Custom label for the image. |
Images in specific sizes are obtained by adding a size suffix before the filename extension:
-thumb
(50x50) - example-small
(150x150) - example-medium
(400x400) - example-large
(700x700) - example-zoom
(1400x1400) - example- the original size of the uploaded image is provided without a suffix - example
Images will never be scaled up. If the original image is tiny, it will keep its original size, even in the "large" and "zoom" sizes.
ProductVariants do not share images. To use the same set of images for multiple ProductVariants, you can implement this in your application by always showing the images of the Master Variant, regardless of the selected ProductVariant.
ImageDimensions
w Int | Width of the image. |
h Int | Height of the image. |
ProductVariantAvailability
The InventoryEntry information of the Product Variant. If there is a supply Channel for the InventoryEntry, then channels
is returned. If not, then isOnStock
, restockableInDays
, and quantityOnStock
are returned.
id String | Unique identifier of the InventoryEntry. |
version Int | Current version of the InventoryEntry. |
channels | For each InventoryEntry with a supply Channel, an entry is added to |
isOnStock Boolean | Indicates whether a Product Variant is in stock. |
restockableInDays Int | Number of days to restock a Product Variant once it is out of stock. |
availableQuantity Int | Number of items of the Product Variant that are in stock. |
ProductVariantChannelAvailabilityMap
A JSON object where the key is a supply Channel id
and the value is the ProductVariantChannelAvailability of the InventoryEntry.
{"cd724bd4-52fa-4d6d-b4b0-bb1560d70475": {"isOnStock": true,"restockableInDays": 10,"availableQuantity": 20,"version": 1,"id": "f64af276-a1ad-4eea-a8bc-89c453742a40"}}
ProductVariantChannelAvailability
id String | Unique identifier of the InventoryEntry. |
version Int | Current version of the InventoryEntry. |
isOnStock Boolean | Indicates whether a Product Variant is in stock in a specified Channel. |
restockableInDays Int | Number of days to restock a Product Variant once it is out of stock in a specified Channel. |
availableQuantity Int | Number of items of this Product Variant that are in stock in a specified Channel. |
ProductPriceMode
This mode determines the type of Prices used for price selection by Line Items and Products. For more information about the difference between the Prices, see Pricing.
Embedded
Composable Commerce uses the Embedded Prices located inside the
prices
field in ProductVariant.Standalone
Composable Commerce uses StandalonePrices, which are associated with the ProductVariant through the
sku
field.
Regardless of the chosen Price mode, ProductVariant prices
contains Embedded Prices only.
ScopedPrice
Scoped Price is contained in a ProductVariant which is returned in response to a Product Projection Search request when Scoped Price Search is used.
id String | Platform-generated unique identifier of the Price. |
value | Original value of the Price. |
currentValue | If available, either the original price |
country | Country code of the geographic location. Pattern:^[A-Z]{2}$ |
customerGroup | Reference to a CustomerGroup. |
channel | Reference to a Channel. |
validFrom | Date and time from which the Price is valid. |
validUntil | Date and time until which the Price is valid. |
discounted | Is set when a matching ProductDiscount exists. If set, the Cart uses the discounted value for the Cart Price calculation. When a relative Product Discount is applied and the fractional part of the discounted Price is 0.5, the discounted Price is rounded half down in favor of the Customer. |
custom | Custom Fields for the Price. |
Get Product
Get Product by ID
If Product price selection query parameters are provided, the selected Prices are added to the response.
view_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
id String |
|
expand | The parameter can be passed multiple times. |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
curl --get https://api.{region}.commercetools.com/{projectKey}/products/{id} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
Get Product by Key
If Product price selection query parameters are provided, the selected Prices are added to the response.
view_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
key String |
|
expand | The parameter can be passed multiple times. |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
curl --get https://api.{region}.commercetools.com/{projectKey}/products/key={key} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
Query Products
Querying Product Attributes should not be used in high-volume use cases as it is an inefficient pattern.
We recommend using the performance-optimized Product Projection Search endpoint, which provides some functionalities that the query API lacks (including sorting by custom Attributes).
If Product price selection query parameters are provided, the selected Prices are added to the response.
view_products:{projectKey} ,
view_published_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
where | |
/^var[.][a-zA-Z0-9]+$/ Any string parameter matching this regular expression | Predicate parameter values. The parameter can be passed multiple times. |
sort | The parameter can be passed multiple times. |
expand | The parameter can be passed multiple times. |
limit Int | Number of results requested. |
offset Int | Number of elements skipped. |
withTotal Boolean | Controls the calculation of the total number of query results. Set to Default: true |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
curl --get https://api.{region}.commercetools.com/{projectKey}/products -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
{"limit": 20,"offset": 0,"count": 1,"total": 1,"results": [{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"version": 2,"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}]}
Query Product Selections for Product
Retrieves Product Selections that contain the given Product.
Query Product Selections for Product by ID
view_product_selections:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
id String |
|
where | The parameter can be passed multiple times. |
/^var[.][a-zA-Z0-9]+$/ Any string parameter matching this regular expression | Predicate parameter values. The parameter can be passed multiple times. |
sort | The parameter can be passed multiple times. |
expand | The parameter can be passed multiple times. |
limit Int | Number of results requested. |
offset Int | Number of elements skipped. |
withTotal Boolean | Controls the calculation of the total number of query results. Set to Default: true |
application/json
curl --get https://api.{region}.commercetools.com/{projectKey}/products/{id}/product-selections -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
{"limit": 20,"offset": 0,"count": 1,"results": [{"productSelection": {"typeId": "product-selection","id": "2e89d89b-bdfb-4339-8e53-7638966a97c2"},"createdAt": "2022-11-21T08:56:22.150Z"}]}
Check if Product exists
Check if Product exists by ID
Checks if a Product exists for a given id
. Returns a 200 OK
status if the Product exists or a 404 Not Found
otherwise.
view_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
id String |
|
curl --head https://api.{region}.commercetools.com/{projectKey}/products/{id} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
Check if Product exists by Key
Checks if a Product exists for a given key
. Returns a 200 OK
status if the Product exists or a 404 Not Found
otherwise.
view_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
key String |
|
curl --head https://api.{region}.commercetools.com/{projectKey}/products/key={key} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
Check if Product exists by Query Predicate
Checks if a Product exists for a given Query Predicate. Returns a 200 OK
status if any Products match the Query Predicate or a 404 Not Found
otherwise.
view_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
where |
curl --head https://api.{region}.commercetools.com/{projectKey}/products -i \--header 'Authorization: Bearer ${BEARER_TOKEN}'
Create Product
To create a new Product, send a representation that is going to become the initial staged and current representation of the new Product in the catalog. If Product price selection query parameters are provided, selected Prices will be added to the response. Produces the ProductCreated Message.
manage_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
expand | The parameter can be passed multiple times. |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
application/json
curl https://api.{region}.commercetools.com/{projectKey}/products -i \--header 'Authorization: Bearer ${BEARER_TOKEN}' \--header 'Content-Type: application/json' \--data-binary @- << DATA{"productType" : {"id" : "24f510c3-f334-4099-94e2-d6224a8eb919","typeId" : "product-type"},"categories" : [ {"typeId" : "category","id" : "24f510c3-f334-4099-94e2-d6224a8eb919"} ],"name" : {"en" : "Some Product"},"slug" : {"en" : "product_slug_<random-uuid>"},"masterVariant" : {"sku" : "SKU-1","prices" : [ {"value" : {"currencyCode" : "EUR","centAmount" : 4200}} ],"images" : [ {"url" : "http://my.custom.cdn.net/master.png","label" : "Master Image","dimensions" : {"w" : 303,"h" : 197}} ]},"variants" : [ {"images" : [ {"url" : "http://my.custom.cdn.net/variant.png","label" : "Variant Image","dimensions" : {"w" : 303,"h" : 197}} ]} ]}DATA
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
Update Product
Update Product by ID
If Product price selection query parameters are provided, the selected Prices are added to the response.
A failed response can return a DuplicatePriceScope, DuplicateVariantValues, DuplicateAttributeValue, or DuplicateAttributeValues error.
manage_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
id String |
|
expand | The parameter can be passed multiple times. |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
version Int | Expected version of the Product on which the changes should be applied. If the expected version does not match the actual version, a ConcurrentModification error will be returned. |
actions Array of ProductUpdateAction | Update actions to be performed on the Product. |
application/json
curl https://api.{region}.commercetools.com/{projectKey}/products/{id} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}' \--header 'Content-Type: application/json' \--data-binary @- << DATA{"version" : 2,"actions" : [ {"action" : "setDescription","description" : {"en" : "The best product ever!"}} ]}DATA
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
Update Product by Key
A failed response can return a DuplicatePriceScope, DuplicateVariantValues, DuplicateAttributeValue, or DuplicateAttributeValues error.
manage_products:{projectKey}
region String | Region in which the Project is hosted. |
projectKey String |
|
key String |
|
expand | The parameter can be passed multiple times. |
priceCurrency | The currency used for Product price selection. |
priceCountry | The country used for Product price selection. Can only be used in conjunction with the |
priceCustomerGroup String |
|
priceChannel String |
|
application/json
version Int | Expected version of the Product on which the changes should be applied. If the expected version does not match the actual version, a ConcurrentModification error will be returned. |
actions Array of ProductUpdateAction | Update actions to be performed on the Product. |
application/json
curl https://api.{region}.commercetools.com/{projectKey}/products/key={key} -i \--header 'Authorization: Bearer ${BEARER_TOKEN}' \--header 'Content-Type: application/json' \--data-binary @- << DATA{"version" : 2,"actions" : [ {"action" : "setDescription","description" : {"en" : "The best product ever!"}} ]}DATA
{"id": "e7ba4c75-b1bb-483d-94d8-2c4a10f78472","version": 2,"masterData": {"current": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}},"hasStagedChanges": false,"published": true,"staged": {"categories": [{"id": "cf6d790a-f027-4f46-9a2b-4bc9a31066fb","typeId": "category"}],"description": {"en": "Sample description"},"masterVariant": {"attributes": [],"id": 1,"images": [{"dimensions": {"h": 1400,"w": 1400},"url": "https://commercetools.com/cli/data/253245821_1.jpg"}],"prices": [{"value": {"type": "centPrecision","fractionDigits": 2,"centAmount": 10000,"currencyCode": "EUR"},"id": "753472a3-ddff-4e0f-a93b-2eb29c90ba54"}],"sku": "sku_MB_PREMIUM_TECH_T_variant1_1369226795424"},"name": {"en": "MB PREMIUM TECH T"},"slug": {"en": "mb-premium-tech-t1369226795424"},"variants": [],"searchKeywords": {}}},"productType": {"id": "24f510c3-f334-4099-94e2-d6224a8eb919","typeId": "product-type"},"taxCategory": {"id": "f1e10e3a-45eb-49d8-ad0b-fdf984202f59","typeId": "tax-category"},"createdAt": "1970-01-01T00:00:00.001Z","lastModifiedAt": "1970-01-01T00:00:00.001Z"}
Update actions
Set Product Key
action String | "setKey" |
key String | Value to set. If empty, any existing value will be removed. To update a Product using the Import API, the Product |
{"action": "setKey","key": "DefaultKey"}
Change Product Name
action String | "changeName" |
name | Value to set. Must not be empty. |
staged Boolean | If true |
{"action": "changeName","name": {"de": "Mein neuer Produkt Name","en": "My new product name"}}
Set Product Description
action String | "setDescription" |
description | Value to set. If empty, any existing value will be removed. |
staged Boolean | If true |
{"action": "setDescription","description": {"de": "Dies ist eine neue Produktbeschreibung","en": "This is a new product description"}}
Change Slug
Produces the ProductSlugChanged Message.
action String | "changeSlug" |
slug | |
staged Boolean | If true |
{"action": "changeSlug","slug": {"de": "mein-neuer-produkt-slug","en": "my-new-product-slug"}}
Add ProductVariant
action String | "addVariant" |
key String | Value to set. Must be unique. |
sku String | Value to set. Must be unique. |
prices Array of PriceDraft | Embedded Prices for the Product Variant. MaxItems:100 |
images Array of Image | Images for the Product Variant. |
attributes Array of Attribute | Attributes for the Product Variant. |
staged Boolean | If true |
assets Array of AssetDraft | Media assets for the Product Variant. |
{"action": "addVariant","key": "VariantKey","sku": "VariantSKU"}
Remove ProductVariant
Either id
or sku
is required.
Produces the ProductVariantDeleted Message.
If the Product Variant to remove is part of a ProductSelectionAssignment
its SKU will be automatically removed from the respective ProductVariantSelection.
id Int | The |
action String | "removeVariant" |
sku String | The |
staged Boolean | If true |
{"action": "removeVariant","id": 2}
Change Master Variant
Assigns the specified Product Variant to the masterVariant
and removes the same from variants
at the same time. The current Master Variant becomes part of the variants
array.
Either variantId
or sku
is required.
action String | "changeMasterVariant" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
{"action": "changeMasterVariant","variantId": 1}
Set PriceMode
This action does not affect the behavior of the Add Price, Set Prices, Change Price, and Remove Price update actions as they are only meant for managing Embedded Prices.
When changing the Price mode, no migration of Prices takes place between Embedded Prices and StandalonePrices.
Controls whether the Prices of a Product Variant are embedded into the Product or standalone.
action String | "setPriceMode" |
priceMode | Specifies which type of Prices should be used when looking up a price for the Product. Default:Embedded |
{"action": "setPriceMode","priceMode": "Standalone"}
Add Price
Adds the given Price to the prices
array of the ProductVariant.
Either variantId
or sku
is required.
action String | "addPrice" |
variantId Int | The |
sku String | The |
price | Embedded Price to add to the Product Variant. |
staged Boolean | If true |
{"action": "addPrice","variantId": 1,"price": {"value": {"currencyCode": "EUR","centAmount": 4000}}}
Prices are defined with a scope (currency and optionally country, CustomerGroup, and Channel and/or a validity period (validFrom
and/or validTo
). For more information see price selection.
Adding an Embedded Price is rejected:
- if the product already contains an Embedded Price with the same price scope (same currency, country, customer group, channel, valid from and valid until).
- if two Embedded Prices have validity periods that overlap within the same price scope. A price without validity period does not conflict with a price defined for a time period.
A maximum number of 100
prices can be specified on a ProductVariant. If your business case requires going beyond this limit, use StandalonePrices instead.
Nonetheless, to keep the number of Embedded Prices per Product Variant low, make use of the price selection fallback logic. For example, you can define a single price for all countries using the EUR
currency instead of defining prices for the individual country
attributes. Similarly, you can define a price without a channel
attribute to use as a base price across channels, and create additional prices with a channel
attribute for specific channels that differ from the base price.
Set Prices
Either variantId
or sku
is required.
action String | "setPrices" |
variantId Int | The |
sku String | The |
prices Array of PriceDraft | The Embedded Prices to set.
Each Price must have its unique Price scope (with same currency, country, Customer Group, Channel, |
staged Boolean | If true |
{"action": "setPrices","variantId": 1,"prices": [{"value": {"currencyCode": "USD","centAmount": 3100}},{"value": {"currencyCode": "EUR","centAmount": 4000}}]}
Change Price
action String | "changePrice" |
priceId String | The |
price | Value to set. |
staged Boolean | If true |
{"action": "changePrice","priceId": "{{priceId}}","price": {"value": {"currencyCode": "EUR","centAmount": 4000}},"staged": true}
Remove Price
action String | "removePrice" |
priceId String | The |
staged Boolean | If true |
{"action": "removePrice","priceId": "{{priceId}}"}
Set Price Custom Type
action String | "setProductPriceCustomType" |
priceId String | The |
staged Boolean | If true |
type | Defines the Type that extends the Price with Custom Fields. If absent, any existing Type and Custom Fields are removed from the Embedded Price. |
fields | Sets the Custom Fields fields for the Embedded Price. |
{"action": "setProductPriceCustomType","priceId": "{{priceId}}","type": {"id": "{{type-id}}","typeId": "type"},"fields": {"exampleStringTypeField": "TextString"}}
Set Price CustomField
action String | "setProductPriceCustomField" |
priceId String | The |
staged Boolean | If true |
name String | Name of the Custom Field. |
value | If |
{"action": "setProductPriceCustomField","priceId": "{{priceId}}","name": "ExampleStringTypeField","value": "TextString"}
Set Discounted Price
Produces the ProductPriceExternalDiscountSet Message.
action String | "setDiscountedPrice" |
priceId String | The |
staged Boolean | If true |
discounted | Value to set. If empty, any existing value will be removed.
The referenced ProductDiscount must have the Type |
{"action": "setDiscountedPrice","priceId": "{{priceId}}","staged": true,"discounted": {"value": {"currencyCode": "EUR","centAmount": 4000},"discount": {"typeId": "product-discount","id": "{{product-discount-id}}"}}}
Set Price Key
Sets the key of an Embedded Price. Produces the ProductPriceKeySet Message.
action String | "setPriceKey" |
key String | Value to set. If empty, any existing value will be removed. MinLength:2 MaxLength: 256 Pattern: ^[A-Za-z0-9_-]+$ |
priceId String | The |
staged Boolean | If true |
{"action": "setPriceKey","priceId": "{{priceId}}","key": "a-new-embedded-price-key","staged": true}
Set Attribute
Either variantId
or sku
is required.
action String | "setAttribute" |
variantId Int | The |
sku String | The |
name String | The name of the Attribute to set. |
value Any | Value to set for the Attribute. If empty, any existing value will be removed. The AttributeType determines the format of the Attribute
|
staged Boolean | If true |
{"action": "setAttribute","variantId": 1,"name": "ExampleStringTypeAttribute","value": "TextString"}
Set Attribute In All Variants
Adds, removes, or changes a Product Attribute in all Product Variants at the same time.
This action is useful for setting values for Attributes with the Constraint SameForAll
.
action String | "setAttributeInAllVariants" |
name String | The name of the Attribute to set. |
value Any | Value to set for the Attributes. If empty, any existing value will be removed. The AttributeType determines the format of the Attribute
|
staged Boolean | If true |
{"action": "setAttributeInAllVariants","name": "ExampleStringTypeAttribute","value": "TextString"}
Add to Category
Produces the ProductAddedToCategory Message.
action String | "addToCategory" |
category | The Category to add. |
orderHint String | A string representing a number between 0 and 1. Must start with ^0.[0-9]*[1-9]$ |
staged Boolean | If true |
{"action": "addToCategory","category": {"typeId": "category","id": "{{category-id}}"}}
Set Category Order Hint
action String | "setCategoryOrderHint" |
categoryId String | The |
orderHint String | A string representing a number between 0 and 1. Must start with ^0.[0-9]*[1-9]$ |
staged Boolean | If true |
{"action": "setCategoryOrderHint","categoryId": "{{category-id}}","orderHint": "0.1"}
Remove from Category
Produces the ProductRemovedFromCategory Message.
action String | "removeFromCategory" |
category | The Category to remove. |
staged Boolean | If true |
{"action": "removeFromCategory","category": {"typeId": "category","id": "{{category-id}}"}}
Set TaxCategory
Cannot be staged. Published Products are immediately updated.
action String | "setTaxCategory" |
taxCategory | The Tax Category to set. If empty, any existing value will be removed. |
{"action": "setTaxCategory","taxCategory": {"typeId": "tax-category","id": "{{tax-category-id}}"}}
Set SKU
SKU cannot be changed or removed if it is associated with an InventoryEntry. If the SKU to set or unset is part of a ProductSelectionAssignment it will be automatically added or removed from the respective ProductVariantSelection.
action String | "setSku" |
variantId Int | The |
sku String | Value to set. Must be unique. If empty, any existing value will be removed. |
staged Boolean | If true |
{"action": "setSku","variantId": 1,"sku": "SKU"}
Set ProductVariant Key
Either variantId
or sku
is required.
action String | "setProductVariantKey" |
key String | Value to set. Must be unique. If empty, any existing value will be removed. |
variantId Int | The |
sku String | The |
staged Boolean | If true |
{"action": "setProductVariantKey","variantId": 1,"key": "keyString"}
Add External Image
Either variantId
or sku
is required. Produces the ProductImageAdded Message.
action String | "addExternalImage" |
variantId Int | The |
sku String | The |
image | Value to add to |
staged Boolean | If true |
{"action": "addExternalImage","variantId": 1,"image": {"url": "//myimage.jpg","dimensions": {"w": 1400,"h": 1400},"label": "myImage"}}
Move Image To Position
Either variantId
or sku
is required.
action String | "moveImageToPosition" |
variantId Int | The |
sku String | The |
imageUrl String | The URL of the image to update. |
position Int | Position in |
staged Boolean | If true |
{"action": "moveImageToPosition","variantId": 1,"imageUrl": "//myimage2.jpg","position": 1}
Remove Image
Removes a Product image and deletes it from the Content Delivery Network (external images are not deleted). Deletion from the CDN is not instant, which means the image file itself will stay available for some time after the deletion. Either variantId
or sku
is required.
action String | "removeImage" |
variantId Int | The |
sku String | The |
imageUrl String | The URL of the image to remove. |
staged Boolean | If true |
{"action": "removeImage","variantId": 1,"imageUrl": "//myimage2.jpg"}
Set Image Label
Either variantId
or sku
is required.
action String | "setImageLabel" |
sku String | The |
variantId Int | The |
imageUrl String | The URL of the image to set the label. |
label String | Value to set. If empty, any existing value will be removed. |
staged Boolean | If true |
{"action": "setImageLabel","variantId": 2,"imageUrl": "//image.png","label": "labelString","staged": true}
Add Asset
Either variantId
or sku
is required.
action String | "addAsset" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
asset | Value to append. |
position Int | Position in |
{"action": "addAsset","variantId": 1,"asset": {"sources": [{"uri": "//asset.mp4"}],"name": {"de": "FirstAssetDE","en": "FirstassetEN"}}}
Remove Asset
Either variantId
or sku
is required. The Asset to remove must be specified using either assetId
or assetKey
.
action String | "removeAsset" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
assetId String | The |
assetKey String | The |
{"action": "removeAsset","variantId": 1,"assetId": "{{assetId}}"}
Set Asset Key
Either variantId
or sku
is required.
action String | "setAssetKey" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
assetId String | The |
assetKey String | Value to set. If empty, any existing value will be removed. MinLength:2 MaxLength: 256 Pattern: ^[A-Za-z0-9_-]+$ |
{"action": "setAssetKey","variantId": 1,"assetId": "{{assetId}}","assetKey": "assetKeyString"}
Change Asset Order
Either variantId
or sku
is required.
action String | "changeAssetOrder" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
assetOrder Array of String | All existing Asset |
{"action": "changeAssetOrder","variantId": 1,"assetOrder": ["{{assetId1}}", "{{assetId2}}"]}
Change Asset Name
Either variantId
or sku
is required. The Asset to update must be specified using either assetId
or assetKey
.
action String | "changeAssetName" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
assetId String | The |
assetKey String | The |
name | New value to set. Must not be empty. |
{"action": "changeAssetName","variantId": 1,"assetId": "{{assetId}}","name": {"de": "Mein Asset","en": "My asset"}}
Set Asset Description
Either variantId
or sku
is required. The Asset to update must be specified using either assetId
or assetKey
.
action String | "setAssetDescription" |
variantId Int | The |
sku String | The |
staged Boolean | If true |
assetId String | The |
assetKey String | The |
description | Value to set. If empty, any existing value will be removed. |