Chilkat Online Tools

VBScript / Cognite API v1 / Aggregate assets

Back to Collection Items

Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
Set outFile = fso.CreateTextFile("output.txt", True)

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

set http = CreateObject("Chilkat_9_5_0.Http")

' Use this online tool to generate code from sample JSON: Generate Code to Create JSON

' The following JSON is sent in the request body.

' {
'   "filter": {
'     "name": "tempor in",
'     "parentIds": [
'       2218036985580300,
'       1325609532768832
'     ],
'     "parentExternalIds": [
'       "proident magna occaecat id",
'       "elit sint in"
'     ],
'     "rootIds": [
'       {
'         "id": 2434556236080026
'       },
'       {
'         "id": 3030224117188012
'       }
'     ],
'     "assetSubtreeIds": [
'       {
'         "id": 5500566008705236
'       },
'       {
'         "externalId": "magna pariatur ullamco aute"
'       }
'     ],
'     "dataSetIds": [
'       {
'         "externalId": "magna mollit eiusmod"
'       },
'       {
'         "externalId": "nulla tempor consectetur occaecat sit"
'       }
'     ],
'     "metadata": {},
'     "source": "quis",
'     "createdTime": {
'       "max": 51644802,
'       "min": 78848688
'     },
'     "lastUpdatedTime": {
'       "max": 42756152,
'       "min": 67449504
'     },
'     "root": false,
'     "externalIdPrefix": "aute officia sint nisi",
'     "labels": {
'       "containsAny": [
'         {
'           "externalId": "quis"
'         },
'         {
'           "externalId": "ex tempor"
'         }
'       ]
'     }
'   }
' }

set json = CreateObject("Chilkat_9_5_0.JsonObject")
success = json.UpdateString("filter.name","tempor in")
success = json.UpdateInt("filter.parentIds[0]",2218036985580300)
success = json.UpdateInt("filter.parentIds[1]",1325609532768832)
success = json.UpdateString("filter.parentExternalIds[0]","proident magna occaecat id")
success = json.UpdateString("filter.parentExternalIds[1]","elit sint in")
success = json.UpdateInt("filter.rootIds[0].id",123)
success = json.UpdateInt("filter.rootIds[1].id",123)
success = json.UpdateInt("filter.assetSubtreeIds[0].id",123)
success = json.UpdateString("filter.assetSubtreeIds[1].externalId","magna pariatur ullamco aute")
success = json.UpdateString("filter.dataSetIds[0].externalId","magna mollit eiusmod")
success = json.UpdateString("filter.dataSetIds[1].externalId","nulla tempor consectetur occaecat sit")
success = json.UpdateNewObject("filter.metadata")
success = json.UpdateString("filter.source","quis")
success = json.UpdateInt("filter.createdTime.max",51644802)
success = json.UpdateInt("filter.createdTime.min",78848688)
success = json.UpdateInt("filter.lastUpdatedTime.max",42756152)
success = json.UpdateInt("filter.lastUpdatedTime.min",67449504)
success = json.UpdateBool("filter.root",0)
success = json.UpdateString("filter.externalIdPrefix","aute officia sint nisi")
success = json.UpdateString("filter.labels.containsAny[0].externalId","quis")
success = json.UpdateString("filter.labels.containsAny[1].externalId","ex tempor")

http.SetRequestHeader "content-type","application/json"
http.SetRequestHeader "api-key","{{api-key}}"

' resp is a Chilkat_9_5_0.HttpResponse
Set resp = http.PostJson3("https://domain.com/api/v1/projects/{{project}}/assets/aggregate","application/json",json)
If (http.LastMethodSuccess = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

outFile.WriteLine(resp.StatusCode)
outFile.WriteLine(resp.BodyStr)


outFile.Close

Curl Command

curl -X POST
	-H "api-key: {{api-key}}"
	-H "content-type: application/json"
	-d '{
    "filter": {
        "name": "tempor in",
        "parentIds": [
            2218036985580300,
            1325609532768832
        ],
        "parentExternalIds": [
            "proident magna occaecat id",
            "elit sint in"
        ],
        "rootIds": [
            {
                "id": 2434556236080026
            },
            {
                "id": 3030224117188012
            }
        ],
        "assetSubtreeIds": [
            {
                "id": 5500566008705236
            },
            {
                "externalId": "magna pariatur ullamco aute"
            }
        ],
        "dataSetIds": [
            {
                "externalId": "magna mollit eiusmod"
            },
            {
                "externalId": "nulla tempor consectetur occaecat sit"
            }
        ],
        "metadata": {},
        "source": "quis",
        "createdTime": {
            "max": 51644802,
            "min": 78848688
        },
        "lastUpdatedTime": {
            "max": 42756152,
            "min": 67449504
        },
        "root": false,
        "externalIdPrefix": "aute officia sint nisi",
        "labels": {
            "containsAny": [
                {
                    "externalId": "quis"
                },
                {
                    "externalId": "ex tempor"
                }
            ]
        }
    }
}'
https://domain.com/api/v1/projects/{{project}}/assets/aggregate

Postman Collection Item JSON

{
  "id": "aggregateAssets",
  "name": "Aggregate assets",
  "request": {
    "url": {
      "host": "{{baseUrl}}",
      "path": [
        "api",
        "v1",
        "projects",
        "{{project}}",
        "assets",
        "aggregate"
      ],
      "query": [
      ],
      "variable": [
      ]
    },
    "method": "POST",
    "header": [
      {
        "key": "api-key",
        "value": "{{api-key}}",
        "description": "An admin can create API keys in the Cognite console."
      },
      {
        "key": "content-type",
        "value": "application/json"
      }
    ],
    "description": "Use advanced filtering options to agggregate assets.",
    "body": {
      "mode": "raw",
      "raw": "{\n    \"filter\": {\n        \"name\": \"tempor in\",\n        \"parentIds\": [\n            2218036985580300,\n            1325609532768832\n        ],\n        \"parentExternalIds\": [\n            \"proident magna occaecat id\",\n            \"elit sint in\"\n        ],\n        \"rootIds\": [\n            {\n                \"id\": 2434556236080026\n            },\n            {\n                \"id\": 3030224117188012\n            }\n        ],\n        \"assetSubtreeIds\": [\n            {\n                \"id\": 5500566008705236\n            },\n            {\n                \"externalId\": \"magna pariatur ullamco aute\"\n            }\n        ],\n        \"dataSetIds\": [\n            {\n                \"externalId\": \"magna mollit eiusmod\"\n            },\n            {\n                \"externalId\": \"nulla tempor consectetur occaecat sit\"\n            }\n        ],\n        \"metadata\": {},\n        \"source\": \"quis\",\n        \"createdTime\": {\n            \"max\": 51644802,\n            \"min\": 78848688\n        },\n        \"lastUpdatedTime\": {\n            \"max\": 42756152,\n            \"min\": 67449504\n        },\n        \"root\": false,\n        \"externalIdPrefix\": \"aute officia sint nisi\",\n        \"labels\": {\n            \"containsAny\": [\n                {\n                    \"externalId\": \"quis\"\n                },\n                {\n                    \"externalId\": \"ex tempor\"\n                }\n            ]\n        }\n    }\n}"
    }
  }
}