Get a product
GEThttps://euwest.api.elasticpath.com/pcm/products/:productID
Returns a product by its identifier.
You can also use include=component_products
to retrieve top-level resources, such as files or images, and key attribute data, such as SKU or slug for component products in a product bundle. With this option, you can get more information about the products in a product bundle in your store front, improving the buying experience for your shoppers.
Request
Path Parameters
productID stringrequired
A unique identifier for the product.
Query Parameters
- Files or main image. For example,
include=files,main_image
. - Component product data. For example,
include=component_products
. - Key attribute data, such as SKU or slug.
include string
Using the include parameter, you can retrieve top-level resources.
Responses
- 200
- 400
- 404
- 500
Returns a product by its identifier.
- application/json
- Schema
- Example (from schema)
- get-product
- get-product-bundle
- get-product-component-parent
- get-product-component-child
- get-product-component-products
Schema
data object
included object
{
"data": {
"id": "string",
"type": "product",
"attributes": {
"name": "string",
"description": "string",
"slug": "string",
"sku": "string",
"status": "live",
"commodity_type": "physical",
"upc_ean": "string",
"mpn": "string",
"external_ref": "string",
"locales": {},
"tags": [
"string"
],
"extensions": {},
"custom_inputs": {},
"build_rules": {
"default": "include",
"include": [
[
"string"
]
],
"exclude": [
[
"string"
]
]
},
"components": {}
},
"meta": {
"created_at": "2020-09-22T09:00:00",
"updated_at": "2020-09-22T09:00:00",
"owner": "organization",
"variations": [
{
"id": "string",
"name": "string",
"options": [
{
"id": "string",
"name": "string",
"description": "string"
}
]
}
],
"child_variations": [
{
"id": "string",
"name": "string",
"sort_order": 0,
"options": [
{
"id": "string",
"name": "string",
"description": "string"
}
],
"option": {
"id": "string",
"name": "string",
"description": "string"
}
}
],
"product_types": [
"parent"
],
"variation_matrix": {}
},
"relationships": {}
},
"included": {
"component_products": [
{
"id": "string",
"type": "product",
"attributes": {
"name": "string",
"description": "string",
"slug": "string",
"sku": "string",
"status": "live",
"commodity_type": "physical",
"upc_ean": "string",
"mpn": "string",
"external_ref": "string",
"locales": {},
"tags": [
"string"
],
"extensions": {},
"custom_inputs": {},
"build_rules": {
"default": "include",
"include": [
[
"string"
]
],
"exclude": [
[
"string"
]
]
},
"components": {}
},
"meta": {
"created_at": "2020-09-22T09:00:00",
"updated_at": "2020-09-22T09:00:00",
"owner": "organization",
"variations": [
{
"id": "string",
"name": "string",
"options": [
{
"id": "string",
"name": "string",
"description": "string"
}
]
}
],
"child_variations": [
{
"id": "string",
"name": "string",
"sort_order": 0,
"options": [
{
"id": "string",
"name": "string",
"description": "string"
}
],
"option": {
"id": "string",
"name": "string",
"description": "string"
}
}
],
"product_types": [
"parent"
],
"variation_matrix": {}
},
"relationships": {}
}
]
}
}
Product
{
"data": {
"type": "product",
"id": "f5bd4e59-a95f-4bda-bfe6-0f34f47ac94b",
"attributes": {
"commodity_type": "physical",
"description": "This electric model offers an induction heating element and convection oven.",
"mpn": "BE-R-1111-aaaa-1a1a",
"name": "BestEver Range, Model 1a1a",
"sku": "BE-Range-1a1a",
"slug": "bestever-range-1a1a",
"status": "draft",
"upc_ean": "111122223333",
"tags": [
"tag1",
"tag2"
],
"extensions": {
"products(size)": {
"widthMM": 600,
"fuelType": "electric",
"hasUKPlug": true,
"online": null
}
}
},
"relationships": {
"files": {
"data": [],
"links": {
"self": "/products/f5bd4e59-a95f-4bda-bfe6-0f34f47ac94b/relationships/files"
}
},
"templates": {
"data": [],
"links": {
"self": "/products/f5bd4e59-a95f-4bda-bfe6-0f34f47ac94b/relationships/templates"
}
}
},
"meta": {
"created_at": "2023-09-28T10:43:41.72Z",
"owner": "organization",
"product_types": [
"standard"
],
"updated_at": "2023-09-28T10:43:41.72Z",
"variation_matrix": {}
}
}
}
Bundle
{
"data": {
"type": "product",
"id": "495f5c48-c747-4540-86fd-40380bf2df91",
"attributes": {
"commodity_type": "physical",
"components": {
"games": {
"name": "Games",
"options": [
{
"id": "1a499918-2ec0-468d-b7b9-f09eab2f6ad8",
"type": "product",
"quantity": 2,
"sort_order": 15,
"default": true
}
],
"sort_order": 10
}
},
"name": "DOOM Bundle",
"status": "draft"
},
"relationships": {
"children": {
"data": [],
"links": {
"self": "/products/495f5c48-c747-4540-86fd-40380bf2df91/children"
}
},
"component_products": {
"data": [],
"links": {
"self": "/products/495f5c48-c747-4540-86fd-40380bf2df91/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/495f5c48-c747-4540-86fd-40380bf2df91/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/495f5c48-c747-4540-86fd-40380bf2df91/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/495f5c48-c747-4540-86fd-40380bf2df91/relationships/variations"
}
}
},
"meta": {
"created_at": "2024-01-08T13:36:53.658Z",
"owner": "organization",
"product_types": [
"bundle"
],
"updated_at": "2024-01-08T13:36:53.658Z",
"variation_matrix": {}
}
}
}
Parent Product
{
"data": {
"type": "product",
"id": "571e366f-17e6-4e51-8239-b3cc8ee1144d",
"attributes": {
"commodity_type": "physical",
"name": "Jeans",
"sku": "jeans",
"slug": "jeans",
"status": "live"
},
"relationships": {
"children": {
"data": [],
"links": {
"self": "/products/571e366f-17e6-4e51-8239-b3cc8ee1144d/children"
}
},
"component_products": {
"data": [],
"links": {
"self": "/products/571e366f-17e6-4e51-8239-b3cc8ee1144d/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/571e366f-17e6-4e51-8239-b3cc8ee1144d/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/571e366f-17e6-4e51-8239-b3cc8ee1144d/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/571e366f-17e6-4e51-8239-b3cc8ee1144d/relationships/variations"
}
}
},
"meta": {
"created_at": "2024-01-05T10:29:44.214Z",
"owner": "store",
"product_types": [
"parent"
],
"updated_at": "2024-01-05T10:29:45.212Z",
"variation_matrix": {
"46fff1c9-668b-461a-9344-e7a8cbbbf931": "4d32b816-4397-4a71-b875-4e4ea3ce6745",
"843868fc-2440-44d1-8ce7-dc474f79ad1c": "cf501150-f02d-49ad-b7d7-33ed15417b76"
},
"variations": [
{
"id": "ec2bcebd-f42e-4725-8715-c338589e33ea",
"name": "Paint colour",
"options": [
{
"id": "843868fc-2440-44d1-8ce7-dc474f79ad1c",
"name": "Blue",
"description": "This is a colour."
},
{
"id": "46fff1c9-668b-461a-9344-e7a8cbbbf931",
"name": "Red",
"description": "This is a colour."
}
]
}
]
}
}
}
Child Product
{
"data": {
"type": "product",
"id": "4d32b816-4397-4a71-b875-4e4ea3ce6745",
"attributes": {
"commodity_type": "physical",
"name": "Jeans",
"sku": "jeansRed",
"slug": "jeansRed",
"status": "live"
},
"relationships": {
"base_product": {
"data": {
"type": "product",
"id": "571e366f-17e6-4e51-8239-b3cc8ee1144d"
}
},
"children": {
"data": []
},
"component_products": {
"data": [],
"links": {
"self": "/products/4d32b816-4397-4a71-b875-4e4ea3ce6745/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/4d32b816-4397-4a71-b875-4e4ea3ce6745/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/4d32b816-4397-4a71-b875-4e4ea3ce6745/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/4d32b816-4397-4a71-b875-4e4ea3ce6745/relationships/variations"
}
}
},
"meta": {
"created_at": "2024-01-05T10:29:44.603Z",
"owner": "store",
"product_types": [
"child"
],
"updated_at": "2024-01-05T10:29:45.155Z",
"variation_matrix": {},
"child_variations": [
{
"id": "119b2b76-0014-4077-826e-ae80ff207393",
"name": "Size",
"options": null,
"option": {
"id": "fad253ad-4485-4b35-8e3b-b475ad28e78d",
"name": "Medium",
"description": "Medium"
}
},
{
"id": "10ceafef-7ac9-4352-9797-4825a1671482",
"name": "Colour",
"options": null,
"option": {
"id": "b8128e51-1b0a-4b16-9eda-bb783b17026b",
"name": "Red",
"description": "#EE2238"
}
}
]
}
}
}
Component Product
{
"data": {
"type": "product",
"id": "4ca7de77-994d-4e7c-b834-4cb2ae156f57",
"attributes": {
"commodity_type": "physical",
"components": {
"Apples": {
"name": "Apples",
"options": [
{
"id": "f809fe4f-83f7-4db4-8175-e467a0d1974a",
"type": "product",
"quantity": 12
}
]
},
"Oranges": {
"name": "Oranges",
"options": [
{
"id": "7f8f596a-2dc0-4e78-ba0d-3810eac6f86a",
"type": "product",
"quantity": 12
}
]
}
},
"description": "fruit",
"name": "fruit Bundle",
"slug": "45-b",
"status": "live"
},
"relationships": {
"children": {
"data": [],
"links": {
"self": "/products/4ca7de77-994d-4e7c-b834-4cb2ae156f57/children"
}
},
"component_products": {
"data": [],
"links": {
"self": "/products/4ca7de77-994d-4e7c-b834-4cb2ae156f57/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/4ca7de77-994d-4e7c-b834-4cb2ae156f57/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/4ca7de77-994d-4e7c-b834-4cb2ae156f57/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/4ca7de77-994d-4e7c-b834-4cb2ae156f57/relationships/variations"
}
}
},
"meta": {
"created_at": "2022-02-01T12:51:51.132Z",
"owner": "store",
"product_types": [
"bundle"
],
"updated_at": "2022-02-01T12:51:51.132Z",
"variation_matrix": {}
}
},
"included": {
"component_products": [
{
"type": "product",
"id": "f809fe4f-83f7-4db4-8175-e467a0d1974a",
"attributes": {
"commodity_type": "physical",
"description": "fruit",
"name": "Apples",
"sku": "45",
"status": "live"
},
"relationships": {
"children": {
"data": [],
"links": {
"self": "/products/f809fe4f-83f7-4db4-8175-e467a0d1974a/children"
}
},
"component_products": {
"data": [],
"links": {
"self": "/products/f809fe4f-83f7-4db4-8175-e467a0d1974a/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/f809fe4f-83f7-4db4-8175-e467a0d1974a/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/f809fe4f-83f7-4db4-8175-e467a0d1974a/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/f809fe4f-83f7-4db4-8175-e467a0d1974a/relationships/variations"
}
}
},
"meta": {
"created_at": "2022-02-01T12:50:33.347Z",
"owner": "store",
"product_types": [
"standard"
],
"updated_at": "2022-02-01T12:50:33.347Z",
"variation_matrix": {}
}
},
{
"type": "product",
"id": "7f8f596a-2dc0-4e78-ba0d-3810eac6f86a",
"attributes": {
"commodity_type": "physical",
"description": "fruit",
"name": "Oranges",
"sku": "46",
"status": "live"
},
"relationships": {
"children": {
"data": [],
"links": {
"self": "/products/7f8f596a-2dc0-4e78-ba0d-3810eac6f86a/children"
}
},
"component_products": {
"data": [],
"links": {
"self": "/products/7f8f596a-2dc0-4e78-ba0d-3810eac6f86a/relationships/component_products"
}
},
"files": {
"data": [],
"links": {
"self": "/products/7f8f596a-2dc0-4e78-ba0d-3810eac6f86a/relationships/files"
}
},
"main_image": {
"data": null
},
"templates": {
"data": [],
"links": {
"self": "/products/7f8f596a-2dc0-4e78-ba0d-3810eac6f86a/relationships/templates"
}
},
"variations": {
"data": [],
"links": {
"self": "/products/7f8f596a-2dc0-4e78-ba0d-3810eac6f86a/relationships/variations"
}
}
},
"meta": {
"created_at": "2022-02-01T12:49:19.298Z",
"owner": "store",
"product_types": [
"standard"
],
"updated_at": "2022-02-01T12:49:19.298Z",
"variation_matrix": {}
}
}
]
}
}
Bad request. The request failed validation.
- application/json
- Schema
- Example (from schema)
- bad-request
Schema
errors undefined[]required
{
"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": "Bad Request",
"detail": "Could not parse the supplied filter",
"status": "400"
}
]
}
Bad Request. Not Found.
- application/json
- Schema
- Example (from schema)
- internal-server-error
Schema
errors undefined[]required
{
"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"
}
]
}
Internal server error. There was a system failure in the platform.
- application/json
- Schema
- Example (from schema)
- internal-server-error
Schema
errors undefined[]required
{
"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"
}
]
}
Authorization: http
name: bearerAuthtype: httpscheme: bearer
- curl
- python
- go
- nodejs
- ruby
- csharp
- php
- java
- powershell
- CURL
curl -L -X GET 'https://euwest.api.elasticpath.com/pcm/products/:productID' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer <TOKEN>'
ResponseClear