PureBasic / Razorpay APIs / Update a Virtual 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.
    ; {
    ;   "types": [
    ;     "vpa"
    ;   ],
    ;   "vpa": {
    ;     "descriptor": "gaurikumar"
    ;   }
    ; }
    json.i = CkJsonObject::ckCreate()
    If json.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf
    CkJsonObject::ckUpdateString(json,"types[0]","vpa")
    CkJsonObject::ckUpdateString(json,"vpa.descriptor","gaurikumar")
    resp.i = CkHttpResponse::ckCreate()
    If resp.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf
    success = CkHttp::ckHttpJson(http,"POST","https://api.razorpay.com/v1/virtual_accounts/{va_id}/receivers",json,"application/json",resp)
    If success = 0
        Debug CkHttp::ckLastErrorText(http)
        CkHttp::ckDispose(http)
        CkJsonObject::ckDispose(json)
        CkHttpResponse::ckDispose(resp)
        ProcedureReturn
    EndIf
    Debug Str(CkHttpResponse::ckStatusCode(resp))
    Debug CkHttpResponse::ckBodyStr(resp)
    CkHttp::ckDispose(http)
    CkJsonObject::ckDispose(json)
    CkHttpResponse::ckDispose(resp)
    ProcedureReturn
EndProcedure
        Curl Command
        curl -X POST
	-u 'username:password'
	-d '{
    "types": [
        "vpa"
    ],
    "vpa": {
        "descriptor": "gaurikumar"
    }
}'
https://api.razorpay.com/v1/virtual_accounts/{va_id}/receivers
        Postman Collection Item JSON
        {
  "name": "Update a Virtual Account",
  "request": {
    "method": "POST",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"types\": [\n        \"vpa\"\n    ],\n    \"vpa\": {\n        \"descriptor\": \"gaurikumar\"\n    }\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "https://api.razorpay.com/v1/virtual_accounts/{va_id}/receivers",
      "protocol": "https",
      "host": [
        "api",
        "razorpay",
        "com"
      ],
      "path": [
        "v1",
        "virtual_accounts",
        "{va_id}",
        "receivers"
      ]
    },
    "description": "You can use this [API](https://razorpay.com/docs/api/smart-collect/#add-receiver-to-an-existing-virtual-account) to add a receiver to a virtual account."
  },
  "response": [
  ]
}