Back to Collection Items
#include <C_CkHttp.h>
#include <C_CkXml.h>
#include <C_CkStringBuilder.h>
#include <C_CkHttpResponse.h>
void ChilkatSample(void)
{
HCkHttp http;
BOOL success;
HCkXml xml;
HCkStringBuilder sbRequestBody;
HCkHttpResponse resp;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttp_Create();
// Use this online tool to generate code from sample XML: Generate Code to Create XML
// The following XML is sent in the request body.
// <?xml version="1.0" encoding="utf-8"?>
// <commodity>
// <id type="integer">4</id>
// <active>false</active>
// <name>Services</name>
// <category>goods</category>
// </commodity>
//
xml = CkXml_Create();
CkXml_putTag(xml,"commodity");
CkXml_UpdateAttrAt(xml,"id",TRUE,"type","integer");
CkXml_UpdateChildContentInt(xml,"id",4);
CkXml_UpdateChildContent(xml,"active","false");
CkXml_UpdateChildContent(xml,"name","Services");
CkXml_UpdateChildContent(xml,"category","goods");
// Adds the "Authorization: Bearer <access_token>" header.
CkHttp_putAuthToken(http,"<access_token>");
sbRequestBody = CkStringBuilder_Create();
CkXml_GetXmlSb(xml,sbRequestBody);
resp = CkHttp_PTextSb(http,"PUT","https://domain.com/commodities/:id?fields=[\"id\",\"category\",\"name\",\"active\",{\"parent\":[\"id\",\"name\",\"category\",{\"custom_fields\":{}}]},{\"custom_fields\":{}}]",sbRequestBody,"utf-8","application/xml",FALSE,FALSE);
if (CkHttp_getLastMethodSuccess(http) == FALSE) {
printf("%s\n",CkHttp_lastErrorText(http));
CkHttp_Dispose(http);
CkXml_Dispose(xml);
CkStringBuilder_Dispose(sbRequestBody);
return;
}
printf("%d\n",CkHttpResponse_getStatusCode(resp));
printf("%s\n",CkHttpResponse_bodyStr(resp));
CkHttpResponse_Dispose(resp);
CkHttp_Dispose(http);
CkXml_Dispose(xml);
CkStringBuilder_Dispose(sbRequestBody);
}
Curl Command
curl -X PUT
-H "Authorization: Bearer <access_token>"
-d '<commodity>
<id type="integer">4</id>
<active>false</active>
<name>Services</name>
<category>goods</category>
</commodity>'
https://domain.com/commodities/:id?fields=["id","category","name","active",{"parent":["id","name","category",{"custom_fields":{}}]},{"custom_fields":{}}]
Postman Collection Item JSON
{
"name": "Update Existing Commodity",
"request": {
"method": "PUT",
"header": [
],
"body": {
"mode": "raw",
"raw": "<commodity>\n <id type=\"integer\">4</id>\n <active>false</active>\n <name>Services</name>\n <category>goods</category>\n</commodity>",
"options": {
"raw": {
"language": "xml"
}
}
},
"url": {
"raw": "{{URL}}/commodities/:id?fields=[\"id\",\"category\",\"name\",\"active\",{\"parent\":[\"id\",\"name\",\"category\",{\"custom_fields\":{}}]},{\"custom_fields\":{}}]",
"host": [
"{{URL}}"
],
"path": [
"commodities",
":id"
],
"query": [
{
"key": "fields",
"value": "[\"id\",\"category\",\"name\",\"active\",{\"parent\":[\"id\",\"name\",\"category\",{\"custom_fields\":{}}]},{\"custom_fields\":{}}]"
}
],
"variable": [
{
"key": "id",
"value": "4"
}
]
}
},
"response": [
]
}