unicodeC / Razorpay APIs / Create a Payment Link
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,
// "expire_by": 1691097057,
// "reference_id": "TSsd1989",
// "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,
// "notes": {
// "policy_name": "Jeevan Bima"
// },
// "callback_url": "https://example-callback-url.com/",
// "callback_method": "get"
// }
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_UpdateInt(json,L"expire_by",1691097057);
CkJsonObjectW_UpdateString(json,L"reference_id",L"TSsd1989");
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_UpdateString(json,L"notes.policy_name",L"Jeevan Bima");
CkJsonObjectW_UpdateString(json,L"callback_url",L"https://example-callback-url.com/");
CkJsonObjectW_UpdateString(json,L"callback_method",L"get");
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,
"expire_by": 1691097057,
"reference_id": "TSsd1989",
"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,
"notes": {
"policy_name": "Jeevan Bima"
},
"callback_url": "https://example-callback-url.com/",
"callback_method": "get"
}'
https://api.razorpay.com/v1/payment_links
Postman Collection Item JSON
{
"name": "Create a Payment Link",
"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 \"expire_by\": 1691097057,\n \"reference_id\": \"TSsd1989\",\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 \"notes\": {\n \"policy_name\": \"Jeevan Bima\"\n },\n \"callback_url\": \"https://example-callback-url.com/\",\n \"callback_method\": \"get\"\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 create a payment link using the <a href=\"https://razorpay.com/docs/api/payment-links/#create-payment-link\" target=\"_blank\">Create a Payment Link API</a>."
},
"response": [
]
}