Back to Collection Items
LOCAL loHttp
LOCAL lnSuccess
LOCAL loXml
LOCAL loSbRequestBody
LOCAL loResp
* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Http')
loHttp = CreateObject('Chilkat.Http')
* 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>
*
* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Xml')
loXml = CreateObject('Chilkat.Xml')
loXml.Tag = "user"
loXml.UpdateChildContent("roles|role|name","Admin")
loXml.UpdateChildContent("roles|role[1]|name","User")
* Adds the "Authorization: Bearer <access_token>" header.
loHttp.AuthToken = "<access_token>"
* For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder')
loSbRequestBody = CreateObject('Chilkat.StringBuilder')
loXml.GetXmlSb(loSbRequestBody)
loResp = loHttp.PTextSb("PUT",'https://domain.com/users/:id?fields=["id",{"roles":["name"]}]',loSbRequestBody,"utf-8","application/xml",0,0)
IF (loHttp.LastMethodSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loXml
RELEASE loSbRequestBody
CANCEL
ENDIF
? STR(loResp.StatusCode)
? loResp.BodyStr
RELEASE loResp
RELEASE loHttp
RELEASE loXml
RELEASE loSbRequestBody
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": [
]
}