Create a Multi-location Inventories Resource
Imagine managing inventory across multiple locations effortlessly. Commerce Extensions makes this possible with Custom APIs designed to handle specific data points like SKU, Collection Name, Location Name, and Inventory amount. This functionality allows businesses to quickly provide inventory information to customers, enhancing the shopping experience.
Prerequisites
If you want to follow along, you need a Client credential token.
Step-by-step Walkthrough
- Create a Custom API location inventories.
- Create Custom Fields to store the relevant fields for your data.
- Create Custom API Entries to store your location inventory data.
- Update Custom API Entries to track changes to your location inventory data.
Create a new Custom API - location inventories
curl -X POST "https://useast.api.elasticpath.com/v2/settings/extensions/custom-apis" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d ${
"data": {
"slug": "location-inventories",
"api_type": "location-inventories_ext",
"name": "Location Inventories",
"description": "Inventory entries for all SKUs at all retail locations.",
"type": "custom_api"
}
}
Make sure to take note of the Custom API ID returned, you must replace :customApiId
in the following step with the Custom API ID.
Create Custom Fields
Create Custom Field - slug
In this step, you will create a Custom Field slug
, this stores a string to represent this SKU.
curl -X POST "https://useast.api.elasticpath.com/v2/settings/extensions/custom-apis/:customApiId/fields" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d $ {
"data": {
"slug": "slug",
"name": "Slug",
"description": "Slug of the entry",
"field_type": "string",
"type": "custom_field"
}
}
Create Custom Field - amount
In this step, you will create a Custom Field amount
, this stores the amount of inventory of this SKU at this location as an integer.
curl -X POST "https://useast.api.elasticpath.com/v2/settings/extensions/custom-apis/:customApiId/fields" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d $ {
"data": {
"slug": "amount",
"name": "Location Inventory",
"description": "Amount of inventory of this SKU at this location",
"field_type": "integer",
"validation": {
"integer": {
"min_value": 0
}
}
"type": "custom_field"
}
}
Take note of validation
in the step above, this field is restricted to not allow negative values. For more information, see integer validation.
Create Custom Field - location-name
In this step, you will create a Custom Field location-name
, this stores a string to represent where a SKU is stored. Additionally, you will restrict this value to specific options using regex.
curl -X POST "https://useast.api.elasticpath.com/v2/settings/extensions/custom-apis/:customApiId/fields" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d $ {
"data": {
"slug": "location-name",
"name": "Location Name",
"description": "Location Name",
"field_type": "string",
"validation": {
"string": {
"regex": "^(Eiffel Tower|Graceland|Hamptons)"
}
}
"type": "custom_field"
}
}
Take note of validation
in the step above, this field is restricted to only allow the following values:
- Eiffel Tower
- Graceland
- Hamptons
For more information, see string validation.
Create Custom Field - collection-name
In this step, you will create a Custom Field collection-name
, this stores a string to represent the collection a SKU is associated with.
curl -X POST "https://useast.api.elasticpath.com/v2/settings/extensions/custom-apis/:customApiId/fields" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d $ {
"data": {
"slug": "collection-name",
"name": "Collection Name",
"description": "Name of the collection",
"field_type": "string",
"type": "custom_field"
}
}
Create Custom API Entries
With your Custom API configured, create Custom API Entries to store you location inventories.
curl -X POST "https://useast.api.elasticpath.com/v2/extensions/location-inventories" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d ${
"data": {
"type": "location_inventory_ext",
"slug": "LR-SFA-201",
"amount": 4,
"location-name": "Hamptons"
}
}
Notice that the URL you made this request is slightly different, you were able to create a Custom API Entry against the slug
of the Custom API you created earlier.
In addition, the type
in the request body was the api_type
of the Custom API you created earlier.
Finally, take note that the keys (slug
, amount
and location-name
) of the attributes used in the request body are the slug
of the Custom Fields you created earlier.
Update Custom API Entries
With your Custom API Entry created, you can update it to modify inventory amount
.
curl -X PUT "https://useast.api.elasticpath.com/v2/extensions/location-inventories/:customApiEntryId" \
-H "Authorization: XXXX" \
-H "Content-Type: application/json" \
-d ${
"data": {
"type": "location_inventory_ext",
"amount": 3
}
}
Example filters for Common Queries
A customer is on a product page and lives near the Hamptons store and wants to know if this product in this color is available at their local store. Filtering on slug
and location-name
will retrieve the record for that location for that SKU.
curl -X GET "https://useast.api.elasticpath.com/v2/extensions/location-inventories?filter=eq(SKU,ABC123):eq(location-name,Hamptions)" \
-H "Authorization: XXXX" \
I am the buyer for the "Timeless" collection. Show me all SKUs that are out of stock in all locations for SKUs in my collection.
curl -X GET "https://useast.api.elasticpath.com/v2/extensions/location-inventories?filter=eq(amount,0):eq(collection-name,Timeless)" \
-H "Authorization: XXXX" \
As a customer, I am looking to purchase several pieces that match for a room I am redoing. I want to know all products available for the collection I like. Filtering on collection-name
, location-name
and inventory amount
greater than 0 will provide a list of all products in stock in that collection at that location.
curl -X GET "https://useast.api.elasticpath.com/v2/extensions/location-inventories?filter=eq(location-name,Hamptons):eq(collection-name,Timeless):gt(amount,0)" \
-H "Authorization: XXXX" \
For more information, see Filtering.