PureBasic / Razorpay APIs / Transfer Payment Link Amount to Linked Account
Back to Collection Items
IncludeFile "CkJsonObject.pb"
IncludeFile "CkHttp.pb"
IncludeFile "CkHttpResponse.pb"
Procedure ChilkatExample()
; This example assumes the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
http.i = CkHttp::ckCreate()
If http.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success.i
CkHttp::setCkBasicAuth(http, 1)
CkHttp::setCkLogin(http, "username")
CkHttp::setCkPassword(http, "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.i = CkJsonObject::ckCreate()
If json.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkJsonObject::ckUpdateInt(json,"amount",1500)
CkJsonObject::ckUpdateString(json,"currency","INR")
CkJsonObject::ckUpdateBool(json,"accept_partial",0)
CkJsonObject::ckUpdateString(json,"reference_id","#aasasw8")
CkJsonObject::ckUpdateString(json,"description","Payment for policy no #23456")
CkJsonObject::ckUpdateString(json,"customer.name","Gaurav Kumar")
CkJsonObject::ckUpdateString(json,"customer.contact","+919999999999")
CkJsonObject::ckUpdateString(json,"customer.email","gaurav.kumar@example.com")
CkJsonObject::ckUpdateBool(json,"notify.sms",1)
CkJsonObject::ckUpdateBool(json,"notify.email",1)
CkJsonObject::ckUpdateBool(json,"reminder_enable",1)
CkJsonObject::ckUpdateString(json,"options.order.transfers[0].account","acc_CPRsN1LkFccllA")
CkJsonObject::ckUpdateInt(json,"options.order.transfers[0].amount",500)
CkJsonObject::ckUpdateString(json,"options.order.transfers[0].currency","INR")
CkJsonObject::ckUpdateString(json,"options.order.transfers[0].notes.branch","Acme Corp Bangalore North")
CkJsonObject::ckUpdateString(json,"options.order.transfers[0].notes.name","Bhairav Kumar")
CkJsonObject::ckUpdateString(json,"options.order.transfers[0].linked_account_notes[0]","branch")
CkJsonObject::ckUpdateString(json,"options.order.transfers[1].account","acc_CNo3jSI8OkFJJJ")
CkJsonObject::ckUpdateInt(json,"options.order.transfers[1].amount",500)
CkJsonObject::ckUpdateString(json,"options.order.transfers[1].currency","INR")
CkJsonObject::ckUpdateString(json,"options.order.transfers[1].notes.branch","Acme Corp Bangalore South")
CkJsonObject::ckUpdateString(json,"options.order.transfers[1].notes.name","Saurav Kumar")
CkJsonObject::ckUpdateString(json,"options.order.transfers[1].linked_account_notes[0]","branch")
resp.i = CkHttp::ckPostJson3(http,"https://api.razorpay.com/v1/payment_links/","application/json",json)
If CkHttp::ckLastMethodSuccess(http) = 0
Debug CkHttp::ckLastErrorText(http)
CkHttp::ckDispose(http)
CkJsonObject::ckDispose(json)
ProcedureReturn
EndIf
Debug Str(CkHttpResponse::ckStatusCode(resp))
Debug CkHttpResponse::ckBodyStr(resp)
CkHttpResponse::ckDispose(resp)
CkHttp::ckDispose(http)
CkJsonObject::ckDispose(json)
ProcedureReturn
EndProcedure
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": [
]
}