unicodeC / Razorpay APIs / Transfer Payment Link Amount to Linked Account
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": 1500,
// "currency": "INR",
// "accept_partial": false,
// "reference_id": "#aasasw8",
// "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": {
// "order": {
// "transfers": [
// {
// "account": "acc_CPRsN1LkFccllA",
// "amount": 500,
// "currency": "INR",
// "notes": {
// "branch": "Acme Corp Bangalore North",
// "name": "Bhairav Kumar"
// },
// "linked_account_notes": [
// "branch"
// ]
// },
// {
// "account": "acc_CNo3jSI8OkFJJJ",
// "amount": 500,
// "currency": "INR",
// "notes": {
// "branch": "Acme Corp Bangalore South",
// "name": "Saurav Kumar"
// },
// "linked_account_notes": [
// "branch"
// ]
// }
// ]
// }
// }
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateInt(json,L"amount",1500);
CkJsonObjectW_UpdateString(json,L"currency",L"INR");
CkJsonObjectW_UpdateBool(json,L"accept_partial",FALSE);
CkJsonObjectW_UpdateString(json,L"reference_id",L"#aasasw8");
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"options.order.transfers[0].account",L"acc_CPRsN1LkFccllA");
CkJsonObjectW_UpdateInt(json,L"options.order.transfers[0].amount",500);
CkJsonObjectW_UpdateString(json,L"options.order.transfers[0].currency",L"INR");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[0].notes.branch",L"Acme Corp Bangalore North");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[0].notes.name",L"Bhairav Kumar");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[0].linked_account_notes[0]",L"branch");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[1].account",L"acc_CNo3jSI8OkFJJJ");
CkJsonObjectW_UpdateInt(json,L"options.order.transfers[1].amount",500);
CkJsonObjectW_UpdateString(json,L"options.order.transfers[1].currency",L"INR");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[1].notes.branch",L"Acme Corp Bangalore South");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[1].notes.name",L"Saurav Kumar");
CkJsonObjectW_UpdateString(json,L"options.order.transfers[1].linked_account_notes[0]",L"branch");
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": 1500,
"currency": "INR",
"accept_partial": false,
"reference_id": "#aasasw8",
"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": {
"order": {
"transfers": [
{
"account": "acc_CPRsN1LkFccllA",
"amount": 500,
"currency": "INR",
"notes": {
"branch": "Acme Corp Bangalore North",
"name": "Bhairav Kumar"
},
"linked_account_notes": [
"branch"
]
},
{
"account": "acc_CNo3jSI8OkFJJJ",
"amount": 500,
"currency": "INR",
"notes": {
"branch": "Acme Corp Bangalore South",
"name": "Saurav Kumar"
},
"linked_account_notes": [
"branch"
]
}
]
}
}
}'
https://api.razorpay.com/v1/payment_links/
Postman Collection Item JSON
{
"name": "Transfer Payment Link Amount to Linked Account",
"request": {
"auth": {
"type": "basic",
"basic": [
{
"key": "username",
"value": "rzp_test_SfP9tlfnec4ntR",
"type": "string"
},
{
"key": "password",
"value": "4ucQzqIsRp0yEJmtEmj3xNcH",
"type": "string"
},
{
"key": "showPassword",
"value": false,
"type": "boolean"
}
]
},
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "{\n \"amount\": 1500,\n \"currency\": \"INR\",\n \"accept_partial\": false,\n \"reference_id\": \"#aasasw8\",\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 \"order\": {\n \"transfers\": [\n {\n \"account\": \"acc_CPRsN1LkFccllA\",\n \"amount\": 500,\n \"currency\": \"INR\",\n \"notes\": {\n \"branch\": \"Acme Corp Bangalore North\",\n \"name\": \"Bhairav Kumar\"\n },\n \"linked_account_notes\": [\n \"branch\"\n ]\n },\n {\n \"account\": \"acc_CNo3jSI8OkFJJJ\",\n \"amount\": 500,\n \"currency\": \"INR\",\n \"notes\": {\n \"branch\": \"Acme Corp Bangalore South\",\n \"name\": \"Saurav Kumar\"\n },\n \"linked_account_notes\": [\n \"branch\"\n ]\n }\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": "Using Razorpay Payment Links, you can transfer the payments received from your customers automatically to your linked accounts. You no longer need to create a separate transfer using Razorpay Route Transfers API. Instead, you can use the order parameter in <a href=\"https://razorpay.com/docs/api/payment-links/advanced-options/transfers/\" target=\"_blank\">Create Payment Links API</a> to automate the transfer once the payment is received from the customer."
},
"response": [
]
}