unicodeC / Razorpay APIs / Implement Thematic Changes in Checkout
Back to Collection Items
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
HCkHttpW http;
BOOL success;
HCkJsonObjectW json;
HCkHttpResponseW resp;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttpW_Create();
CkHttpW_putBasicAuth(http,TRUE);
CkHttpW_putLogin(http,L"username");
CkHttpW_putPassword(http,L"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
// }
// }
// }
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateInt(json,L"amount",1000);
CkJsonObjectW_UpdateString(json,L"currency",L"INR");
CkJsonObjectW_UpdateBool(json,L"accept_partial",TRUE);
CkJsonObjectW_UpdateInt(json,L"first_min_partial_amount",100);
CkJsonObjectW_UpdateString(json,L"reference_id",L"#423212");
CkJsonObjectW_UpdateString(json,L"description",L"Payment for policy no #23456");
CkJsonObjectW_UpdateString(json,L"customer.name",L"Gaurav Kumar");
CkJsonObjectW_UpdateString(json,L"customer.contact",L"+919999999999");
CkJsonObjectW_UpdateString(json,L"customer.email",L"gaurav.kumar@example.com");
CkJsonObjectW_UpdateBool(json,L"notify.sms",TRUE);
CkJsonObjectW_UpdateBool(json,L"notify.email",TRUE);
CkJsonObjectW_UpdateBool(json,L"reminder_enable",TRUE);
CkJsonObjectW_UpdateBool(json,L"options.checkout.theme.hide_topbar",TRUE);
resp = CkHttpW_PostJson3(http,L"https://api.razorpay.com/v1/payment_links",L"application/json",json);
if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
return;
}
wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkHttpResponseW_Dispose(resp);
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
}
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": [
]
}