Chilkat Online Tools

delphiDll / Zoho CRM REST APIs / Solutions

Back to Collection Items

var
http: HCkHttp;
success: Boolean;
json: HCkJsonObject;
sbRequestBody: HCkStringBuilder;
resp: HCkHttpResponse;

begin
// 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 JSON: Generate Code to Create JSON

// The following JSON is sent in the request body.

// {
//   "data": [
//     {
//       "Owner": {
//         "id": "{{user-id}}"
//       },
//       "Product_Name": {
//         "id": "{{product-id}}"
//       },
//       "Status": "Duplicate",
//       "Answer": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.",
//       "Solution_Title": "Solution_Title",
//       "Question": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately."
//     }
//   ]
// }

json := CkJsonObject_Create();
CkJsonObject_UpdateString(json,'data[0].Owner.id','{{user-id}}');
CkJsonObject_UpdateString(json,'data[0].Product_Name.id','{{product-id}}');
CkJsonObject_UpdateString(json,'data[0].Status','Duplicate');
CkJsonObject_UpdateString(json,'data[0].Answer','Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.');
CkJsonObject_UpdateString(json,'data[0].Solution_Title','Solution_Title');
CkJsonObject_UpdateString(json,'data[0].Question','Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.');

CkHttp_SetRequestHeader(http,'Authorization','{{authorization-token}}');
CkHttp_SetRequestHeader(http,'Content-Type','application/json');

sbRequestBody := CkStringBuilder_Create();
CkJsonObject_EmitSb(json,sbRequestBody);

resp := CkHttp_PTextSb(http,'PUT','https://domain.com/crm/v2.1/Solutions/{{record-id}}',sbRequestBody,'utf-8','application/json',False,False);
if (CkHttp_getLastMethodSuccess(http) = False) then
  begin
    Memo1.Lines.Add(CkHttp__lastErrorText(http));
    Exit;
  end;

Memo1.Lines.Add(IntToStr(CkHttpResponse_getStatusCode(resp)));
Memo1.Lines.Add(CkHttpResponse__bodyStr(resp));
CkHttpResponse_Dispose(resp);

CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
CkStringBuilder_Dispose(sbRequestBody);

Curl Command

curl -X PUT
	-H "Authorization: Bearer <access_token>"
	-H "Authorization: {{authorization-token}}"
	-H "Content-Type: application/json"
	-d '{
	"data": [
		{
			"Owner": {
				"id": "{{user-id}}"
			},
			"Product_Name": {
				"id": "{{product-id}}"
			},
			"Status": "Duplicate",
			"Answer": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.",
			"Solution_Title": "Solution_Title",
			"Question": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately."
		}
	]
}'
https://domain.com/crm/v2.1/Solutions/{{record-id}}

Postman Collection Item JSON

{
  "name": "Solutions",
  "request": {
    "method": "PUT",
    "header": [
      {
        "key": "Authorization",
        "value": "{{authorization-token}}"
      },
      {
        "key": "Content-Type",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n\t\"data\": [\n\t\t{\n\t\t\t\"Owner\": {\n\t\t\t\t\"id\": \"{{user-id}}\"\n\t\t\t},\n\t\t\t\"Product_Name\": {\n\t\t\t\t\"id\": \"{{product-id}}\"\n\t\t\t},\n\t\t\t\"Status\": \"Duplicate\",\n\t\t\t\"Answer\": \"Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.\",\n\t\t\t\"Solution_Title\": \"Solution_Title\",\n\t\t\t\"Question\": \"Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.\"\n\t\t}\n\t]\n}"
    },
    "url": {
      "raw": "{{api-domain}}/crm/v2.1/Solutions/{{record-id}}",
      "host": [
        "{{api-domain}}"
      ],
      "path": [
        "crm",
        "v2.1",
        "Solutions",
        "{{record-id}}"
      ]
    },
    "description": "To update existing entities in the module."
  },
  "response": [
  ]
}