2022-01-10 Pricing Flow
Revision as of 12:25, 16 January 2022 by Sven the Barbarian (talk | contribs)
Filtered List of Sell Offers
- eg: from Browse Catalog
SearchResult: sellOffer
- Final result expected is a list of sellOfferIds and their pricing (eg min or max), along with any other fields wanted
- Original request is sent to sellOffer Search Result service which uses SellOfferManager service to process Logicals and FindData
- Request might originate higher up, eg Product/VariantProduct level, for pricing the sellOffer level is the important start point
- sellOffer searchType / sellOffer filterType
- logical/findData types can be maxPrice/minPrice
Logical: SellOfferManager - sellOffer - maxPrice / minPrice
- passes on to a sortResult request for sellOffer that has logicalTag = aggregatedSellOfferPrices, sorted by price (ascending)
- at the end after the sortResult complete message it will perform logical comparison in ProcessLogicalSortedRequest
- requires sorted aggregatedSellOfferPrices so can perform it's comparison
- searchResult requiredData/FindData is "price" fieldname, found after aggregatedSellOfferPrices complexFilter complete
- once aggregatedSellOfferPrices completes triggers ProcessLogicalSortedRequest (set callingFlow = this service's ProcessLogicalSortedRequest), which will trigger SortResult's CopyDataToExternalTable lambda
- CopyDataToExternalTable will copy sellOfferId records to SellOfferManager's LogicalResults table
- SellOfferManager's CompleteLogicalSortedRequest lambda subscribes to sortResult's CopyDataToExternalTableComplete topic, and completes the Logical request
Logical: SellOfferManager - sellOffer - aggregatedSellOfferPrices
- passes on to sellOffer complexFilter with child complexFilter type planDeliveryPaymentCombination
- we add this step to reduce the number of sellOfferIds that we dig prices combinations for, to only sellOfferIds that have a plan that points to given paymentMethodIds/deliveryMethodIds
- complexFilter will find all unique sellOfferIds that offer requested delivery and payment methods
- sellOffer complexFilter passes down to planDeliveryPaymentCombination filterType handled by SellOfferPlan service
- sellOffer complexFilter will trigger FindSellOfferFilterComplete lambda (callingFlow = this service's FindSellOfferFilterComplete)
Logical: SellOfferPlan - planDeliveryPaymentCombination - planDeliveryPaymentCombination
- invokes sellOfferPlan's FindPlanDeliveryPaymentCombinations lambda
sellOfferPlan - FindPlanDeliveryPaymentCombinations
- queries graph for all sellOfferPlanId + sellOfferPlanDeliveryMethodLinkId + sellOfferPlanPaymentMethodLinkId combinations that match given paymentMethodIds/deliveryMethodIds
- saves each combination into it's LogicalResultsData table
- completes it's logical, which completes the planDeliveryPaymentCombination complexFilter which completes the sellOffer complexFilter (after TranslateIds), which triggers SellOfferManager's FindSellOfferFilterComplete lambda
SellOfferManager - FindSellOfferFilterComplete
- receives complexFilterComplete message for sellOffer level complexFilter
- sellOffer level complexFilter found all unique sellOffers that have planDeliveryPaymentCombination (any combination of given paymentMethodIds/deliveryMethodIds)
- finds all logicalResultMain waiting for this sellOffer complexFilter
- for each logicalResultMain found, send request to CreatePerSellOfferSortedPriceRequests (because next step needs to handle multiple invocations per logicalResultMain)
SellOfferManager - CreatePerSellOfferSortedPriceRequests
- for one logicalResultMain, iterates all sellOfferIds found in sellOffer-planDeliveryPaymentCombination complexFilter results
- passes on to a sortResult request for orderPrice that has logicalTag = sellOfferQuantityLocationIdCombinations, sorted by price (ascending)
- for each sellOfferId we need an ordered list of prices that come from the different deliverToLocationIds/paymentMethodIds/deliveryMethodIds combinations
- searchResult requiredData is "price", will invoke FindData after sellOfferQuantityLocationIdCombinations complexFilter complete
- saves each sellOfferQuantityLocationIdCombinations request into AwaitingMultipleStep for the original aggregatedSellOfferPrices logical
- sends sortResult request to SellOfferManager sortResult service
- once the per sellOffer orderPrice sortResult completes triggers AggregateOneSellOfferPrices for each (set callingFlow = this service's AggregateOneSellOfferPrices)
Logical: SellOfferManager - orderPrice - sellOfferQuantityLocationIdCombinations
- passes on to planDeliveryPaymentCombination complexFilter, finding all combinations for only the requested sellOfferId
- will use the same results as aggregatedSellOfferPrices for the planDeliveryPaymentCombination logicalTag
- once planDeliveryPaymentCombination complexFilter complete triggers SellOfferManager - CreateOrderPriceCombinations (set callingFlow = this service's CreateOrderPriceCombinations)
SellOfferManager - CreateOrderPriceCombinations
- find all logicalResultMains (ie: sellOfferId+orderQuantity+deliverToLocationIds+deliveryMethodIds+paymentMethodIds+excludeEmpty request) that are waiting for this sellOfferId+planDeliveryPaymentCombination filter (initiated in sellOfferQuantityLocationIdCombinations logical)
- for each logicalResultMain's planDeliveryPaymentCombination, iterate the logicalResultMain's deliverToLocationIds to create orderPriceId
- make sure an orderPrice record exists for the calculated orderPriceId
- this will result in multiple orderPriceIds being created/checked exist for one logicalResultMain
- complete each sellOfferQuantityLocationIdCombinations logicalResultMain
- for each sellOfferQuantityLocationIdCombinations logicalResultMain found, the logical complete message will trigger FindData for orderPrice - "price" field (original request created in createPerSellOfferSortedPriceRequests)
FindData: SellOfferManager - orderPrice - price
- orderPrice record should always exist when entering here, eg created by CreateOrderPriceCombinations
- finds the sellOffer subtotal for the orderPrice (not delivery/payment method costs yet) and saves into orderPrice record
- passes on to a sorted searchResult request for sellOfferPlanDeliveryMethodLink with fixed dataIds being a list of deliveryMethodLinkIds (no complexFilter), sorted by price (minDeliveryPrice)
- require minimum DeliveryPrice because there might be multiple locationIds found and we want to use the lowest priced one
- searchResult requiredData is "minDeliveryPrice", which is required for the sorting
- once we have the sorted results we actually want the maximum of the (minDeliveryPrice) results, because there might be multiple deliveryMethodLinkIds found in the given sellOfferQuantities, and we want to return the highest priced one
- once sellOfferPlanDeliveryMethodLink sorted searchResult completes triggers ProcessFindDataSortedRequest (set callingFlow = this service's ProcessFindDataSortedRequest)
ProcessFindDataSortedRequest: SellOfferManager - orderPrice - price - sellOfferPlanDeliveryMethodLink
- saves into orderPrice record: deliveryPrice and sellOfferPlanDeliveryMethodLinkId
- passes on to a sorted searchResult request for sellOfferPlanUserPaymentMethodLink with fixed dataIds being a list of userPaymentMethodLinkIds (no complexFilter), sorted by price (paymentPrice)
- searchResult requiredData is "paymentPrice", which is required for the sorting
- once we have the sorted results we actually want the maximum of the (paymentPrice) results, because there might be multiple userPaymentMethodLinkIds found in the given sellOfferQuantities, and we want to return the highest priced one
- once sellOfferPlanUserPaymentMethodLink sorted searchResult completes triggers ProcessFindDataSortedRequest (set callingFlow = this service's ProcessFindDataSortedRequest)
ProcessFindDataSortedRequest: SellOfferManager - orderPrice - price - sellOfferPlanUserPaymentMethodLink
- saves into orderPrice record: paymentPrice and sellOfferPlanUserPaymentMethodLinkId
- calculates final orderPrice value
- completes the "orderPrice - price" FindData record, this is where one orderPrice is completed
- FindData records are from the sellOfferQuantityLocationIdCombinations searchResult requests, initiated in CreatePerSellOfferSortedPriceRequests
- each CreatePerSellOfferSortedPriceRequests triggers AwaitingMultipleSteps link created in CreatePerSellOfferSortedPriceRequests but linking to original aggregatedSellOfferPrices logical
- each AwaitingMultipleStep triggers AggregateOneSellOffersPrices
SellOfferManager - AggregateOneSellOffersPrices
- finds all aggregatedSellOfferPrices logicals that match the received sellOffer's sorted prices sellOfferOrderPriceSortedRequest
- for each logical found find this sellOffer's orderPriceId from SortResult service that matches the requested aggregation
- check any sellOffer AwaitingMultipleSteps remain for aggregatedSellOfferPrices logical, if not complete it
- original maxPricePerSellOffer / minPricePerSellOffer logical created an awaiting step waiting aggregatedSellOfferPrices logical that triggers CompleteLogicalSortedRequest
SellOfferManager - CompleteLogicalSortedRequest
- performs maxPricePerSellOffer / minPricePerSellOffer logical's comparison and completes that logical
aggregatedSellOfferPrices logical complete
- completed aggregatedSellOfferPrices logical will pass back to the aggregatedOrderPriceSortedRequest SearchResult initiated in "SellOfferManager - orderPrice - maxPricePerSellOffer / minPricePerSellOffer" logical
- SearchResult triggers FindData field "price"
FindData: SellOfferManager - orderPrice - price
- will find cached result in FindData table for the recorded orderPriceId, or will re-calculate if FindData expired
- after all FindData for maxPricePerSellOffer / minPricePerSellOffer logical is complete will trigger ProcessLogicalSortedRequest which will perform the comparison and trigger CompleteLogicalSortedRequest to complete the logical