Получить историю состояний
Возвращает все записи истории состояний для объектов и связей. Этот запрос возвращает только те записи, которые относятся к объектам, к которым у пользователя есть доступ.
Запрос
Параметры запроса
Параметр | Тип | Описание | ||
---|---|---|---|---|
from |
Integer |
От какой даты искать записи. Unix-время в миллисекундах. |
||
to |
Integer |
До какой даты искать записи. Unix-время в миллисекундах. |
||
limit |
String |
Максимальное количество возвращаемых записей. Отсчёт начинается с |
||
skip |
String |
Сколько записей с начала списка нужно пропустить. Значение по умолчанию |
||
inverse |
Boolean |
|
||
downsample |
Boolean |
|
||
stateId |
String | Array<String> |
ID состояния, по которому фильтровать историю состояний. |
||
classId |
String | Array<String> |
ID состояния или массив ID состояний, по которому фильтровать историю состояний. Запрос вернёт только те записи, которые относятся к объектам этого класса. |
||
tagId |
String | Array<String> |
ID тега или массив ID тегов, по которому фильтровать историю состояний. Запрос вернёт только те записи, которые относятся к объектам с указанными тегами. |
||
entityId |
String | Array<String> |
ID сущности или массив ID сущностей, по которому фильтровать историю состояний. Запрос вернёт только те записи, которые относятся к объектам с указанными ID. |
||
entityType |
Integer |
Фильтр по типу сущности. |
||
entityName |
String |
Фильтр истории по имени сущности.
|
Ответ
Возвращает массив записей, которые подходят по критериям, указанным в параметрах. Подробная информация о модели доступна в статье История состояний.
Пример
Запрос
-
Bash
-
JavaScript
-
NodeJS
-
Python
login=<...>
password=<...>
saymon_hostname=<...>
url=https://$saymon_hostname/node/api/state-history-log
curl -X GET $url -u $login:$password
let login = <...>
let password = <...>
let saymonHostname = <...>
let path = "/node/api/state-history-log";
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 path = "/node/api/state-history-log";
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 = <...>
url = "https://" + saymon_hostname + "/node/api/state-history-log"
response = requests.request("GET", url, auth=(login, password))
print(response.text)
Ответ
[
{
"entityId": 1,
"entityType": 1,
"stateId": 1,
"timestamp": 1579267920651,
"entityName": "ROOT",
"entityClass": 1,
"skip": 0,
"id": "5e21b750308c3c66d64e071a"
},
{
"entityId": "5e21b85b308c3c66d64e07c8",
"entityType": 1,
"stateId": 1,
"timestamp": 1579268187090,
"entityName": "SAYMON Agent",
"entityClass": 2,
"skip": 2,
"id": "5e21b85b308c3c66d64e07cd"
},
...
]