PureBasic / Razorpay APIs / Set Checkout Fields as Read-Only
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": 1000,
; "currency": "INR",
; "accept_partial": true,
; "first_min_partial_amount": 100,
; "reference_id": "#20",
; "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": {
; "readonly": {
; "email": true,
; "contact": true
; }
; }
; }
; }
json.i = CkJsonObject::ckCreate()
If json.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkJsonObject::ckUpdateInt(json,"amount",1000)
CkJsonObject::ckUpdateString(json,"currency","INR")
CkJsonObject::ckUpdateBool(json,"accept_partial",1)
CkJsonObject::ckUpdateInt(json,"first_min_partial_amount",100)
CkJsonObject::ckUpdateString(json,"reference_id","#20")
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::ckUpdateBool(json,"options.checkout.readonly.email",1)
CkJsonObject::ckUpdateBool(json,"options.checkout.readonly.contact",1)
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": 1000,
"currency": "INR",
"accept_partial": true,
"first_min_partial_amount": 100,
"reference_id": "#20",
"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": {
"readonly": {
"email": true,
"contact": true
}
}
}
}'
https://api.razorpay.com/v1/payment_links/
Postman Collection Item JSON
{
"name": "Set Checkout Fields as Read-Only",
"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\": \"#20\",\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 \"readonly\": {\n \"email\": true,\n \"contact\": 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": "Learn how to customize and set the email and contact fields in the Checkout Section of the Payment Links payment request page using Razorpay API."
},
"response": [
]
}