Validate Offer Service
This service validates the request based on the number of inputs including segments, order, and offer. When you submit an order request, that order is submitted to TIBCO OPE. Based on the product model and group constraints, it returns a message stating if the products are valid or not.
You can apply IncompatibleSegment to a LinkID for the ValidateOffer web service. To implement this, add a UDF with the name SegmentLinkID under the seg:Segment element and under the orderline UDF where you want to map the LinkID under the validateOffer request.
Validate Offer Request
Request Flag Name | Default |
---|---|
validateData | True |
validateProductRequiredForGroups | True |
validateProductComprisedOfGroups | True |
validateProductCompatibility | True |
validateSegmentCompatibility | True |
decomposeProducts | False |
basicValidationOnExistingOffer | True |
validateProdDate | False |
enforceCompatibleSegment | False |
skipChildFilterValidation | False |
Element Name | Element Type | Description |
---|---|---|
BusinessTransactionID | String
(Optional) |
Used for the upstream web services to correlate a response with the appropriate request. |
CalculateConsequences | Boolean
(Mandatory) |
Used to enforce migration for basket items. If it is set to false, those items are invalid. If it is set to true, those items become valid, and the corresponding migration actions are done during the request. |
RequestControl/validateData |
RequestControl (Optional) |
With this element, you can turn off the validation of UDFs, such as type, mandatory, and compatibility, to support a staged order configuration in the sales process. If this is not set, it defaults to true. |
RequestControl/validateProdDate | Boolean
(Optional) |
Toggles if the engine checks that the products are valid based on the configured start dates and end dates. |
RequestControl/validateProductRequiredForGroups | Boolean
(Optional) |
Toggles if ProductRequiredFor groups are evaluated in eligibility. The default value is true. |
RequestControl/validateProductComprisedOfGroups | Boolean
(Optional) |
Toggles if ProductComprisedOf groups are evaluated in eligibility. The default value is true. |
RequestControl/validateProductCompatibility | Boolean
(Optional) |
Toggles if ProductCompatibility is evaluated in eligibility. The default value is true. |
validateSegmentCompatibility | Boolean
(Optional) |
Toggles if SegmentCompatibility is evaluated in eligibility. The default value is true. |
RequestControl/decomposeProducts | Boolean
(Optional) |
Toggles if products are decomposed into autoprovisioned children or requiredForchildren. The default value is true. |
RequestControl/basicValidationOnExistingOffer |
Boolean
(Optional) |
Toggles if the existing basket is validated before selecting eligible products. The default value is false. |
Segments | Boolean
(Optional) |
Segment information is used to validate the compatibility of order items against the provided segments. |
orderRequest |
orderRequest (Optional) |
Products in the basket can be passed into the validation engine through the order. |
Validate Offer Response
Element Name | Element Type | Description |
---|---|---|
Component | String
(Optional) |
The service's name is ExtEligbilityAndValidation |
Operation | String
(Optional) |
The operation's name is validate offer |
Severity | String
(Optional) |
INFO, ERROR |
Code | String
(Optional) |
The error code is the string that identifies the error and the TIBCO Fulfillment Orchestration Suite component that produced the error. An error code of 0 (zero) indicates a successful invocation of the service. |
Message | String
(Optional) |
A descriptive text string associated with the code |
Element Name | Element Type | Description |
---|---|---|
ValidationPass | Boolean
(Mandatory) |
True if the request is validated and no messages of type 'ERROR' are thrown |
Element Name | Element Type | Description |
---|---|---|
LineNumber |
String (Mandatory) |
Indicates on which item the messages were created. |
ProductID | String
(Mandatory) |
The product ID for which the product the message was created. |
Code | String
(Mandatory) |
The code of the validation message. |
Type | String
(Optional) |
The type of validation message. It is mostly an error message because validation messages are only created in case of errors. The only exception is in case of a migration. |
Details | String
(Optional) |
The corresponding textual message is configurable in the GVs located in
AFFOfferConfigurationValidation/Constants/Errors/OfferValidation |
CausingItem | String
(Optional) |
The CausingItem field indicates which type of item caused the validation error or message, for example, TrolleyItem or UDF. |
CausingItemID | String
(Optional) |
The CausingItemID field displays the ID of the item causing the validation error or message, for example, the Product ID or the UDF name. |
CausingItemPosition | String
(Optional) |
The CausingItemPosition indicates the position type of the item causing the validation error or message, for example, LineNumber for Orderline. |
CausingPositionID | String
(Optional) |
The CausingItemPositionID indicates the position of the item causing the validation error or message, for example, LineNumber for Orderline. |
RuleViolation | String
(Optional) |
The RuleViolation displays the concrete violation of the particular rule that created this message, for example, violation of a maximum constraint of Product comprised group is Group.Max: 2.0 / Actual count: 3.0. |
RelatedSegment | String
(Optional) |
Segments for subscribers are mapped into these elements. They are taken into account for the PriceRequiresSegment and DiscountRequiresSegment mechanism.
<Segment> <Name>Segment-Name</Name> <Type>SegmentType</Type> </Segment> |