CalculateOrder
Description
We use this method to calculate the order in real time against the business rules defined in the ERP system. Extra orderlines can be returned, for example service fees, shipping costs and/or administrative fees.
SOAP API:
Action
http://shoxl.com/ShoxlService/CalculateOrder
Please note: this is not a working url, but a combination of namespace and method. Do not expect the url to return a result.
Style
Document
Input (Literal)
The input of this method is the document element tns:CalculateOrder having the structure defined by the following table.
Element | Type | Occurs | Description |
Sequence | 1..1 | ||
request | tns:CalculateOrderRequest | 0..1 |
Complex Type: tns:CalculateOrderRequest
Description
The CalculateOrderRequest contains all the information needed to calculate the
Order in the ERP system.
Component | Type | Occurs | Description |
Sequence | 1..1 | ||
AccountNumber | s:string | 1..1 | This is the (project) account number of the customer. |
ExternalOrderNumber | s:string | 1..1 | This the Shoxl Shop unique order number |
OrderLines | tns:ArrayOfOrderLineRequest | 0..1 | A list of order lines. The order needs to be calculated for. |
ShipmentMethodCode | s:int | 1..1 | A Shipment Method Code: 0 = pickup by customer, 1 = default delivery |
Complex Type: tns:ArrayOfOrderLineRequest
Component | Type | Occurs | Description |
Sequence | 1..1 | ||
OrderLine | tns:OrderLineRequest | 0..* |
Complex Type: tns:OrderLineRequest
A orderline Request contains all the information needed to calculate.
Component | Type | Occurs | Description |
Sequence | 1..1 | ||
IsExternal | s:boolean | 1..1 | If the order line is added by the ERP system (for example when its an extra fee or shipping costs), this field must be set true. If Shoxl Shop adds an order line this field is set false. |
ProductNumber | s:string | 1..1 | The product number for the requested product details, this can be a customer-specific product number |
Quantity | s:int | 1..1 | The amount of products ordered |
BaseUnit | s:string | 0..1 | The unit to be used for getting the correct price |
Output (Literal)
The output of this method is the document element tns:CalculateOrderResponse having the structure defined by the following table.
Element | Type | Occurs | Description |
Sequence | 1..1 | ||
CalculateOrderResult | tns:CalculateOrderResult | 0..1 |
Complex Type: tns:CalculateOrderResult
Description
The CalculateOrderResult contains the update order line information from the
ERP system.
Component | Type | Occurs | Description |
Sequence | 1..1 | ||
ErrorCode | s:string | 0..1 | An error code returned by the ERP system |
ErrorDescription | s:string | 0..1 | The error description related to the error code returned by the ERP system |
OrderLines | tns:ArrayOfOrderLine | 0..1 | The calculated orderlines. |
TotalAmount | s:int | 1..1 | The total amount of items in the order |
TotalDiscountExclVat | s:decimal | 1..1 | The total amount of discount excluding VAT |
TotalPriceExclVat | s:decimal | 1..1 | The total price of the order excluding VAT |
TotalPriceInclVat | s:decimal | 1..1 | The total price of the order including VAT |
TotalVat | s:decimal | 1..1 | The total amount of VAT |
REST API:
URL: /Shoxl/v1/CalculateOrder Method: POST
Changes in ShoxlRestApiSwagger_v8
The vatCode field on OrderLine is replaced by a new taxPercentage field
Changes in ShoxlRestApiSwagger_v16
A new field "context" is introduced in the request body. When configured this object contains key value pairs (e.g. divisionCode).
Request body:
CalculateOrderRequest{
Parameter | Type | |
---|---|---|
accountNumber | string required | This is the (project) account number of the customer. |
externalOrderNumber | string | This the Shoxl Shop unique order number |
orderLines | [OrderLineRequest] | The order needs to be calculated for. |
shipmentMethodCode | integer($int32) | A Shipment Method Code: 0 = pickup by customer, 1 = default delivery |
shippingCountry | string | The country where the order is shipped to. Must be a two-letter ISO country code. |
context | object | A generic object designed to hold key-value pairs for the purpose of providing customer-specific fields. |
}
OrderLineRequest{
parameter | type |
isExternal | boolean |
productNumber | string required |
quantity | integer($int32) |
baseUnit | string |
}
Example:
Response body:
CalculateOrderResult{
errorCode | string nullable: true |
errorDescription | string nullable: true |
orderLines | [OrderLine] |
totalAmount | integer($int32) |
totalDiscountExclVat | number($double) nullable: true |
totalPriceExclVat | number($double) nullable: true |
totalPriceInclVat | number($double) nullable: true |
totalVat | number($double) nullable: true |
}
Orderline{
baseUnit | string nullable: true |
carrier | string nullable: true |
discountAmountExclVat | number($double) nullable: true |
discountDescription | string nullable: true |
discountPercentage | number($double) nullable: true |
grossPriceExclVat | number($double) nullable: true |
isExternal | boolean |
nettoPriceExclVat | number($double) nullable: true |
nettoPriceInclVat | number($double) nullable: true |
orderLineStatus | integer($int32) |
priceUnit | number($double) |
productDescription | string nullable: true |
productNumber | string nullable: true |
quantity | number($double) |
remainingQuantity | number($double) |
subTotalPriceExclVat | number($double) nullable: true |
subTotalPriceInclVat | number($double) nullable: true |
trackAndTraceReference | string nullable: true |
taxPercentage | number($double) nullable: true |
type | integer($int32) |
relatedProductNumber | string nullable: true |
}
Types:
Type | Values |
---|---|
Type | None = 0 Product = 1 Shipping = 2 Payment = 3 Other = 4 Discount = 5 DisposalFee = 6 |