Additional Order Data
In some cases you would want to pass some additional data to Cashfree for every order. This data can be used to pass custom data for GST and can be received back in the API calls and reports.
If you have send some custom data for every order you can use multiple different parameters.
- You can pass some free text in
order_note
(around 200 characters) - Or if your use-case requires you to pass structured data, you can use another field
order_tags
.
If you use the order_tags
field, you can pass different key-value pairs for every order. Here are some basic things to keep in mind when using this field.
- The
order_tags
field accepts a collection of key and values. - You can set any key and value. The maximum number of keys supported is 6.
- We do not have any validations on these key values, and hence it is upto the merchant to pass the correct values.
- These custom order tags will also #be part of the transaction report which can be downloaded from the merchant dashboard.
- We do not display these
order_tags
in the merchant dashboard.
curl --request POST \
--url https://sandbox.cashfree.com/pg/orders \
--header 'Content-Type: application/json' \
--header 'x-api-version <<x-api-version>>' \
--header 'x-client-id: xxxx' \
--header 'x-client-secret: xxxx' \
--data '{
"customer_details": {
"customer_email": "[email protected]",
"customer_id": "LD09755CSCON10092021",
"customer_name": "Rohit",
"customer_phone": "9999911111"
},
"order_tags": {
"enrollment": "786712",
"candidate_name": "Rohit"
},
"order_amount": 1,
"order_currency": "INR"
}'
{
"cf_order_id": 607549860,
"order_id": "order_863621yqbBCubgkiunqnTJTkq7so9ken",
"entity": "order",
"order_currency": "INR",
"order_amount": 1.00,
"order_expiry_time": "2021-10-30T11:35:27+05:30",
"customer_details": {
"customer_id": "LD09755CSCON10092021",
"customer_name": "Rohit",
"customer_email": "[email protected]",
"customer_phone": "9999911111"
},
"order_meta": {
"return_url": null,
"notify_url": null,
"payment_methods": null
},
"settlements": {
"url": "https://sandbox.cashfree.com/pg/orders/order_863621yqbBCubgkiunqnTJTkq7so9ken/settlements"
},
"payments": {
"url": "https://sandbox.cashfree.com/pg/orders/order_863621yqbBCubgkiunqnTJTkq7so9ken/payments"
},
"refunds": {
"url": "https://sandbox.cashfree.com/pg/orders/order_863621yqbBCubgkiunqnTJTkq7so9ken/refunds"
},
"order_status": "ACTIVE",
"order_token": "WMaMUspnIx7eSdsiu9Ir",
"order_note": null,
"payment_link": "https://payments-test.cashfree.com/order/#WMaMUspnIx7eSdsiu9Ir",
"order_tags": {
"candidate_name": "Rohit",
"enrollment": "786712"
},
"order_splits": []
}
Report
To get the order_tags
in the report, you can download the report from the merchant dashboard.
Dynamic GST QR Code
RBI had made it mandatory for certain businesses having turnover above 500 crores to print dynamic QR code in all the B2C invoices. Customers should be able to scan these Dynamic QR Codes from any PSP app and make payment for the order invoice. As per RBI, the dynamic QR code should also capture the following information from the merchant:
- Supplier GSTIN number
- Supplier UPI ID
- Payee’s Bank A/C number and IFSC
- Invoice number & invoice date
- Total Invoice Value
- GST amount along with breakup i.e. CGST, SGST, IGST, CESS, etc.
Creating a Dynamic GST QR Code
Merchant's can create these Dynamic GST QR Codes with the help of 2 API call
POST /orders
To create order with GST detailsPOST /orders/sessions
To create Dynamic GST QR Code for an order
Create Order API
To create a Dynamic GST QR Code, first merchant needs to create an order by passing all the required GST details and invoice parameters.
curl --request POST \
--url https://sandbox.cashfree.com/pg/orders \
--header 'Content-Type: application/json' \
--header 'x-api-version: <<x-api-version>>' \
--header 'x-client-id: xxxx' \
--header 'x-client-secret: xxxx' \
--data '{
"order_id": "order_FWkKQOlj",
"order_amount": 20,
"order_currency": "INR",
"customer_details": {
"customer_id": "walterwPzvvJ",
"customer_phone": "8474090589"
},
"order_tags": {
"gst": "5",
"gstin": "27AAFCN5072P1ZV",
"invoice_date": "2021-10-02T13:21:55.459Z",
"invoice_number": "inv1633094531270",
"invoice_link": "https://cashfree.com",
"invoice_name": "Walters Invoice",
"cgst": "2",
"sgst": "2",
"igst": "1",
"cess": "1",
"gst_incentive": "1",
"gst_percentage": "1",
"pincode": "560034",
"city_tier": "TIER1"
}
}'
"cf_order_id": 609944681,
"order_id": "order_FWkKQOlj",
"entity": "order",
"order_currency": "INR",
"order_amount": 20,
"order_expiry_time": "2021-10-31T18:52:47+05:30",
"customer_details": {
"customer_id": "walterwPzvvJ",
"customer_name": null,
"customer_email": null,
"customer_phone": "8474090589"
},
"order_meta": {
"return_url": null,
"notify_url": null,
"payment_methods": null
},
"settlements": {
"url": "https://api.cashfree.com/pg/orders/order_FWkKQOlj/settlements"
},
"payments": {
"url": "https://api.cashfree.com/pg/orders/order_FWkKQOlj/payments"
},
"refunds": {
"url": "https://api.cashfree.com/pg/orders/order_FWkKQOlj/refunds"
},
"order_status": "ACTIVE",
"order_token": "jE8kxCZPkyDYomowFctF",
"order_note": null,
"payment_link": "https://payments.cashfree.com/order/#jE8kxCZPkyDYomowFctF",
"order_tags": {
"cess": "1",
"cgst": "2",
"city_tier": "TIER1",
"gst": "5",
"gst_incentive": "1",
"gst_percentage": "1",
"gstin": "27AAFCN5072P1ZV",
"igst": "1",
"invoice_date": "2021-10-02T18:51:55+05:30",
"invoice_link": "https://cashfree.com",
"invoice_name": "Walters Invoice",
"invoice_number": "inv1633094531270",
"pincode": "560034",
"sgst": "2"
},
"order_splits": []
}
Pay Order API
Once the order is created, an /order/pay
request can be sent to create a Dynamic GST QR Code. In the pay request, payment method should be UPI
, channel should be qrcode
and the add invoice flag should be true
curl --request POST \
--url https://sandbox.cashfree.com/pg/orders/sessions \
--header 'Content-Type: application/json' \
--data '{
"payment_session_id": "jE8kxCZPkyDYomowFctF",
"payment_method": {
"upi": {
"channel": "qrcode",
"add_invoice": true
}
}
}'
{
"payment_method": "upi",
"channel": "qrcode",
"action": "custom",
"data": {
"url": null,
"payload": {
"qrcode": ""
},
"content_type": null,
"method": null
}
}
Generated QR Code
The generate Dynamic QR Code can now be printed in the order invoice
Subscribe to Developer Updates
Updated 5 months ago