The Aspenware Commerce Inventory feature can be used to control the number of sales allowed for a given day for a specific product or product variant based on Inventory configured in the resort POS. Inventory supports cart locking as well, so when an inventoried product is added to the cart, that available inventory spot will be reserved for them until they check out or their lock expires.
This feature is supported for RTP|One Inventory Pools and Siriusware Max4Sale
This feature is NOT supported for Sirusware Points4Sale
Key Terms
Inventory Function
RTP|ONE Inventory pool slots and Siriusware Max4Sale slots are synced to Aspenware Commerce inventory tables by an Azure function. The sync timer is configurable and is typically set to run to every 5 - 20 minutes. On this interval, the function obtains the latest inventory numbers from the POS and writes them to the Aspenware Commerce inventory table for each component code or DCI configured in Aspenware Commerce’s Inventory Pool administration.
Inventory Locking
Inventory Locking is a mechanism that prevents another guest from “stealing” inventory if they are faster at checking out. It also eliminates the possibility that inventory can oversell if the order processor is delayed. When a customer adds a product to the cart, they “lock” in their inventory and are guaranteed their spot for as long as the lock timer allows. (The duration of the lock timer is configurable.) When a guest completes their order, the system checks inventory levels again and attempts to get an order lock upon order complete. If the product in their cart is still available after the cart lock time expires, they will obtain an order lock and be able to check out. If the product in their cart sells out and is no longer available, they will be prevented from buying that product. The order lock holds the inventory until the inventory is decremented in the POS and the inventory sync runs again, at which point the order lock is released.
Inventory Pools (RTP|One only)
This is RTP|One’s term for their inventory control mechanism. In RTP|One inventory is pooled, meaning multiple product headers can pull from a common inventory pool and all decrement the same inventory, so if the inventory pool is sold out for a date, it will be sold out for all products using that inventory pool.
Max4Sale (Siriusware only)
This is one of two inventory control mechanisms in Siriusware, the other being Points4Sale which Aspenware does not yet support. In Siriusware, Max4Sale inventory is configured at the Department level, or the Department + Category level, or the Department + Category + Item (DCI) level, meaning multiple DCIs cannot pull from a common inventory grouping and all decrement the same inventory unless these items are also in the same Category and Department. If Max4Sale is configured at the DCI level, each DCI has its own Max4Sale allotment, and when it's sold out for a date, only that single DCI will be sold out.
Feature Description
If a product should be limited from being sold on dates when Inventory in the POS is sold out, then set up Inventory in Aspenware Commerce. Based on this setup, inventory numbers in the POS will be checked at a configurable interval, blocking dates in the shop that are no longer available, or warning of low inventory if low-inventory thresholds are configured by the resort. When a guest selects inventory-controlled products and adds them to the cart, Aspenware Commerce locks the slot(s) of inventory on those products for a configurable period (default is 15 minutes), drawing from the most recently synced inventory. If a lock on a product expires before the guest checks out, the inventory is checked again. If the inventory is still available, the guest will be able to check out, but if the product is sold out, the guest will no longer be able to buy that product for that date.
Inventory can be checked for single day products on the day of the product and also checked for multi-day products that are consecutive or non-consecutive. On multi-day products, inventory can be checked for every day of the reservation and will not enable booking if any day of the product is sold out.
RTP|ONE Inventory pool slots and Siriusware Max4Sale slots are synced to Aspenware Commerce inventory tables by an Azure function on a configurable basis. The sync timer is configurable and is defaulted to every N seconds. On this interval, the function obtains the latest inventory numbers from the POS and writes them to the Aspenware Commerce inventory table for each component code or Siriusware Max4Sale value (DCI, Department + Category, or Department) configured in Aspenware Commerce’s Inventory Pool administration.
While the inventory limits available on the shop rely on POS available inventory in RTP|One or Siriusware, it is not called every time a guest navigates to an inventoried product, but rather on a configurable basis. This approach ensures optimal shop performance and eliminates the possibility of overbooking inventory. The inventory that the shop reads from is fully contained within Aspenware and accounts for inventory from the following:
POS (based on the last sync which runs every N minutes)
Items that are in guest carts with an active lock
Items that are in orders that are completed but not “processed” through to the POS
Items that have been “processed” through to the POS but the inventory sync has not yet run to update the shop with the new POS inventory numbers
Because inventory calls can be taxing to the POS database when the sync runs, the following measures improve the performance of this sync when it runs against the POS database:
First, redundant calls that could occur when multiple products point to a single RTP|One inventory pool and inventory location or Sirisuware Max4Sale pool are reduced to a single call.
Second, only dates from today’s date through the end of the season are called. If today’s date is outside of the season, only dates within the upcoming season are called.
Finally, for products that do not need their inventory to be synced at regular intervals and have high availability, there is an option to only sync inventory for these once daily, which limits the regular syncs to only get inventory for products that could reasonably sell out.
Add ‘StoreId’ setting to function app. This means if you have multiple stores, work with your Aspenware Representative to define which store’s season start and end dates the inventory function should use as parameters for dates that it gets inventory for. The current default is 0, which is “All Stores.”
The function to Update Inventory Pool Codes (which looks for changes to the configuration in Aspenware Commerce inventory pools) now can be run on a different frequency from the overall Inventory Sync function.
The inventory sync function was re-written to use proper Azure Durable function architecture and function chaining to increase performance.
The inventory architecture is diagrammed below.
By utilizing this feature, resorts have control of capacity across any of their products. In turn, this will promote increased control and allow resorts to plan proper staffing for upcoming arrivals. In the case of COVID-enforced limitations, resorts can ensure they are adhering to capacity limitations.
Other Interesting Reads
Configuration Links
Like this page? Click the like button below. Don't like this page and/or want to give feedback about this page, leave a comment below and Aspenware will address to improve this article.