Creating an order in OTO through the API is a simple process when you understand the required fields and the proper API calls. This guide will walk you through the steps necessary to create an order using OTO's REST API.
Instructions
Step 1: Obtain the Required Authentication
- Before making any API request, ensure that you have a valid access Token. The token is necessary for authentication and must be included in the headers of all API requests.To obtain the token, log in to the OTO dashboard and navigate to the Sales Channel section under OTO API. Retrieve your refresh token and then use it to get an access token. 
Step 2: Understand the Required API Endpoint
- The endpoint for creating an order is as follows: https://api.tryoto.com/rest/v2/createOrderThis endpoint requires certain fields to be passed in the request body. These fields define the order's details, such as the customer information, items, delivery address, and additional metadata. 
Step 3: Prepare the Request Body
- The request body must be in JSON format and should include the following fields:
| Name | Required | Type | Description | 
|---|---|---|---|
| orderId | yes | string | Id of the Order | 
| parentOrderId | no | string | parent id of splitted orders. | 
| ref1 | no | string | Reference for order optional | 
| pickupLocationCode | no | string | predefined pickup address of stores/warehouses, if it doesn't exist then OTO will assign it to a pickup location automatically. it is required when serviceTypeis filledpickupfromStore | 
| createShipment | no | boolean | if you fill it truethen automatic shipment will be created for this order.pickupLocationCodeis required when this field istrue. | 
| serviceType | no | string | pickupFromStorethis is optional for orders customer pick it up from store | 
| forReverseShipment | no | boolean | if it is true, order can be reverse shipped without forward shipment | 
| deliveryOptionId | no | string | activated delivery company option id, if this exists OTO try to create shipment with this settings. if not exists try with possible active settings. | 
| storeName | no | String | Name of the store | 
| payment_method | yes | string | Possible values: - cod - paid | 
| amount | yes | Double | Total value amount of the order | 
| amount_due | yes | Double | Total due amount of the order. If order paid amount_due will be 0. Otherwise equal to amount. | 
| currency | yes | String | Currency code of the order currency | 
| shippingAmount | no | Double | shipping amount of this order | 
| subtotal | no | Double | Subtotal of the order | 
| shippingNotes | no | String | Notes of customer for shipping. I.e don’t ring the bell. | 
| packageSize | no | String | Used for specifiying the maximum package size. Possible values smalbox | 
| packageCount | no | Integer | States how many package in the order | 
| packageWeight | no | Double | Total weight of the order | 
| boxWidth | conditional | Double | width of the package, it is needed to use Aggregator shipping options | 
| boxLength | conditional | Double | length of the package, it is needed to use Aggregator shipping options | 
| boxHeight | conditional | Double | height of the package, it is needed to use Aggregator shipping options | 
| deliverySlotDate | no | Date | Prefered Deliverydate | 
| deliverySlotFrom | no | String | “From” time for delivery time | 
| deliverySlotTo | no | String | “To” time for delivery time | 
| orderDate | no | DateTime | Date of the order | 
| senderName | no | String | Sender name | 
| customer | yes | Object | Customer Data | 
| items | yes | Array | Items data | 
| couponCode | no | text | Discount or special offer code. | 
| codFee | no | Double | COD Fee | 
| brandId | no | Long | Brand (Client Store) ID | 
| whoPays | no | String | If implemented, annotates who wil pay for the shipment. Possible values: marketplacePaysDeliveryFee, sellerPaysDeliveryFee | 
- Example Request Body- Here is an example of a request body for creating an order: 
Step 4: Make the API Call
- Use the following cURL command to send the request:
Step 5: Handle the Response
- A successful response will look like this:
The otoId returned in the above response is a unique internal identifier for the order in OTO's database, it is different from the Order ID used in the order payload.
Was this article helpful?
That’s Great!
Thank you for your feedback
Sorry! We couldn't be helpful
Thank you for your feedback
Feedback sent
We appreciate your effort and will try to fix the article