unicodeC / Razorpay APIs / Update Subscription
Back to Collection Items
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
HCkHttpW http;
BOOL success;
HCkJsonObjectW json;
HCkStringBuilderW sbRequestBody;
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.
// {
// "plan_id": "{plan_id}",
// "quantity": 3,
// "remaining_count": 6,
// "schedule_change_at": "now",
// "customer_notify": 1,
// "offer_id": "{offer_id}"
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(json,L"plan_id",L"{plan_id}");
CkJsonObjectW_UpdateInt(json,L"quantity",3);
CkJsonObjectW_UpdateInt(json,L"remaining_count",6);
CkJsonObjectW_UpdateString(json,L"schedule_change_at",L"now");
CkJsonObjectW_UpdateInt(json,L"customer_notify",1);
CkJsonObjectW_UpdateString(json,L"offer_id",L"{offer_id}");
CkHttpW_SetRequestHeader(http,L"Content-Type",L"application/json");
sbRequestBody = CkStringBuilderW_Create();
CkJsonObjectW_EmitSb(json,sbRequestBody);
resp = CkHttpW_PTextSb(http,L"PATCH",L"https://api.razorpay.com/v1/subscriptions/{sub_id}",sbRequestBody,L"utf-8",L"application/json",FALSE,FALSE);
if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
return;
}
wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkHttpResponseW_Dispose(resp);
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
}
Curl Command
curl -X PATCH
-u 'username:password'
-H "Content-Type: application/json"
-d '{
"plan_id": "{plan_id}",
"quantity": 3,
"remaining_count": 6,
"schedule_change_at": "now",
"customer_notify": 1,
"offer_id":"{offer_id}"
}'
https://api.razorpay.com/v1/subscriptions/{sub_id}
Postman Collection Item JSON
{
"name": "Update Subscription",
"request": {
"method": "PATCH",
"header": [
{
"key": "Content-Type",
"name": "Content-Type",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"plan_id\": \"{plan_id}\",\n \"quantity\": 3,\n \"remaining_count\": 6,\n \"schedule_change_at\": \"now\",\n \"customer_notify\": 1,\n \"offer_id\":\"{offer_id}\"\n}"
},
"url": {
"raw": "https://api.razorpay.com/v1/subscriptions/{sub_id}",
"protocol": "https",
"host": [
"api",
"razorpay",
"com"
],
"path": [
"v1",
"subscriptions",
"{sub_id}"
]
},
"description": "You can update a specific subscription created by you using the <a href=\"https://razorpay.com/docs/api/subscriptions/#update-a-subscription\" target=\"_blank\">Update a Subscription API</a>."
},
"response": [
]
}