Overview of the APIs and related concepts for managing the Product catalog of your Project.
The product catalog is the central location where you can manage all your Product data definitions and sellable items. It acts as the foundation for your retail offerings.
This central repository lets you:
- Support structured data across all Products (Product Types).
- Define navigational pathways (Categories).
- Control Store-specific visibility (Product Selections).
- Manage how Products are shown to Customers on a storefront (Product Projections).
Definitions
Product
100 Product Variants.To support editorial workflows, each Product resource contains the following two representations of its Product data:
- Current: the published version that you need to present to your Customers on the storefront.
- Staged: the draft version to which your content editors can make updates, but it remains invisible to your Customers until explicitly published.
It isn't possible to stage certain Product data that's not intended to be exposed in the storefront, such as Tax Category or Price mode. These are immediately made available in the current representation after making any updates.
The Product lifecycle typically follows these steps:
- Creation: when a Product is created, both the current and staged representations are identical.
- Editing: when a content editor makes changes to the Product, they are applied to only the staged representation. The current representation remains unchanged and is visible to Customers.
- Publishing: when the editor is satisfied with the changes, they can publish the Product. This action copies the staged representation to the current representation and sets the
publishedflag astrue. - Further edits: after publishing, the editor can continue making changes to the staged representation, repeating the cycle.
- Unpublishing: if you don't want the Product to appear in the storefront, you can unpublish it. This action keeps the staged and current representations as they are, but it sets the
publishedflag asfalse. - Deletion: when a Product is no longer needed, you can delete it. This action removes both the current and staged representations from the Project. Only unpublished Products can be deleted.
hasStagedChanges and published fields on a Product Projection to determine whether a Product has unpublished edits or is currently published. This staging and current mechanism also lets you run a preview site and a production storefront from a single Project.Slug
/products/classic-leather-jacket instead of /products/a1b2c3d4.
Slugs must be unique across the Project.Product Variant
- Master Variant: every Product has one Master Variant. The Master Variant always has
idset to1. It ensures that even a simple Product always has at least one variant that can be purchased. It is typically presented as the default on Product detail pages. You can reassign which variant is the Master Variant by using the Change Master Variant update action. - Other variants: an array of additional variants.
- Variant data: contains the following information that changes for every variant:
-
Prices: specific Prices, including tiers, Customer Groups, and Channels.
-
Images: images that are specific to a color and size combination.
-
Attributes: values for Variant Attributes such as
color: Redorsize: L. -
SKU: unique identifier of each variant. The primary role of SKUs is to act as the permanent, machine-readable key for Inventory tracking, ordering, and fulfillment.
We recommend that you don't frequently change any SKU. Doing so can trigger unwanted performance-impacting changes in related resources like Product Selections.
-
SameForAll constraint are editable as Product-level Attributes.
Editing them sets the Attributes on all variants.
When updating product data through the HTTP API, you can use the Set Attribute in All Variants update action.A Product and its variants can have a one-to-one relationship (for unique Products without variations) or a one-to-many relationship (for Products with different sizes, colors, or materials).
Attribute
SameForAll: ensures consistency across all Product Variants, as the value is maintained at the Product level.CombinationUnique: guarantees no two Product Variants share the same combination of specified Attributes. Use this constraint for variant dimensions such as color and size.Unique: ensures Attribute values remain distinct within the same Product.
enum Attribute to differentiate variant types and define optional Attributes specific to each type.Product Projection
The two most important aspects of a Product Projection are as follows:
-
Publishing state: choose between current data and staged data by using the
stagedquery parameter on the Product Projections endpoints. These endpoints request the current projection by default because it's the typical use case for Customer-facing storefronts. -
Contextual data: you can "project" the data to fit a specific context. For example, you can query a Product Projection to show the following contextual data:
- Offered Price for a Product Variant by using the Product price selection process. The Product Projection API filters Prices based on the Store context (currencies, countries, and distribution Channels) to find the best match.
- Localized Attributes (like
nameanddescription) in a specific language, such as German. - Inventory availability for a specific warehouse or sales Channel.
Attribute Group
An Attribute Group lets you group related Attributes for easier data entry and define granular editing permissions. For example, you can bundle color, material, and fit into a Core Specifications group.
meta_title and meta_description into an SEO Metadata group). You can then restrict editing permissions to specific teams (such as the Marketing team).Product Type
Product Types help define the Attributes of a Product. You can define the meta-information associated with an Attribute as part of a Product Type. For example, you can configure whether the Attribute is searchable and define its constraints.
The primary purpose of Product Types is as follows:
-
Define custom Attributes: configure the set of custom fields (Attributes) that a Product or its variants can have.
-
Configure Attribute structure: define where the values of Attribute are stored:
- Variant Attribute: Attributes that vary per SKU (like color or size).
- Product Attribute: Attributes that are identical across all variants (like
brandorwashing_instructions).
-
Control Attribute behavior: specify the constraints and search behavior for each Attribute:
- Constraints: enforce rules such as requiring an Attribute or making its value unique across variants.
- Searchability: specify which Attributes should be searchable, filterable, or used for facets in search queries, which is important for the storefront experience.
When designing Product Types, Products within the same type should share a significant overlap in their Attributes, typically around 80% or above. If Products within the same type don't share many Attributes, many fields remain empty or not applicable. This makes data management more difficult.
Aim to strike a balance between the following approaches:
- Specific Product Types: fewer Attributes, more relevant to each Product. Too many granular Product Types can complicate maintenance and integration.
- Generic Product Types: encompass a wide range of Products with many Attributes, but often result in unused fields for each Product.
The choice between specific and generic Product Types depends on where Product data is managed:
- When managing data in the Merchant Center: use multiple specific Product Types. Using specific Product Types ensures only relevant Attributes are displayed in the Merchant Center.
- When managing data externally: generic Product Types are more efficient to reduce the number of types and Attributes to synchronize.
Product Selection
A Product Selection is a resource that establishes a relationship between a Store and its Products. It determines which Products are available within the scope of a given Store.
You can create a Product Selection, and then assign specific Products to it. Your frontend application makes a Product Projections API call to retrieve the Products that are part of the Product Selection.
You can use a Product Selection in the following key scenarios:
- Assortment control: allow different geographic regions or distinct brands operating within the same commercetools Project to display only their relevant Products.
- Product visibility: temporarily limit or expand the catalog for specific sales Channels without modifying Product content.
Product Tailoring
We recommend that you use localized fields when the content differences among your Stores are related to language translation. And use Product Tailoring when the differences pertain to marketing, legal, or region-specific content.
Deleting a Store permanently removes all associated Product Tailoring data.
You can use Product Tailoring in the following key scenarios:
- Store-specific naming: change the Product name, description, or slug (URL) to use locally appropriate terms.
- Asset customization: override the set of images or Product assets to feature models or settings that are relevant for a specific local market.
In addition to managing resource access, a Store is a tool for tailoring Product information. By combining Stores and Product Tailoring, you can customize Product details such as names, descriptions, slugs, images, and selected Attributes on a per-Store basis. This lets you present targeted and relevant catalog content for different Customer segments, regions, or brands.
Searching for Products by using Store-specific tailored names isn't possible in the Merchant Center. Also, you can't import or export Product Tailoring data from the Merchant Center.
Product Search
current representation of a Product resource, not the staged representation.You can use the Product Search API to implement the following features on your Product listing page:
- Full-text search: let Customers find Products by entering specific search terms.
- Filtering and facets: enable the feature to refine results by using dynamic filters (facets) based on Product Attributes, such as filtering Products by size, color, or brand.
- Sorting: order search results by various criteria such as Price, popularity, or newest arrivals.
Category
Categories have the following key characteristics:
- Hierarchical structure: Categories are designed to form a tree structure. You can have multiple root-level Categories; such Categories don't have a parent Category. And each Category can have zero to several child Categories.
- Product assignment: Products are explicitly linked to one or more Categories. This ensures that a single Product can appear in multiple locations in the storefront navigation simultaneously.
Categories are essential for the following Customer-facing features and content organization:
- Storefront navigation: Categories form the primary menu structure that Customers use to browse Products on your storefront.
- SEO optimization: Categories include fields such as slug (the URL part) and metaDescription that are crucial for search engine optimization (SEO).
When structuring your catalog, start by defining a primary Category tree (typically for navigation), then construct additional Category trees as needed (for example, for promotions).
Review
Reviews have the following key characteristics:
- Customer feedback collection: Reviews store the rating score, text of the Customer's comment, author's details, and metadata such as the date and title of the Review.
- Product enrichment: the Reviews API provides aggregated statistics, such as average rating and total count. These statistics are calculated from all linked reviews and displayed as ratings badges on Product pages.
- Moderation and visibility: Reviews include a State field such as
approved,pending, orrejected. This lets you moderate content before it becomes visible on the storefront. Review States are user-defined and configured in a State machine, letting you control the names and allowed transitions.
Product data management
This section describes how to manage your product data to make them available for purchase.
Evaluate requirements
Before modeling your Product catalog, clarify the necessary commerce integrations and their requirements. Pay close attention to any systems that produce or enrich Product information, as they may impose constraints such as required fields or text-length restrictions.
Evaluate additional requirements that can influence the data model, including search functionality, promotions, and pricing. For example, promotions may require specific Attributes to define Product Discounts accurately.
The system where Product information is maintained has a significant impact on the data model.
- If you manage Products in the Merchant Center, build a model that allows for easy Product edits and supports robust data governance. Set up Attributes as enums or booleans, or group Attributes for intuitive UI navigation.
- If Product details are managed externally (for example, in a PIM system), you can simplify the model and focus on the primary commerce requirements.
As a general guideline, only include data essential for commerce operations, though exceptions exist when additional Product data benefits downstream integrations.
Collect data
Standardize and cleanse the data
Before importing Product data, it's essential that you standardize and cleanse the data to ensure consistency and accuracy across your Product catalog. This process can include the following steps:
- Removing duplicate entries
- Correcting errors
- Supplementing missing information
- Formatting the data into a consistent, standardized structure
Import the data
Several flexible options are available for importing data to suit the following business needs, from manual updates to large-scale automated synchronization:
Merchant Center manual entry
Users can create and edit individual Products and variants directly within the Merchant Center UI. This method is ideal for making small, ad-hoc updates and managing unique Product details one by one.
Merchant Center file upload
For bulk operations, the Merchant Center allows non-technical users to import data by using either CSV or JSON files. This is suitable for initial data migration or periodic mass updates of Products, Prices, and Inventory without needing API development.
Synchronous Products API
Asynchronous Import API
Libraries and CLI tools
Enrich the Product data
Add detailed content to raw Product data, including marketing descriptions, high-quality images, videos, feature highlights, and Customer reviews. SEO optimization improves Product appeal and search visibility.
Categorize and structure your Products
Organize your Products into logical hierarchies, Categories, and taxonomies to facilitate easy navigation and provide an intuitive Customer experience.
Manage Attributes and variants
Define and manage specific Product attributes (size, color, weight, material) and handle Product variations or configurable bundles and kits.
Manage pricing and Inventory
Maintain accurate base pricing, promotional offers, real-time Inventory levels, and availability statuses, often by integrating with ERP or inventory management systems.
Manage workflow and governance
Establish clear workflows, role-based access controls, and approval processes to maintain data quality, track changes, and ensure compliance before information is published.
Implement localization and personalization
Customize Product information, including translations, regional pricing, and specific content, for different markets and Customer segments.
B2B implementations B2B
Performance monitoring and analysis
Track catalog performance metrics, such as data completeness, conversion rates, and return rates, and use Customer feedback and analytics to inform future optimizations.
Storefront consumption
Projection dimensions
Current / staged
current projected representation. Newly created Products only have a staged projected representation. Typically, a storefront application retrieves the Product data by either querying or searching the current Product Projections.Locales
- Locales defined directly with the
localeProjectionquery parameter. - Locales configured in the Store that's specified with the
storeProjectionquery parameter.
If no translation is found on a given field for the specified locales, another locale is used as a fallback. This ensures that required fields can't remain empty in the Product Projection.
Prices
Price projection is a mechanism for filtering Prices that are included in a Product Projection. It ensures that the API response for a Product contains only the Prices relevant to a specific context, such as a particular country, Customer Group, or Channel. This simplifies client-side logic by keeping responses concise.
Projection by Store
storeProjection query parameter.distributionChannels set, then the Product Projection includes only the Prices that meet any one of the following criteria:- The Price has a distribution Channel that's included in the Store's
distributionChannels. - The Price doesn't have an assigned distribution Channel.
countries set, then the projection includes only the Prices that meet any one of the following criteria:- The Price has a country that's included in the Store's
countries. - The Price doesn't have any assigned country.
prices array within the Product Projection.Projection by price selection
priceCurrency, priceCountry, priceCustomerGroup, and priceChannel.When Price selection is applied, the Product Variants that are returned contain the following two fields with Prices:
- The
pricesarray contains Embedded Prices (optionally projected by Store); Standalone Prices are never included. - The optional
pricefield contains the best matching Price based on the provided Price selection parameters. This can be either an Embedded Price or a Standalone Price.
Inventory entries
storeProjection query parameter.supplyChannels set, then only the following Inventory entries are included in the projected Product Variants availability:- Inventory entries with a supply Channel that's included in the Store's
supplyChannels - Inventory entries without a supply Channel
Product Selection assignments
Attributes
filter[attributes] query parameter. It lets you specify which Product Attributes to include or exclude in the response.- Include Attributes: specify the Attribute names to include them in the response.
- Exclude Attributes: add a dash (
-) before the Attribute names to exclude them from the response.
You can include or exclude Product Attributes, Attributes in the Master Variant, and all other variants of the Product.
Here are a few example queries:
curl --get https://api.{region}.commercetools.com/{projectKey}/product-projections/{id}?filter[attributes]=color&filter[attributes]=size -i \
--header "Authorization: Bearer ${BEARER_TOKEN}"
color and size Attributes in the Product Projections response.curl --get https://api.{region}.commercetools.com/{projectKey}/product-projections/{id}?filter[attributes]=-description&filter[attributes]=-specifications -i \
--header "Authorization: Bearer ${BEARER_TOKEN}"
description and specifications in the Product Projections response.Product Projections API vs. Product Search API
Two primary APIs are available for Product discovery and retrieving Product information: the Product Projection API and the Product Search API. Both read-only APIs are optimized for Customer-facing storefront needs, but they serve different use cases and have distinct characteristics.
The following table compares use cases and features of each API, and it provides performance tips for optimal usage:
| Feature | Product Projections API | Product Search API |
|---|---|---|
| Purpose |
|
|
| Use case |
|
|
| Data consistency |
|
|
| Query language |
|
|
| Data returned |
|
|
| Publishing state |
|
|
| Product Selections |
|
|
| Performance tips |
|
|