C++ / Razorpay APIs / Implement Thematic Changes in Checkout
Back to Collection Items
#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkHttpResponse.h>
void ChilkatSample(void)
{
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttp http;
bool success;
http.put_BasicAuth(true);
http.put_Login("username");
http.put_Password("password");
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "amount": 1000,
// "currency": "INR",
// "accept_partial": true,
// "first_min_partial_amount": 100,
// "reference_id": "#423212",
// "description": "Payment for policy no #23456",
// "customer": {
// "name": "Gaurav Kumar",
// "contact": "+919999999999",
// "email": "gaurav.kumar@example.com"
// },
// "notify": {
// "sms": true,
// "email": true
// },
// "reminder_enable": true,
// "options": {
// "checkout": {
// "theme": {
// "hide_topbar": true
// }
// }
// }
// }
CkJsonObject json;
json.UpdateInt("amount",1000);
json.UpdateString("currency","INR");
json.UpdateBool("accept_partial",true);
json.UpdateInt("first_min_partial_amount",100);
json.UpdateString("reference_id","#423212");
json.UpdateString("description","Payment for policy no #23456");
json.UpdateString("customer.name","Gaurav Kumar");
json.UpdateString("customer.contact","+919999999999");
json.UpdateString("customer.email","gaurav.kumar@example.com");
json.UpdateBool("notify.sms",true);
json.UpdateBool("notify.email",true);
json.UpdateBool("reminder_enable",true);
json.UpdateBool("options.checkout.theme.hide_topbar",true);
CkHttpResponse *resp = http.PostJson3("https://api.razorpay.com/v1/payment_links","application/json",json);
if (http.get_LastMethodSuccess() == false) {
std::cout << http.lastErrorText() << "\r\n";
return;
}
std::cout << resp->get_StatusCode() << "\r\n";
std::cout << resp->bodyStr() << "\r\n";
delete resp;
}
Curl Command
curl -X POST
-u 'username:password'
-d '{
"amount": 1000,
"currency": "INR",
"accept_partial": true,
"first_min_partial_amount": 100,
"reference_id": "#423212",
"description": "Payment for policy no #23456",
"customer": {
"name": "Gaurav Kumar",
"contact": "+919999999999",
"email": "gaurav.kumar@example.com"
},
"notify": {
"sms": true,
"email": true
},
"reminder_enable": true,
"options": {
"checkout": {
"theme": {
"hide_topbar": true
}
}
}
}'
https://api.razorpay.com/v1/payment_links
Postman Collection Item JSON
{
"name": "Implement Thematic Changes in Checkout",
"request": {
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "{\n \"amount\": 1000,\n \"currency\": \"INR\",\n \"accept_partial\": true,\n \"first_min_partial_amount\": 100,\n \"reference_id\": \"#423212\",\n \"description\": \"Payment for policy no #23456\",\n \"customer\": {\n \"name\": \"Gaurav Kumar\",\n \"contact\": \"+919999999999\",\n \"email\": \"gaurav.kumar@example.com\"\n },\n \"notify\": {\n \"sms\": true,\n \"email\": true\n },\n \"reminder_enable\": true,\n \"options\": {\n \"checkout\": {\n \"theme\": {\n \"hide_topbar\": true\n }\n }\n }\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "https://api.razorpay.com/v1/payment_links",
"protocol": "https",
"host": [
"api",
"razorpay",
"com"
],
"path": [
"v1",
"payment_links"
]
},
"description": "You can modify the top bar theme element of the Checkout UI on the payment request page to restrict customers from navigating to the initial screen of Checkout and selecting a different payment method. Know more about <a href=\"https://razorpay.com/docs/api/payment-links/customise/checkout-theme/\" target=\"_blank\">this API</a>."
},
"response": [
]
}