Back to Collection Items
#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkStringBuilder.h>
#include <CkHttpResponse.h>
void ChilkatSample(void)
{
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttp http;
bool success;
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "entitlements": {
// "access": {
// "allow": [
// "urn:elli:encompass:{{encompass_instance_id}}"
// ],
// "deny": [
// ]
// }
// }
// }
CkJsonObject json;
json.UpdateString("entitlements.access.allow[0]","urn:elli:encompass:{{encompass_instance_id}}");
json.UpdateNewArray("entitlements.access.deny");
// Adds the "Authorization: Bearer {{partner_token}}" header.
http.put_AuthToken("{{partner_token}}");
http.SetRequestHeader("Content-Type","application/merge-patch+json");
CkStringBuilder sbRequestBody;
json.EmitSb(sbRequestBody);
CkHttpResponse *resp = http.PTextSb("PATCH","https://domain.com/",sbRequestBody,"utf-8","application/merge-patch+json",false,false);
if (http.get_LastMethodSuccess() == false) {
std::cout << http.lastErrorText() << "\r\n";
return;
}
std::cout << resp->get_StatusCode() << "\r\n";
std::cout << resp->bodyStr() << "\r\n";
delete resp;
}
Curl Command
curl -X PATCH
-H "Authorization: Bearer {{partner_token}}"
-H "Content-Type: application/merge-patch+json"
-d '{
"entitlements": {
"access": {
"allow": [
"urn:elli:encompass:{{encompass_instance_id}}"
],
"deny": []
}
}
}'
https://domain.com/
Postman Collection Item JSON
{
"name": "[Partner] Update a Product",
"_postman_id": "68a5c2d0-73d6-4976-967f-008cb3ea3361",
"request": {
"method": "PATCH",
"header": [
{
"key": "Authorization",
"value": "Bearer {{partner_token}}",
"type": "text"
},
{
"key": "Content-Type",
"name": "Content-Type",
"value": "application/merge-patch+json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"entitlements\": {\n \"access\": {\n \"allow\": [\n \"urn:elli:encompass:{{encompass_instance_id}}\"\n ],\n \"deny\": []\n }\n }\n}\n"
},
"url": "{{api_host}}/partner/v2/products/{{product_id}}"
},
"response": [
]
}