Back to Collection Items
#include <C_CkHttpW.h>
#include <C_CkXmlW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
HCkHttpW http;
BOOL success;
HCkXmlW xml;
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();
// 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"?>
// <user>
// <roles>
// <role>
// <name>Admin</name>
// </role>
// <role>
// <name>User</name>
// </role>
// </roles>
// </user>
//
xml = CkXmlW_Create();
CkXmlW_putTag(xml,L"user");
CkXmlW_UpdateChildContent(xml,L"roles|role|name",L"Admin");
CkXmlW_UpdateChildContent(xml,L"roles|role[1]|name",L"User");
// Adds the "Authorization: Bearer <access_token>" header.
CkHttpW_putAuthToken(http,L"<access_token>");
sbRequestBody = CkStringBuilderW_Create();
CkXmlW_GetXmlSb(xml,sbRequestBody);
resp = CkHttpW_PTextSb(http,L"PUT",L"https://domain.com/users/:id?fields=[\"id\",{\"roles\":[\"name\"]}]",sbRequestBody,L"utf-8",L"application/xml",FALSE,FALSE);
if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkXmlW_Dispose(xml);
CkStringBuilderW_Dispose(sbRequestBody);
return;
}
wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkHttpResponseW_Dispose(resp);
CkHttpW_Dispose(http);
CkXmlW_Dispose(xml);
CkStringBuilderW_Dispose(sbRequestBody);
}
Curl Command
curl -X PUT
-H "Authorization: Bearer <access_token>"
-d '<user>
<roles>
<role>
<name>Admin</name>
</role>
<role>
<name>User</name>
</role>
</roles>
</user>'
https://domain.com/users/:id?fields=["id",{"roles":["name"]}]
Postman Collection Item JSON
{
"name": "Set / add roles on a user record",
"request": {
"method": "PUT",
"header": [
],
"body": {
"mode": "raw",
"raw": "<user>\n <roles>\n <role>\n <name>Admin</name>\n </role>\n <role>\n <name>User</name>\n </role>\n </roles>\n</user>",
"options": {
"raw": {
"language": "xml"
}
}
},
"url": {
"raw": "{{URL}}/users/:id?fields=[\"id\",{\"roles\":[\"name\"]}]",
"host": [
"{{URL}}"
],
"path": [
"users",
":id"
],
"query": [
{
"key": "fields",
"value": "[\"id\",{\"roles\":[\"name\"]}]"
}
],
"variable": [
{
"key": "id",
"value": "279"
}
]
},
"description": "The process of updating user roles involves two API calls - 1) Remove all roles and 2) Set/add the roles on the user record. "
},
"response": [
]
}