Identifiers in fabric APIs
This topic explains how fabric uses sku, itemId, pricelineId, and inventoryId as methods of identification with fabric APIs.
In general, fabric uses sku to specify a product because it’s used across all domains. However, other identifiers are also used in certain API services.
fabric recommends avoiding itemId in V3 API implementations. However, itemId is still supported and used in V2.
| Identifier | Description | 
|---|
| sku | This identifier is used across all services, such as Product Catalog, Offers, Carts, Orders, and Inventory. | 
| itemId | This identifier is used in Offers, Carts, Orders, and Inventory. The Product Catalog service doesn’t use itemId. In Carts, a user-generateditemIdis used, separate from theitemIdused in other services. | 
| priceListId | This identifier is used in Offers and Carts. | 
| inventoryId | This identifier is used only in Inventory. | 
Product catalog
Stock keeping unit (SKU)
In Product Catalog, a sku is a unique identifier for a specific product. SKUs are created by the user when adding a product. SKUs are the preferred method for managing products. They allow you to monitor, publish, and unpublish products.
You can perform several key actions with SKUs to manage products and their lifecycles.
The following table shows examples of supported operations using sku:
Similar to SKUs, the itemId is also used to identify products in Product Catalog.
However, unlike SKUs,itemId is automatically generated by the fabric system when a new product is created.
The following table shows examples of supported operations using itemId:
Offers
Stock keeping unit (SKU)
fabric’s Offers APIs enable you to manage prices and create various types of discounts and promotions using sku.
The following are some examples of operations in Offers that are supported using sku:
| Operations | Descriptions | 
|---|
| Set the price of an item | When creating a price for an item, skuoritemIdcan be used as an identifier in the request body. | 
| Retrieve price of an item | When retrieving the default price for an item, skucan be used as an identifier ifpriceListIdisn’t specified. | 
| Delete price of an item | When removing an items price, skucan be used as an identifier ifpriceListIdisn’t specified. | 
| Retrieve product and price details | When retrieving a products price, details, or any additional information, skucan be used as an identifier. | 
Item ID
fabric’s Offers APIs enable you to manage prices and create various types of discounts and promotions using itemId.
The following are some examples of operations in Offers that are supported using itemId:
| Operations | Descriptions | 
|---|
| Set the price of an item | When creating a price for an item, skuoritemIdcan be used as an identifier in the request body. | 
| Retrieve price of an item | When retrieving the default price for an item, itemIdcan be used as an identifier ifpriceListIdisn’t specified. | 
| Delete price of an item | When removing an items price, itemIdcan be used as an identifier ifpriceListIdisn’t specified. | 
| Retrieve product and price details | When retrieving a products price, details, or any additional information, itemIdcan be used as an identifier. | 
Price list ID
Offers API creates a priceListId when generating a price list, which includes generic information such as currency.
The priceListId is used to identify entities that specify how the items should be priced.
The following are some examples of how priceListId is utilized:
| Operations | Descriptions | 
|---|
| Create price list | When creating price list for an item, priceListIdis automatically generated and is used to identify different price lists. | 
| Create promotion | If the priceListis eligible, a promotion is created for the item. | 
| Retrieve SKUs in a price list | In a given price list, all associated skuandproductItemIdvalues are returned in the response body. | 
| Retrieve priced products | If priceListIdis sent in the request body, all items belonging to the price list are returned in the response body. | 
Carts
Stock keeping unit (SKU)
The Carts API allows you to add, update, and remove items, and those items can be identified by sku, from the storefront cart.
When creating a checkout, the system uses the cartId to identify all items using sku in the specific cart.
While sku isn’t used in the path parameter for Carts endpoints, it’s used in the request body. The following shows examples of operations where you use sku in the request body and view it in the response body:
| Operations | Descriptions | 
|---|
| Create a line item | Adds a line item to the cart using sku. | 
| Update a line item | Updates a line item in the cart to a new item by referencing the sku. | 
| Retrieve a cart | In the cart details, you can view the line items and their associated skuvalues. | 
Item ID
The Carts endpoint creates a cart-specific itemId, also referred to as lineItemId. You can use the itemId to add an item to the corresponding cartId and adjust prices.
The following are some examples of operations in Carts that are supported using itemId:
Price list ID
The Carts API uses priceListId to calculate prices and evaluate discounts for individual products and carts. This ensures accurate pricing when items are added to a cart.
The following are some examples of how priceListId is utilized:
Orders
Stock keeping unit (SKU)
When creating or modifying an order, you can add one or more sku by selecting a network and channel, a network and channel, which enables browsing for all the available sku.
Only sku with an “Available” stock status and availability greater than or equal to one can be added to an order.
You can select more than one sku at once and specify the quantity for each.
Orders display sku information, including sku, price per unit, quantity, and availability.
sku is used as unique identifier for items in an order. Order details typically show sku, quantity, and total cost for each item.
The following are some examples of when sku is used to verify that orders contain the correct items:
| Operations | Descriptions | 
|---|
| Create a new order | When creating a new order, the item’s skuanditemIdare used to verify that the correct item is processed. | 
| Search for backorders or preorders | After searching for backorders or preorders, you can use the skuto verify that the correct items are included in the order. | 
| Search for allocation | One of the filter criteria for searching inventory allocation is sku. | 
| Create a new shipment | To fulfill an order and ship it, the items that are set to ship can be identified by sku. | 
Item ID
When creating or modifying an order, you can add one ore more sku by selecting a network and channel, and then browsing available itemId.
Only itemId with an “Available” stock status and availability greater than or equal to one can be added to an order.
You can select more than one itemId at once and specify the quantity for each.
Orders display itemId information, including itemId, price per unit, quantity, and availability.
itemId is used as a unique identifier for items in an order. Order details typically show itemId, quantity, and total cost for each item.
The following are some examples of when itemId is used to verify that orders contain the correct items:
| Operations | Descriptions | 
|---|
| Create a new order | When creating a new order, the item’s skuanditemIdare used to verify that the correct item is processed. | 
| Search for backorders or preorders | After searching for backorders or preorders, you can use the itemIdto verify that the correct items are included in the order. | 
| Search for allocation | One of the filter criteria for searching inventory allocation is itemId. | 
| Create a new shipment | To fulfill an order and ship it, the items that are set to ship can be identified by itemId. | 
Inventory
Stock keeping unit (SKU)
When you create inventory, the sku is stored as a native value.
During network setup, you can apply conditional rules to include specific SKUs and configure safety stock levels to maintain optimal inventory availability.
Inventory networks also aggregate sku quantities across various locations. Even if sku isn’t directly referenced in some endpoints, they play a crucial role in the background.
The following are some examples of operations in Inventory that are supported using sku:
| Operations | Descriptions | 
|---|
| Create inventory | Create inventory using a combination of location number, channel ID, and either skuoritemId. | 
| Add new property to an existing inventory | By using skuto identify inventory, you can add a new property or update an existing one by specifying it in the request body. | 
| Find inventory of specific items | Search for all items in the location specified in the request body that match the skuin the request body. | 
| Create inventory network | Creates an inventory network. Although skuisn’t used directly, it’s utilized within the network to monitor item quantities. | 
Item ID
When you create inventory, the itemId is stored as a native value.
During network setup, you can apply conditional rules to include a specific itemId and configure safety stock levels to maintain optimal inventory availability.
Inventory networks also aggregate itemId quantities across various locations. Even if sku isn’t directly referenced in some endpoints, they play a crucial role in the background.
The following are some examples of operations in Inventory that are supported by itemId:
| Operations | Descriptions | 
|---|
| Create inventory | Create inventory using a combination of location number, channel ID, and either skuoritemId. | 
| Add new property to an existing inventory | By using itemIdto identify inventory, you can add a new property or update an existing one by specifying it in the request body. | 
| Find inventory of specific items | Search for all items in the location specified in the request body that match the itemIdin the request body. | 
| Create inventory network | Creates an inventory network. Although itemIdisn’t used directly, it’s utilized within the network to monitor item quantities. | 
Shipping Method Association: itemId are used to determine which items are associated with specific shipping methods.
Inventory ID
inventoryId is used to track inventory to manage and track product stock across different locations, channels, and items.
Inventory is the only domain that uses inventoryId.
The following are some examples of how inventoryId is utilized: