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.

  1. You can pass some free text in order_note (around 200 characters)
  2. 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 details
  • POST /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

341

Dynamic GST QR code image