Получить путь до объекта

Получить путь иерархии от заданного объекта до корневого объекта.

Запрос

HTTP Запрос

GET /node/api/objects/:id/paths

Права

objectPermissions

Параметры пути

Параметр Тип Описание

id

String

ID объекта.

Параметры запроса

Параметр Тип Описание

fields

String

Список полей, которые нужно вернуть в теле ответа. Перечисляются через запятую.

Тело запроса

Тело запроса пустое.

Ответ

Ответ содержит два списка – пути (paths) и объекты (objects).

  • paths содержит ID каждого родительского объекта (включая корневой объект и сам запрошенный объект). Первый элемент это заданный объект, последний – корневой объект.

  • objects содержит информацию о каждом объекте в пути. Поля, возвращаемые в каждой записи можно настроить в настройках параметра fields. Все возможные поля можно посмотреть в статье Объект.

Если у объекта есть несколько путей до корневого объекта (например, в пути есть объект с несколькими родителями), поле path будет содержать список всех путей. Значения в массиве objects не будут дублированы.

По умолчанию, каждая запись в поле objects включает следующие поля:

Поле Тип Описание

id

String

ID объекта.

name

String

Имя объекта.

class_id

String

ID класса объекта.

child_ids

Array<String>

Массив ID дочерних объектов.

child_link_ids

Array<String>

Массив ID дочерних связей.

child_ref_ids

Array<String>

Массив ID дочерних ссылок.

parent_id

Array<String>

ID родительских объектов.

geoposition

Array<Float>

Позиция объекта на карте. Определяется как массив из двух элементов. Первый – широта, второй – долгота.

geopositionRadius

Integer

Радиус геопозиции объекта на карте.

state_id

String

ID состояния объекта.

last_state_update

Integer

Время последнего обновления состояния объекта.

Примеры

Запрос

  • Bash

  • JavaScript

  • NodeJS

  • Python

login=<...>
password=<...>
saymon_hostname=<...>
object_id=<...>
url=https://$saymon_hostname/node/api/objects/$object_id/paths?fields=id,name

curl -X GET $url -u $login:$password
let login = <...>
let password = <...>
let saymonHostname = <...>
let objectId = <...>
let path = "/node/api/objects/" + objectId + "/paths?fields=id,name";
let auth = "Basic " + btoa(login + ":" + password);

let headers = new Headers();
headers.append("Authorization", auth);

let requestOptions = {
    method: "GET",
    headers: headers
};

fetch(saymonHostname + path, requestOptions)
    .then(response => response.text())
    .then(result => console.log(result))
    .catch(error => console.log("error", error));
const http = require("http");

let login = <...>
let password = <...>
let saymonHostname = <...>
let objectId = <...>
let path = "/node/api/objects/" + objectId + "/paths?fields=id,name";
let auth = "Basic " + Buffer.from(login + ":" + password).toString("base64");

let options = {
    "method": "GET",
    "hostname": saymonHostname,
    "headers": {
        "Authorization": auth
    },
    "path": path
};

let req = http.request(options, function (res) {
    let chunks = [];

    res.on("data", function (chunk) {
        chunks.push(chunk);
    });

    res.on("end", function (chunk) {
        let body = Buffer.concat(chunks);
        console.log(body.toString());
    });

    res.on("error", function (error) {
        console.error(error);
    });
});

req.end();
import requests

login = <...>
password = <...>
saymon_hostname = <...>
object_id = <...>
url = "https://" + saymon_hostname + "/node/api/objects/" + object_id + "/paths?fields=id,name"

response = requests.request("GET", url, auth=(login, password))
print(response.text)

Ответ

{
  "paths": [
    [
      "59367b82ffb40f0b89504a96",
      "59318c33ce35c42e1c8b4efa",
      "5926c944beefaf6c11526a11",
      "5641e41511039b1637d31c9b",
      1
    ],
    [
      "59367b82ffb40f0b89504a96",
      "59318c33ce35c42e1c8b4efa",
      "5926c944beefaf6c11526a11",
      "5821c8ddd0240f4f5a7dba04",
      "5800d9aaac7bf0f90d3d520e",
      1
    ],
    [
      "59367b82ffb40f0b89504a96",
      "59318c33ce35c42e1c8b4efa",
      "5926c944beefaf6c11526a11",
      1
    ]
  ],
  "objects": [
    {
      "name": "Staging",
      "id": 1
    },
    {
      "name": "Test Host",
      "id": "5641e41511039b1637d31c9b"
    },
    {
      "name": "BlackBox",
      "id": "5800d9aaac7bf0f90d3d520e"
    },
    {
      "name": "Data",
      "id": "5821c8ddd0240f4f5a7dba04"
    },
    {
      "name": "Demo and Test",
      "id": "5926c944beefaf6c11526a11"
    },
    {
      "name": "CDR Data",
      "id": "59318c33ce35c42e1c8b4efa"
    },
    {
      "name": "sum",
      "id": "59367b82ffb40f0b89504a96"
    }
  ]
}