Build child products
POST/pcm/products/:productID/build
With product variations in Product Experience Manager, you can create product variations and different options for each variation and use both to create child products for a product. Each child product is a unique combination of options associated with the product.
Child products inherit attributes from their parent products. When you make changes to the attributes of the parent products, you can rebuild your child products, ensuring that changes to the parent products are propagated to the child products.
Alternatively, you can modify a child product independently, without impacting its parent product. For example, you may prefer the status of your child product to be live
, while keeping the parent product's status as draft
. When you directly update a child product, it becomes independent of its parent product. In other words, any subsequent changes made to the parent product are not automatically reflected in the child product when you rebuild the parent product and its child products. Once a child product is independent of its parent, you cannot recreate the association between the child product and its parent. You must delete the child product and rebuild the parent to recreate the child product.
Following on from that, if you add the same flow to both a parent and child product, the child flow values are not affected by changes to the parent flow values in a rebuild.
Using Build Rules
When building your child products, you can build all products related to a product.
Alternatively, you can build a combination of child products associated with a product, based on build rules that you specify. This is useful, for example, if you have a variation option that you do not sell. This makes managing and building your child products quick and easy. You can do this using build_rules
. build_rules
are combinations of variation option IDs that you wish to include or exclude when building your child products.
You do not need to configure any build_rules
in the following scenarios:
- Child products must be built with all variation options. Simply, use the
Create a product
orUpdate a product
endpoints with nobuild_rules
specified. - Child products must be built apart from all options for a specific variation. In this case, you must remove the variation and use the
Create a product
orUpdate a product
endpoints with nobuild_rules
specified. In other words, using our example, if none of thesize
options should be included, then remove thesize
variation.
The build_rules
contain:
- (Required)
default
: specifies the default behavior. - (Optional)
include
: specifies the option IDs to include when the child products are built. Each combination consists of a nested array of option IDs from one or more variations. Combinations of option IDs in the nested arrays must come from different variations. See Invalid Build Rules. - (Optional)
exclude
: specifies the option IDs to exclude when the child products are built. Each combination consists of a nested array of option IDs from one or more variations. Combinations of option IDs in the nested arrays must come from different variations. See Invalid build rules.
When building child products, Commerce compares each combination of option IDs to these rules to determine how your child products should be built, depending on how you have configured the build_rules
. It depends on your requirements how you configure your build_rules
.
Invalid Build Rules
The build_rules
are invalid if both the option IDs come from the same variation. Combinations of option IDs in the nested arrays must come from different variations.
If Commerce cannot resolve the build_rules
a could not determine whether to include or exclude a child product due to ambiguous rules
error is returned. This error can occur, for example, if you have the same number of variation option IDs in both the include
and exclude
arrays and the variation option IDs match.
Building Child Products
Building child products is an asynchronous operation. When you build child products, a job is created. The jobId of the job is displayed in the response. When the job is complete, the build child products operation is also complete. You can use the jobId to see the status of your job using the Get a Job
endpoint.
Jobs are processed one at a time. You can continue to send build child product requests, but those jobs are queued. In other words, Commerce looks for any jobs that have a status of PENDING and starts the job with the earliest created date. This process is repeated until all jobs are processed. See Jobs.
Re-building child products after adding or removing a new variation changes the total number of child products that you can generate from a parent product. When you rebuild the child products after updating variations associated with the parent product, all existing child products that belong to a parent product are deleted. New child products are created with new product IDs.
If you have any bundles that reference child products directly, then you must update the bundles with the new child product IDs.
However, re-building child products after adding or removing an option does not change the existing product IDs.
Request
Path Parameters
A unique identifier for the product.
- application/json
Body
object
Responses
- 201
- 403
- 404
- 422
- 500
Successfully started building child products
- application/json
- Schema
- Example (from schema)
- build-child-products
Schema
pending
- Commerce has received the request but is currently busy processing other requests.started
- Commerce has started processing the job.success
- The job has successfully completed.failed
- The job has failed.
data objectrequired
A unique identifier generated when a job is created.
Possible values: [pim-job
]
This represents the type of resource object being returned. Always pim-job
.
attributes objectrequired
The date and time a job is started.
The date and time a job is completed.
The date and time a job is created.
The date and time a job is updated.
Possible values: [child-products
, product-import
, product-export
, hierarchy-duplicate
, price-import
]
The status of a job.
Possible values: [pending
, cancelled
, started
, success
, failed
]
meta objectrequired
Applies to all job types. A unique request ID is generated when a job is created.
Applies to hierarchy-duplicate
job types. The ID of the original hierarchy that you duplicated.
Applies to hierarchy-duplicate
job types. The duplicated hierarchy ID.
If the job type is product_export
, a link to the file is created when running a job.
The entities included in the job. For example, if the job type is product-export
, the PXM products included in the export.
{
"data": {
"id": "string",
"type": "pim-job",
"attributes": {
"started_at": "2020-09-22T09:00:00",
"completed_at": "2020-09-22T09:00:00",
"created_at": "2020-09-22T09:00:00",
"updated_at": "2020-09-22T09:00:00",
"type": "child-products",
"status": "pending"
},
"meta": {
"x_request_id": "string",
"copied_from": "string",
"hierarchy_id": "string",
"file_locations": [
"string"
],
"filter": "string"
}
}
}
{
"data": {
"type": "pim-job",
"id": "dcc9e0bb-526b-4207-9e52-081589cdb50e",
"attributes": {
"completed_at": null,
"created_at": "2024-11-01T14:11:00.917Z",
"started_at": null,
"status": "pending",
"type": "child-products",
"updated_at": "2024-11-01T14:11:00.917Z"
},
"meta": {
"x_request_id": "85609bc9-6f19-4831-919a-a5b43e662061"
}
}
}
Forbidden
- application/json
- Schema
- Example (from schema)
- internal-server-error
Schema
- Array [
- ]
errors undefined[]required
The HTTP response code of the error.
A brief summary of the error.
Optional additional detail about the error.
Internal request ID.
Additional supporting meta data for the error.
{
"errors": [
{
"status": "500",
"title": "Internal server error",
"detail": "An internal error has occurred.",
"request_id": "00000000-0000-0000-0000-000000000000",
"meta": {
"missing_ids": [
"e7d50bd5-1833-43c0-9848-f9d325b08be8"
]
}
}
]
}
{
"errors": [
{
"title": "Forbidden",
"status": "403",
"detail": "entity owned by organization"
}
]
}
Bad Request. Not Found.
- application/json
- Schema
- Example (from schema)
- internal-server-error
Schema
- Array [
- ]
errors undefined[]required
The HTTP response code of the error.
A brief summary of the error.
Optional additional detail about the error.
Internal request ID.
Additional supporting meta data for the error.
{
"errors": [
{
"status": "500",
"title": "Internal server error",
"detail": "An internal error has occurred.",
"request_id": "00000000-0000-0000-0000-000000000000",
"meta": {
"missing_ids": [
"e7d50bd5-1833-43c0-9848-f9d325b08be8"
]
}
}
]
}
{
"errors": [
{
"title": "Not Found",
"status": "404"
}
]
}
Bad request. The request failed validation.
- application/json
- Schema
- Example (from schema)
- failed-validation
Schema
- Array [
- ]
errors undefined[]required
The HTTP response code of the error.
A brief summary of the error.
Optional additional detail about the error.
Internal request ID.
Additional supporting meta data for the error.
{
"errors": [
{
"status": "500",
"title": "Internal server error",
"detail": "An internal error has occurred.",
"request_id": "00000000-0000-0000-0000-000000000000",
"meta": {
"missing_ids": [
"e7d50bd5-1833-43c0-9848-f9d325b08be8"
]
}
}
]
}
{
"errors": [
{
"title": "Failed Validation",
"status": "422",
"detail": "<XYZ> can not be empty"
}
]
}
Internal server error. There was a system failure in the platform.
- application/json
- Schema
- Example (from schema)
- internal-server-error
Schema
- Array [
- ]
errors undefined[]required
The HTTP response code of the error.
A brief summary of the error.
Optional additional detail about the error.
Internal request ID.
Additional supporting meta data for the error.
{
"errors": [
{
"status": "500",
"title": "Internal server error",
"detail": "An internal error has occurred.",
"request_id": "00000000-0000-0000-0000-000000000000",
"meta": {
"missing_ids": [
"e7d50bd5-1833-43c0-9848-f9d325b08be8"
]
}
}
]
}
{
"errors": [
{
"status": "500",
"title": "Internal Server Error",
"detail": "There was an internal server error, you can report with your request id.",
"request_id": "635da56d-75a1-43cd-b696-7ab119756b3a"
}
]
}