Download OpenAPI specification:Download
The products service is responsible for products, pricings and availabilites.
This API is interesting for mainly these use-cases:
Under the hood, snabble's internal services make use of the service's internal endpoints for calculating carts, etc. These endpoints are documented internally.
All endpoints exist within the following paths:
/{projectID}/products
/{projectID}/pricing
/{projectID}/availabilites
Prices and products can exist independently of another. They are joined through their SKU, in the context of a project and a pricing category configured for a shop.
As this is one of the eldest and most central APIs at snabble. it has undergone a lot of changes over time.
The original product schema was later extended with a new content-type application/vnd.snabble.product.list.v2+json
, which has since become the standard.
In 2025, we launched a new major version of the pricing API that features price conditions. As the schema changes were not backwards-compatible, we offer them with a v2 prefix.
For example, the main endpoint for retailer importing prices is now /{projectID}/pricing/v2/category/batch
.
Endpoints relevant to retailer importers and other integrators. Mainly batch imports, but they may also use the REST endpoints for inspecting and updating single resources.
Import an ndjson batch of product objects. Maximal batch size is 20000 items.
If any of the individual product updates cannot be processed, the service will still return status code 200. It is therefore important to inspect the response and the status codes within.
Note that it is not possible to express ndjson in OpenAPI, so only a single entry is expressed here. Multiple entries are separated by linebreaks.
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
project | string (ProjectID) ID of the project |
name | string The display name of the product |
description | string A short description of the product |
subtitle | string An additional title line for individual use (e.g. brand information) |
imageURL | string The full URL for a product image |
depositProduct | string The SKU of the associated deposit product. If a user scans a product with a deposit SKU, the latter will automatically be added to the cart. Deposit products can not be bought on their own. |
bundledProduct | string The SKU of the product contained in the bundle. Bundles are products that contain other products, ie. a crate of beer bottles. |
outOfStock | boolean Default: false Flag to indicate if the product is currently available in markets. |
deleted | boolean Default: false Flag to indicate that a product does not exist any longer. |
taxCategory | string Identifier of the tax category |
weighByCustomer | boolean Default: false Flag, if the product is prepackaged, or the customer has to do weighting by themselves. |
referenceUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" The unit in which the price attribute is calculated (e.g. "kg" where price is EUR/Kg). |
encodingUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" Unit which is used as encoding within the EAN (e.g. "g" when the EAN contains grams). |
Array of objects (Code) Object codes | |
productType | string Enum: "default" "weighable" "deposit" "depositReturnVoucher" Type of the product. Default is "default". |
controlIndication | number Default: 0 Indicates necessity of control. -1 no control needed, 1 high control indication. Default is 0, meaning the configured control probability applies. |
forceControl | boolean Default: false Flag to indicate if a control is necessary. |
saleRestriction | string Enum: "min_age_6" "min_age_12" "min_age_14" "min_age_16" "min_age_18" "min_age_21" "fsk" Sales restrictions, usually minimum age being |
saleStop | boolean Default: false Flag to indicate if there is a sale stop for this product. Flagged products can not be purchased and a default message will be shown This product cannot be paid for using the app. |
pluSet | Array of strings (PLU) PLUs, short codes to identify a weighable product |
scanMessage | string Identifier of a message shown to the user after scanning a product (e.g. a product has more than one package ) |
notForSale | boolean Default: false Flag to indicate if the product is not for sale. When scanning the product only the scan message will be shown. If there is no scan message This product cannot be paid for using the app, please pay for it at the cashier. will be displayed. |
isDiscountable | boolean Default: false Flag to indicate if the product should be considered for discounts. |
isReturnable | boolean Default: false Flag to indicate that the product can be returned. |
priceEntryRequired | boolean Default: false Flag to indicate if the price of the product should be provided by the customer or the cashier. |
fulfillmentType | string Attribute linking the product with a fulfillment process (i.e. issuing of goods through a vending machine) |
object A string map of additional attributes for special use-cases. | |
quantityPriceKey | string (QuantityPriceKey) Key to link products to graduated pricing rules. Products with the same quantity price key are counted together when deciding on quantity-based price for line items. The sum of amounts in line items with the same quantityPriceKey should be used to determine which price quantity condition is satisfied. If the product has no quantityPriceKey, the sum of line items with the same sku should be used. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
{- "sku": "1120325205",
- "status": "ok"
}
Availability batch operation for products in a project.
projectID required | string (ProjectID) ID of the project |
op | string Enum: "put" "delete" |
object (AvailabilityBatchParams) Availability parameters for updating or deleting availabilities in batch |
{- "op": "delete",
- "availability": {
- "shopID": "1234",
- "sku": "123456789"
}
}
{- "availability": {
- "shopID": "string",
- "value": "inStock",
- "project": "string",
- "sku": "string"
}, - "status": "ok",
- "message": "string"
}
Note that this endpoint is not yet finalized and may change in the future.
Import an ndjson batch of category pricing objects. Maximal batch size is limited to 20000 items.
Note that it is not possible to express ndjson in OpenAPI, so only a single entry is expressed here. Multiple entries are separated by linebreaks.
projectID required | string (ProjectID) ID of the project |
sku required | string The SKU of the product for which the pricing applies. |
category required | string The product category for which the pricings apply. |
Array of objects The prices for the product in the category. These will completely replaces the previous prices in the given category. If no prices are included, the product will no longer have any price in the category. |
{- "sku": "1120325205",
- "category": "default",
- "prices": [
- {
- "price": "14.99",
- "currency": "EUR",
- "tier": "list",
- "basePrice": "14,99 €/kg",
- "quantity": 1
}, - {
- "price": "12.99",
- "currency": "EUR",
- "tier": "discount",
- "basePrice": "12,99 €/kg",
- "validFrom": "2024-12-13T00:00:00Z",
- "validTo": "2024-12-20T23:59:59Z",
- "quantity": 1
}
]
}
{- "error": {
- "type": "string",
- "message": "string"
}
}
Point of Sale endpoints. Searching for products, looking up information and prices in the context of a shop.
Search for products. The returned products contain the currently valid
list and base price. Only prices with quantity 1
are considered.
projectID required | string (ProjectID) ID of the project |
search required | string |
shopID required | string |
showProductsWithoutPrices | boolean |
page | integer |
perPage | integer |
{- "search": "string",
- "shopID": "string",
- "showProductsWithoutPrices": true,
- "page": 0,
- "perPage": 0
}
{- "products": [
- {
- "sku": "aSKU",
- "name": "string",
- "description": "string",
- "subtitle": "string",
- "imageUrl": "string",
- "type": "default",
- "saleRestriction": "string",
- "saleStop": true,
- "notForSale": true,
- "price": 1.2,
- "basePrice": "string",
- "weighing": "piece",
- "referenceUnit": "string",
- "encodingUnit": "string",
- "weighByCustomer": true,
- "additionalAttributes": { },
- "quantityPriceKey": "string"
}
], - "pagination": {
- "page": 1,
- "perPage": 50,
- "totalPages": 2,
- "totalItems": 80
}
}
Return a batch of products. If no products are found, the response is empty.
projectID required | string (ProjectID) ID of the project |
limit | integer Example: limit=100 Sets a limit of products returned. 0 is interpreted as no limit. |
q | string Query string. Will do a full text search in the product name and description and will perform a prefix search with the product SKU, EAN and weighed item id. All products found by either search will be returned. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
Retrieve availabilites for a product. Note that it will always respond with availabilities, regardless of whether the project and product actually exists or not.
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
{- "availabilities": [
- {
- "shopID": "1234",
- "project": "a-project",
- "sku": "12345",
- "value": "notAvailable"
}, - {
- "shopID": "1235",
- "project": "a-project",
- "sku": "12345",
- "value": "listed"
}, - {
- "shopID": "1236",
- "project": "a-project",
- "sku": "12345",
- "value": "inStock"
}
]
}
Note that this endpoint is not yet finalized and may change in the future.
Get the product pricing for a specific SKU. The response is sorted by category. The prices for a category are sorted by "tier" and then by "validFrom" date (no date for "validFrom" first).
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
[- {
- "sku": "string",
- "pricings": [
- {
- "category": "string",
- "prices": [
- {
- "tier": "string",
- "price": "14.99",
- "currency": "EUR",
- "basePrice": "string",
- "validFrom": "2019-08-24T14:15:22Z",
- "validTo": "2019-08-24T14:15:22Z",
- "quantity": 10
}
]
}
]
}
]
THIS WILL DELETE EVERYTHING FROM THE PROJECT! PROCEED WITH EXTREME CAUTION!
projectID required | string (ProjectID) ID of the project |
{- "error": {
- "type": "string",
- "message": "string"
}
}
Return a batch of products. If no products are found, the response is empty.
projectID required | string (ProjectID) ID of the project |
limit | integer Example: limit=100 Sets a limit of products returned. 0 is interpreted as no limit. |
q | string Query string. Will do a full text search in the product name and description and will perform a prefix search with the product SKU, EAN and weighed item id. All products found by either search will be returned. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
project | string (ProjectID) ID of the project |
name | string The display name of the product |
description | string A short description of the product |
subtitle | string An additional title line for individual use (e.g. brand information) |
imageURL | string The full URL for a product image |
depositProduct | string The SKU of the associated deposit product. If a user scans a product with a deposit SKU, the latter will automatically be added to the cart. Deposit products can not be bought on their own. |
bundledProduct | string The SKU of the product contained in the bundle. Bundles are products that contain other products, ie. a crate of beer bottles. |
outOfStock | boolean Default: false Flag to indicate if the product is currently available in markets. |
deleted | boolean Default: false Flag to indicate that a product does not exist any longer. |
taxCategory | string Identifier of the tax category |
weighByCustomer | boolean Default: false Flag, if the product is prepackaged, or the customer has to do weighting by themselves. |
referenceUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" The unit in which the price attribute is calculated (e.g. "kg" where price is EUR/Kg). |
encodingUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" Unit which is used as encoding within the EAN (e.g. "g" when the EAN contains grams). |
Array of objects (Code) Object codes | |
productType | string Enum: "default" "weighable" "deposit" "depositReturnVoucher" Type of the product. Default is "default". |
controlIndication | number Default: 0 Indicates necessity of control. -1 no control needed, 1 high control indication. Default is 0, meaning the configured control probability applies. |
forceControl | boolean Default: false Flag to indicate if a control is necessary. |
saleRestriction | string Enum: "min_age_6" "min_age_12" "min_age_14" "min_age_16" "min_age_18" "min_age_21" "fsk" Sales restrictions, usually minimum age being |
saleStop | boolean Default: false Flag to indicate if there is a sale stop for this product. Flagged products can not be purchased and a default message will be shown This product cannot be paid for using the app. |
pluSet | Array of strings (PLU) PLUs, short codes to identify a weighable product |
scanMessage | string Identifier of a message shown to the user after scanning a product (e.g. a product has more than one package ) |
notForSale | boolean Default: false Flag to indicate if the product is not for sale. When scanning the product only the scan message will be shown. If there is no scan message This product cannot be paid for using the app, please pay for it at the cashier. will be displayed. |
isDiscountable | boolean Default: false Flag to indicate if the product should be considered for discounts. |
isReturnable | boolean Default: false Flag to indicate that the product can be returned. |
priceEntryRequired | boolean Default: false Flag to indicate if the price of the product should be provided by the customer or the cashier. |
fulfillmentType | string Attribute linking the product with a fulfillment process (i.e. issuing of goods through a vending machine) |
object A string map of additional attributes for special use-cases. | |
quantityPriceKey | string (QuantityPriceKey) Key to link products to graduated pricing rules. Products with the same quantity price key are counted together when deciding on quantity-based price for line items. The sum of amounts in line items with the same quantityPriceKey should be used to determine which price quantity condition is satisfied. If the product has no quantityPriceKey, the sum of line items with the same sku should be used. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
Updates a product with the given SKU, or creates it if it doesn't already exists.
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
Note that the SKU in the request body must match the path parameter.
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
project | string (ProjectID) ID of the project |
name | string The display name of the product |
description | string A short description of the product |
subtitle | string An additional title line for individual use (e.g. brand information) |
imageURL | string The full URL for a product image |
depositProduct | string The SKU of the associated deposit product. If a user scans a product with a deposit SKU, the latter will automatically be added to the cart. Deposit products can not be bought on their own. |
bundledProduct | string The SKU of the product contained in the bundle. Bundles are products that contain other products, ie. a crate of beer bottles. |
outOfStock | boolean Default: false Flag to indicate if the product is currently available in markets. |
deleted | boolean Default: false Flag to indicate that a product does not exist any longer. |
taxCategory | string Identifier of the tax category |
weighByCustomer | boolean Default: false Flag, if the product is prepackaged, or the customer has to do weighting by themselves. |
referenceUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" The unit in which the price attribute is calculated (e.g. "kg" where price is EUR/Kg). |
encodingUnit | string Enum: "ml" "cl" "dl" "l" "m3" "cm3" "m2" "m2e-1" "dm2" "m2e-3" "cm2" "mm" "cm" "dm" "m" "g" "dag" "hg" "kg" "t" "piece" "price" Unit which is used as encoding within the EAN (e.g. "g" when the EAN contains grams). |
Array of objects (Code) Object codes | |
productType | string Enum: "default" "weighable" "deposit" "depositReturnVoucher" Type of the product. Default is "default". |
controlIndication | number Default: 0 Indicates necessity of control. -1 no control needed, 1 high control indication. Default is 0, meaning the configured control probability applies. |
forceControl | boolean Default: false Flag to indicate if a control is necessary. |
saleRestriction | string Enum: "min_age_6" "min_age_12" "min_age_14" "min_age_16" "min_age_18" "min_age_21" "fsk" Sales restrictions, usually minimum age being |
saleStop | boolean Default: false Flag to indicate if there is a sale stop for this product. Flagged products can not be purchased and a default message will be shown This product cannot be paid for using the app. |
pluSet | Array of strings (PLU) PLUs, short codes to identify a weighable product |
scanMessage | string Identifier of a message shown to the user after scanning a product (e.g. a product has more than one package ) |
notForSale | boolean Default: false Flag to indicate if the product is not for sale. When scanning the product only the scan message will be shown. If there is no scan message This product cannot be paid for using the app, please pay for it at the cashier. will be displayed. |
isDiscountable | boolean Default: false Flag to indicate if the product should be considered for discounts. |
isReturnable | boolean Default: false Flag to indicate that the product can be returned. |
priceEntryRequired | boolean Default: false Flag to indicate if the price of the product should be provided by the customer or the cashier. |
fulfillmentType | string Attribute linking the product with a fulfillment process (i.e. issuing of goods through a vending machine) |
object A string map of additional attributes for special use-cases. | |
quantityPriceKey | string (QuantityPriceKey) Key to link products to graduated pricing rules. Products with the same quantity price key are counted together when deciding on quantity-based price for line items. The sum of amounts in line items with the same quantityPriceKey should be used to determine which price quantity condition is satisfied. If the product has no quantityPriceKey, the sum of line items with the same sku should be used. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
{- "error": {
- "type": "string",
- "message": "string"
}
}
projectID required | string (ProjectID) ID of the project |
plu required | string (PLU) PLU (Price Look-up) of a product. A PLU can only be assigned to one product. If a PLU is assigned to multiple products in a batch, it will only be applied to one of them. |
{- "sku": "1120325205",
- "project": "project",
- "name": "Premium-Holzöl",
- "description": "farblos, 750ml",
- "subtitle": "Aplina",
- "taxCategory": "normal",
- "productType": "default",
- "controlIndication": 0.4,
- "saleRestriction": "min_age_18",
- "saleStop": true,
- "notForSale": true,
- "isDiscountable": true,
- "isReturnable": true,
- "scanMessage": "multipack-2",
- "codes": [
- {
- "code": "0654203316514",
- "transmissionCode": "1234203316514",
- "template": "default"
}
], - "additionalAttributes": {
- "this": "that",
- "foo": "bar"
}
}
projectID required | string (ProjectID) ID of the project |
plu-prefix required | string Partial PLU. Performs a case-insensitive prefix search for the given input. |
[- "123456789",
- "1120325205"
]
Search for products. The returned products contain the currently valid
list and base price. Only prices with quantity 1
are considered.
projectID required | string (ProjectID) ID of the project |
search required | string |
shopID required | string |
showProductsWithoutPrices | boolean |
page | integer |
perPage | integer |
{- "search": "string",
- "shopID": "string",
- "showProductsWithoutPrices": true,
- "page": 0,
- "perPage": 0
}
{- "products": [
- {
- "sku": "aSKU",
- "name": "string",
- "description": "string",
- "subtitle": "string",
- "imageUrl": "string",
- "type": "default",
- "saleRestriction": "string",
- "saleStop": true,
- "notForSale": true,
- "price": 1.2,
- "basePrice": "string",
- "weighing": "piece",
- "referenceUnit": "string",
- "encodingUnit": "string",
- "weighByCustomer": true,
- "additionalAttributes": { },
- "quantityPriceKey": "string"
}
], - "pagination": {
- "page": 1,
- "perPage": 50,
- "totalPages": 2,
- "totalItems": 80
}
}
Note that this endpoint is not yet finalized and may change in the future.
Import an ndjson batch of category pricing objects. Maximal batch size is limited to 20000 items.
Note that it is not possible to express ndjson in OpenAPI, so only a single entry is expressed here. Multiple entries are separated by linebreaks.
projectID required | string (ProjectID) ID of the project |
sku required | string The SKU of the product for which the pricing applies. |
category required | string The product category for which the pricings apply. |
Array of objects The prices for the product in the category. These will completely replaces the previous prices in the given category. If no prices are included, the product will no longer have any price in the category. |
{- "sku": "1120325205",
- "category": "default",
- "prices": [
- {
- "price": "14.99",
- "currency": "EUR",
- "tier": "list",
- "basePrice": "14,99 €/kg",
- "quantity": 1
}, - {
- "price": "12.99",
- "currency": "EUR",
- "tier": "discount",
- "basePrice": "12,99 €/kg",
- "validFrom": "2024-12-13T00:00:00Z",
- "validTo": "2024-12-20T23:59:59Z",
- "quantity": 1
}
]
}
{- "error": {
- "type": "string",
- "message": "string"
}
}
Note that this endpoint is not yet finalized and may change in the future.
Get the product pricing for a specific SKU. The response is sorted by category. The prices for a category are sorted by "tier" and then by "validFrom" date (no date for "validFrom" first).
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
[- {
- "sku": "string",
- "pricings": [
- {
- "category": "string",
- "prices": [
- {
- "tier": "string",
- "price": "14.99",
- "currency": "EUR",
- "basePrice": "string",
- "validFrom": "2019-08-24T14:15:22Z",
- "validTo": "2019-08-24T14:15:22Z",
- "quantity": 10
}
]
}
]
}
]
Retrieve availabilites for a product. Note that it will always respond with availabilities, regardless of whether the project and product actually exists or not.
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
{- "availabilities": [
- {
- "shopID": "1234",
- "project": "a-project",
- "sku": "12345",
- "value": "notAvailable"
}, - {
- "shopID": "1235",
- "project": "a-project",
- "sku": "12345",
- "value": "listed"
}, - {
- "shopID": "1236",
- "project": "a-project",
- "sku": "12345",
- "value": "inStock"
}
]
}
Create or update availabilities for a product.
projectID required | string (ProjectID) ID of the project |
sku required | string (SKU) SKU (Stock Keeping Unit) of a product. This must be distinct (primary key). |
shopID required | string (ShopID) The ID of the Shop in which the availability applies. |
value required | string (AvailabilityValue) Enum: "inStock" "listed" "notAvailable" Classifies the availability for the product in a given sh0op |
[- {
- "shopID": "1234",
- "value": "notAvailable"
}, - {
- "shopID": "1235",
- "value": "listed"
}, - {
- "shopID": "1236",
- "value": "inStock"
}
]
{- "availabilities": [
- {
- "shopID": "1234",
- "project": "a-project",
- "sku": "12345",
- "value": "notAvailable"
}, - {
- "shopID": "1235",
- "project": "a-project",
- "sku": "12345",
- "value": "listed"
}, - {
- "shopID": "1236",
- "project": "a-project",
- "sku": "12345",
- "value": "inStock"
}
]
}
Availability batch operation for products in a project.
projectID required | string (ProjectID) ID of the project |
op | string Enum: "put" "delete" |
object (AvailabilityBatchParams) Availability parameters for updating or deleting availabilities in batch |
{- "op": "delete",
- "availability": {
- "shopID": "1234",
- "sku": "123456789"
}
}
{- "availability": {
- "shopID": "string",
- "value": "inStock",
- "project": "string",
- "sku": "string"
}, - "status": "ok",
- "message": "string"
}
Return simple statistics about the products in a time period ranging from a selected date until now.
projectID required | string (ProjectID) ID of the project |
since | string Example: since=2022-04-23T18:25:43.511Z ISO 8601 timestamp |
{- "inStock": 240,
- "created": 122,
- "updated": 247,
- "deleted": 8,
- "count": 240
}