Chilkat Online Tools

VB.NET / Zoho CRM REST APIs / Products

Back to Collection Items

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

Dim http As New Chilkat.Http
Dim success As Boolean

' 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}}"
'       },
'       "Handler": {
'         "id": "{{user-id}}"
'       },
'       "Vendor_Name": {
'         "id": "{{vendor-id}}"
'       },
'       "Product_Category": "Software",
'       "Qty_in_Demand": 1237.89,
'       "Description": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.",
'       "Commission_Rate": 1237.67,
'       "Product_Name": "Product_Name",
'       "Quantity_In_Stock": 12792,
'       "Sales_Start_Date": "2018-01-25",
'       "Tax": [
'         "Sales Tax"
'       ],
'       "Support_Start_Date": "2018-01-25",
'       "Product_Active": true,
'       "Usage_Unit": "Caton",
'       "Product_Code": "Product_Code",
'       "Qty_Ordered": 1237.89,
'       "Manufacturer": "LexPon Inc.",
'       "Qty_in_Stock": 1237.89,
'       "Support_Expiry_Date": "2018-01-25",
'       "Sales_End_Date": "2018-01-25",
'       "Unit_Price": 1237.67,
'       "Taxable": true,
'       "Reorder_Level": 1237.89
'     }
'   ]
' }

Dim json As New Chilkat.JsonObject
json.UpdateString("data[0].Owner.id","{{user-id}}")
json.UpdateString("data[0].Handler.id","{{user-id}}")
json.UpdateString("data[0].Vendor_Name.id","{{vendor-id}}")
json.UpdateString("data[0].Product_Category","Software")
json.UpdateNumber("data[0].Qty_in_Demand","1237.89")
json.UpdateString("data[0].Description","Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.")
json.UpdateNumber("data[0].Commission_Rate","1237.67")
json.UpdateString("data[0].Product_Name","Product_Name")
json.UpdateInt("data[0].Quantity_In_Stock",12792)
json.UpdateString("data[0].Sales_Start_Date","2018-01-25")
json.UpdateString("data[0].Tax[0]","Sales Tax")
json.UpdateString("data[0].Support_Start_Date","2018-01-25")
json.UpdateBool("data[0].Product_Active",True)
json.UpdateString("data[0].Usage_Unit","Caton")
json.UpdateString("data[0].Product_Code","Product_Code")
json.UpdateNumber("data[0].Qty_Ordered","1237.89")
json.UpdateString("data[0].Manufacturer","LexPon Inc.")
json.UpdateNumber("data[0].Qty_in_Stock","1237.89")
json.UpdateString("data[0].Support_Expiry_Date","2018-01-25")
json.UpdateString("data[0].Sales_End_Date","2018-01-25")
json.UpdateNumber("data[0].Unit_Price","1237.67")
json.UpdateBool("data[0].Taxable",True)
json.UpdateNumber("data[0].Reorder_Level","1237.89")

http.SetRequestHeader("Authorization","{{authorization-token}}")
http.SetRequestHeader("Content-Type","application/json")

Dim sbRequestBody As New Chilkat.StringBuilder
json.EmitSb(sbRequestBody)

Dim resp As Chilkat.HttpResponse = http.PTextSb("PUT","https://domain.com/crm/v2.1/Products/{{record-id}}",sbRequestBody,"utf-8","application/json",False,False)
If (http.LastMethodSuccess = False) Then
    Debug.WriteLine(http.LastErrorText)
    Exit Sub
End If


Debug.WriteLine(resp.StatusCode)
Debug.WriteLine(resp.BodyStr)

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}}"
      },
      "Handler": {
        "id": "{{user-id}}"
      },
      "Vendor_Name": {
        "id": "{{vendor-id}}"
      },
      "Product_Category": "Software",
      "Qty_in_Demand": 1237.89,
      "Description": "Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.",
      "Commission_Rate": 1237.67,
      "Product_Name": "Product_Name",
      "Quantity_In_Stock": 12792,
      "Sales_Start_Date": "2018-01-25",
      "Tax": [
        "Sales Tax"
      ],
      "Support_Start_Date": "2018-01-25",
      "Product_Active": true,
      "Usage_Unit": "Caton",
      "Product_Code": "Product_Code",
      "Qty_Ordered": 1237.89,
      "Manufacturer": "LexPon Inc.",
      "Qty_in_Stock": 1237.89,
      "Support_Expiry_Date": "2018-01-25",
      "Sales_End_Date": "2018-01-25",
      "Unit_Price": 1237.67,
      "Taxable": true,
      "Reorder_Level": 1237.89
    }
  ]
}'
https://domain.com/crm/v2.1/Products/{{record-id}}

Postman Collection Item JSON

{
  "name": "Products",
  "request": {
    "method": "PUT",
    "header": [
      {
        "key": "Authorization",
        "value": "{{authorization-token}}"
      },
      {
        "key": "Content-Type",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n  \"data\": [\n    {\n      \"Owner\": {\n        \"id\": \"{{user-id}}\"\n      },\n      \"Handler\": {\n        \"id\": \"{{user-id}}\"\n      },\n      \"Vendor_Name\": {\n        \"id\": \"{{vendor-id}}\"\n      },\n      \"Product_Category\": \"Software\",\n      \"Qty_in_Demand\": 1237.89,\n      \"Description\": \"Design your own layouts that align your business processes precisely. Assign them to profiles appropriately.\",\n      \"Commission_Rate\": 1237.67,\n      \"Product_Name\": \"Product_Name\",\n      \"Quantity_In_Stock\": 12792,\n      \"Sales_Start_Date\": \"2018-01-25\",\n      \"Tax\": [\n        \"Sales Tax\"\n      ],\n      \"Support_Start_Date\": \"2018-01-25\",\n      \"Product_Active\": true,\n      \"Usage_Unit\": \"Caton\",\n      \"Product_Code\": \"Product_Code\",\n      \"Qty_Ordered\": 1237.89,\n      \"Manufacturer\": \"LexPon Inc.\",\n      \"Qty_in_Stock\": 1237.89,\n      \"Support_Expiry_Date\": \"2018-01-25\",\n      \"Sales_End_Date\": \"2018-01-25\",\n      \"Unit_Price\": 1237.67,\n      \"Taxable\": true,\n      \"Reorder_Level\": 1237.89\n    }\n  ]\n}"
    },
    "url": {
      "raw": "{{api-domain}}/crm/v2.1/Products/{{record-id}}",
      "host": [
        "{{api-domain}}"
      ],
      "path": [
        "crm",
        "v2.1",
        "Products",
        "{{record-id}}"
      ]
    },
    "description": "To update existing entities in the module."
  },
  "response": [
  ]
}