ClickPay provides you with a collection of API endpoints which used to process all payments, regardless of if they are through either your own payment pages, the managed payment pages, or if you are using the hosted payment pages.
This article is dedicated to the clarification of the cart ID (cart_id) parameter. "cart_id" is one of the mandatory parameters that the request should have, which indicates the cart/order/invoice/receipt id at the merchant end to easily relate the transaction to.
Specifications
| The Parameter Tag/Name | cart_id | 
| JSON Example | {
    "cart_id": "CART#10001"
} | 
| Data Type | String | 
| Required | ✔ | 
| Validation Rules | - | 
| Min Length | 1 | 
| Max Length | 64 | 
Usage Workflow
Along with the required parameters mentioned in our Step 3 - API Endpoints | Initiating the payment solution article, you will need to set the "cart_id" as shown below:
You can notice that the passed "cart_id" parameter is already included within the response object.
Sample Request Payload
{
    "profile_id": "987654",
    "tran_type": "sale",
    "tran_class": "ecom",
    "cart_id": "CART#1001",
    "cart_currency": "USD",
    "cart_amount": 500,
    "cart_description": "Description of the items/services",
}Sample Response Payload
{
    "tran_ref": "TST2231101374414",
    "tran_type": "Sale",
    "cart_id": "CART#1001",
    "cart_description": "Description of the items/services",
    "cart_currency": "USD",
    "cart_amount": "500.00",
    "redirect_url": "https://secure.clickpay.com.sa/payment/page/599B792482E5A2AB2A3E8373265BA2963700A06113BC510285887ED7",
    "serviceId": 2,
    "profileId": 987654,
    "merchantId": 123456,
    "trace": "PMNT0404.6368BC3D.000BAF4C"
}..
