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"?>
// <address>
// <name>address with cf</name>
// <location-code>CODETEST1</location-code>
// <street1>line address1</street1>
// <street2>line address2</street2>
// <city>Reno</city>
// <state>NV</state>
// <postal-code>08550-3423</postal-code>
// <active>true</active>
// <country>
// <code>US</code>
// </country>
// <custom-fields>
// <date type="dateTime">2021-11-07</date>
// </custom-fields>
// </address>
//
xml = CkXml_Create();
CkXml_putTag(xml,"address");
CkXml_UpdateChildContent(xml,"name","address with cf");
CkXml_UpdateChildContent(xml,"location-code","CODETEST1");
CkXml_UpdateChildContent(xml,"street1","line address1");
CkXml_UpdateChildContent(xml,"street2","line address2");
CkXml_UpdateChildContent(xml,"city","Reno");
CkXml_UpdateChildContent(xml,"state","NV");
CkXml_UpdateChildContent(xml,"postal-code","08550-3423");
CkXml_UpdateChildContent(xml,"active","true");
CkXml_UpdateChildContent(xml,"country|code","US");
CkXml_UpdateAttrAt(xml,"custom-fields|date",TRUE,"type","dateTime");
CkXml_UpdateChildContent(xml,"custom-fields|date","2021-11-07");
// Adds the "Authorization: Bearer <access_token>" header.
CkHttp_putAuthToken(http,"<access_token>");
sbRequestBody = CkStringBuilder_Create();
CkXml_GetXmlSb(xml,sbRequestBody);
resp = CkHttp_PTextSb(http,"POST","https://domain.com/addresses?fields=[\"id\",\"name\",\"active\",\"street1\",\"street2\",\"city\",\"state\",\"postal_code\",\"location_code\",{\"country\":{}},{\"tax_registrations\":{}},{\"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 POST
-H "Authorization: Bearer <access_token>"
-d '<address>
<name>address with cf</name>
<location-code>CODETEST1</location-code>
<street1>line address1</street1>
<street2>line address2</street2>
<city>Reno</city>
<state>NV</state>
<postal-code>08550-3423</postal-code>
<active>true</active>
<country>
<code>US</code>
</country>
<custom-fields>
<date type="dateTime">2021-11-07</date>
</custom-fields>
</address>'
https://domain.com/addresses?fields=["id","name","active","street1","street2","city","state","postal_code","location_code",{"country":{}},{"tax_registrations":{}},{"custom_fields":{}}]
Postman Collection Item JSON
{
"name": "Create Address",
"request": {
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "<address>\n <name>address with cf</name>\n <location-code>CODETEST1</location-code>\n <street1>line address1</street1>\n <street2>line address2</street2>\n <city>Reno</city>\n <state>NV</state>\n <postal-code>08550-3423</postal-code>\n <active>true</active>\n <country>\n <code>US</code>\n </country>\n <custom-fields>\n <date type=\"dateTime\">2021-11-07</date>\n </custom-fields>\n</address>",
"options": {
"raw": {
"language": "xml"
}
}
},
"url": {
"raw": "{{URL}}/addresses?fields=[\"id\",\"name\",\"active\",\"street1\",\"street2\",\"city\",\"state\",\"postal_code\",\"location_code\",{\"country\":{}},{\"tax_registrations\":{}},{\"custom_fields\":{}}]",
"host": [
"{{URL}}"
],
"path": [
"addresses"
],
"query": [
{
"key": "fields",
"value": "[\"id\",\"name\",\"active\",\"street1\",\"street2\",\"city\",\"state\",\"postal_code\",\"location_code\",{\"country\":{}},{\"tax_registrations\":{}},{\"custom_fields\":{}}]"
}
]
}
},
"response": [
]
}