Сценарии - новая версия API
-
Не все из блоков в сценарий попадает.
Сделал простой сценарий для изменения сдвига температуры отключения радиаторов в зависимости от температуры на улице (если на улице ниже -10, радиаторы греют до достижения нужной Т в комнате, т.е. сдвиг 0, если от -10 до +10, до сдвиг 2, т.е. радиаторы выключаются на 2 градуса раньше, остальное теплый пол догревает, если Т выше +10, сдвиг 5, т.е. в последних двух случаях радиаторы подключатся при переключении режимов, когда комнату нагреть нужно до комфортной Т, или при агрессивном проветривании :lol: ).
Сценарий должен срабатывать по изменению показаний датчика температуры улицы,
и в зависимости от температурного диапазона присваивать смещениям одно из 3-х фиксированных значений.
Перед присвоением проверяю текущее значение, присвоение должно происходить если текущее не равно нужному (не равно это "!=" ???).
Все хорошо, но проверка текущего значения смещения в скрипт не попадает.
Скрипт по этой схеме прописывается такой
/** * @name SdvigRO * @desc * @version 4 */ const ACTORA1 = Device("ACTORA1"); const ACTORA76 = Device("ACTORA76"); const ACTORA77 = Device("ACTORA77"); startOnChange([ACTORA1]); script({ start() { if (10 <= ACTORA1.value) { } this.sub1(); this.sub2(); if ((ACTORA1.value > -10) && (ACTORA1.value < 10)) { } this.sub3(); this.sub4(); if (-10 >= ACTORA1.value) { } this.sub5(); this.sub6(); }, sub1() { if (10 <= ACTORA1.value) { ACTORA76.setParam("value",5); } }, sub2() { if (10 <= ACTORA1.value) { ACTORA77.setParam("value",5); } }, sub3() { if ((ACTORA1.value > -10) && (ACTORA1.value < 10)) { ACTORA76.setParam("value",2); } }, sub4() { if ((ACTORA1.value > -10) && (ACTORA1.value < 10)) { ACTORA77.setParam("value",2); } }, sub5() { if (-10 >= ACTORA1.value) { ACTORA76.setParam("value",0); } }, sub6() { if (-10 >= ACTORA1.value) { ACTORA77.setParam("value",0); } } })
-
И расписание утром не сработало.
Вечером скрипты запустились.
Утром - или не запустились, или не отобразилось, что были запущены.
Скрипты одинаковые, в вечернем значение увеличивается на 1, в утреннем уменьшается на 1.
/** * @name Уменьшить.Т.Днем * @desc * @version 4 */ const ActRz = Device("ActorA", "Режим отопления"); const ActComf = Device("ActorA", "Уставка Комфорт"); script({ start() { if (ActRz.value === 0) { let newvalue = ActComf.value-1; ActComf.setValue(newvalue); return; } } });
-
И расписание утром не сработало.
Вечером скрипты запустились.
Утром - или не запустились, или не отобразилось, что были запущены.
Скрипты одинаковые, в вечернем значение увеличивается на 1, в утреннем уменьшается на 1.
> /** > * @name Уменьшить.Т.Днем > * @desc > * @version 4 > */ > > const ActRz = Device("ActorA", "Режим отопления"); > const ActComf = Device("ActorA", "Уставка Комфорт"); > > script({ > start() { > if (ActRz.value === 0) { > let newvalue = ActComf.value-1; > ActComf.setValue(newvalue); > return; > } > } > }); >
В 12 часов посмотрел, скрипты значатся выполненными в 8:00. Они выполнились позже, или выполнились вовремя, а информация о выполнении отобразилась позже?
-
Все хорошо, но проверка текущего значения смещения в скрипт не попадает.
Проверим, спасибо за баг-репорт
-
И расписание утром не сработало.
…
В 12 часов посмотрел, скрипты значатся выполненными в 8:00. Они выполнились позже, или выполнились вовремя, а информация о выполнении отобразилась позже?
Если бы выполнились позже, то и время выполнения было бы позже. Время фиксируется в момент запуска сценария
Экраны в PM динамически не обновляются. Может причина в том, что вкладка была открыта до 8:00 ?
-
И расписание утром не сработало.
…
В 12 часов посмотрел, скрипты значатся выполненными в 8:00. Они выполнились позже, или выполнились вовремя, а информация о выполнении отобразилась позже?
Если бы выполнились позже, то и время выполнения было бы позже. Время фиксируется в момент запуска сценария
Экраны в PM динамически не обновляются. Может причина в том, что вкладка была открыта до 8:00 ?
Там есть кнопка "обновить", я ее нажимал.
Может опять шутки с временным поясом.
Добавил в скрипты уведомление на почту.
Посмотрю, во сколько будут отправлены письма.
-
Все хорошо, но проверка текущего значения смещения в скрипт не попадает.
Проверим, спасибо за баг-репорт
Поменял блок схему на такую
Все в скрипте прописалось
/** * @name SdvigRO * @desc * @version 4 */ const ACTORA1 = Device("ACTORA1"); const ACTORA76 = Device("ACTORA76"); const ACTORA77 = Device("ACTORA77"); startOnChange([ACTORA1]); script({ start() { if (10 <= ACTORA1.value) { } this.sub1(); this.sub2(); if ((ACTORA1.value > -10) && (ACTORA1.value < 10)) { } this.sub3(); this.sub4(); if (-10 >= ACTORA1.value) { } this.sub5(); this.sub6(); }, sub1() { if (10 <= ACTORA1.value || 5) { ACTORA76.setParam("value",5); } }, sub2() { if (10 <= ACTORA1.value || 5) { ACTORA77.setParam("value",5); } }, sub3() { if ((ACTORA1.value > -10) && (ACTORA1.value < 10) || 2) { ACTORA76.setParam("value",2); } }, sub4() { if ((ACTORA1.value > -10) && (ACTORA1.value < 10) || 2) { ACTORA77.setParam("value",2); } }, sub5() { if (-10 >= ACTORA1.value || 0) { ACTORA76.setParam("value",0); } }, sub6() { if (-10 >= ACTORA1.value || 0) { ACTORA77.setParam("value",0); } } })
-
Все хорошо, но проверка текущего значения смещения в скрипт не попадает.
Проверим, спасибо за баг-репорт
Попробовал заменить функцию "И" на "Если А=В" (она сравнивает результат двух других "если").
Просто ошибка в скрипте в результате.
-
Может опять шутки с временным поясом.
Добавил в скрипты уведомление на почту.
Посмотрю, во сколько будут отправлены письма.
Письмо отправляется в 11-00.
Это установка часового пояса на сервере.
Виджет "часы" с сервера время берет, или с компьютера, на котором отображается?
-
Может опять шутки с временным поясом.
Добавил в скрипты уведомление на почту.
Посмотрю, во сколько будут отправлены письма.
Письмо отправляется в 11-00.
Это установка часового пояса на сервере.
Виджет "часы" с сервера время берет, или с компьютера, на котором отображается?
Виджет "часы" время берет с компьютера
-
Может опять шутки с временным поясом.
Добавил в скрипты уведомление на почту.
Посмотрю, во сколько будут отправлены письма.
Письмо отправляется в 11-00.
Это установка часового пояса на сервере.
Виджет "часы" с сервера время берет, или с компьютера, на котором отображается?
Я в тупике.
Часовой пояс на сервере сменил - все равно скрипт выполнятся по UTC, а не по Москве.
РАсписание запуска пересоздал. Результат тот же - запускаются по UTC.
могу, конечно, просто сместить настройку на 3 часа.
-
могу, конечно, просто сместить настройку на 3 часа.
Это конечно не вариант
Перезапустите сервер IntraHouse. Часовой пояс берется движком Node при старте.
Чтобы убедиться, что время правильное, можно посмотреть текущее время в любом из журналов, в отладчике любого сценария, плагина…
-
После перезагрузки в отладчике плагина время стало московским.
Спасибо.
-
Чтобы в новом мобильном клиенте корректно отображалась температура создал датчики температуры по комнатам, которые не привязаны к реальным устройствам.
И пытаюсь скриптом назначить им значение актуатора, который привязан к реальному датчику температуры через модбас.
Скрипт такой
const ActorT = Device("ActorA"); const StempT = Device("StempA"); startOnChange(ActorT); script({ start() { let newvalue = ActorT.value; StempT.setValue(newvalue); return; } });
Выбирать устройства не дает, пишет ошибку "Real devices OR param devices?"
Что оно от меня хочет?
-
Чтобы в новом мобильном клиенте корректно отображалась температура создал датчики температуры по комнатам, которые не привязаны к реальным устройствам.
И пытаюсь скриптом назначить им значение актуатора, который привязан к реальному датчику температуры через модбас.
Скрипт такой
> const ActorT = Device("ActorA"); > const StempT = Device("StempA"); > > startOnChange(ActorT); > > script({ > start() { > let newvalue = ActorT.value; > StempT.setValue(newvalue); > return; > } > }); >
Выбирать устройства не дает, пишет ошибку "Real devices OR param devices?"
Что оно от меня хочет?
В объявлении устройств нужно указывать либо класс устройств (ActorA, SensorA) для мультисценария, либо "Real device" - тогда это будет обычный сценарий.
const ActorT = Device("ActorA"); - указан класс const StempT = Device("StempA");- такого класса нет
-
Если я поставлю SensorA, мультисценарий не видит датчики температуры.
Если я вместо датчика температуры сделаю какой нибудь сенсор, новый мобильный клиент не воспримет его как датчик температуры комнаты.
ПРостым сценарием можно присвоить значение датчику температуры?
Попробовал, пишет "missing devices Stemp2"
Переписал на STEMP2, ошибка пропала.
Но значение не присваивает.
12.08 15:34:43.136 Started 12.08 15:34:43.137 do STEMP2 set 20.5 12.08 15:34:43.138 Not found act or prop set 12.08 15:34:43.139 Stopped
-
В свойствах устройства - датчика температуры можно выставить, что значение "назначается скриптом".
Как скриптом назначить значение датчику температуры?
-
Если я поставлю SensorA, мультисценарий не видит датчики температуры.
Если я вместо датчика температуры сделаю какой нибудь сенсор, новый мобильный клиент не воспримет его как датчик температуры комнаты.
ПРостым сценарием можно присвоить значение датчику температуры?
Попробовал, пишет "missing devices Stemp2"
Переписал на STEMP2, ошибка пропала.
Но значение не присваивает.
> 12.08 15:34:43.136 Started > 12.08 15:34:43.137 do STEMP2 set 20.5 > 12.08 15:34:43.138 Not found act or prop set > 12.08 15:34:43.139 Stopped >
Датчики нельзя переключать с помощью set, это не актуатор
Чтобы установить значение датчику, используйте команду сценария this.assign:
this.assign(Temp, "value", newvalue );
Для мультисценария описание должно быть таким:
const ActorT = Device("ActorA"); // Источник данных - датчик температура как актуатор const StempT = Device("SensorA"); // Любой аналоговый датчик
Если хотите простой сценарий - просто пропишите имена реальных устройств.
Регистр в именах устройств имеет значение
const ActorT = Device("STEMP2"); const StempT = Device("STEMP2x");
Мультисценарий полностью (не оставляйте комментарии в декларативной части!)
const ActorT = Device("ActorA"); const StempT = Device("SensorA"); startOnChange(ActorT); script({ start() { this.assign(StempT, "value", ActorT.value ); } });
-
Спасибо.
-
2. Доступности из сценариев "журнал устройств" (для принудительного запуска насосов/котлов/кранов/клапанов если их период простоя велик)
Эта возможность уже добавлена в последней версии 4.5.3 как функция устройства device.getLog(<count>)
Опциональный параметр count - количество записей.
Возвращаются последние записи по возрастанию времени в виде массива с полями: значение, флаг ошибки, метка времени
> {val:"23.5", err:0, ts:1554076800000} >
Получить последние 10 записей:
> const logArr = dn.getLog(10); > logArr.forEach(item => { > this.log(JSON.stringify(item)); > }); > > ````</count> Довольно не тривиально получается извлекать время последнего выключения устройства поскольку массив данных получается такой:
21.08 15:06:08.026 log: {"val":1,"ts":1566328458717}
21.08 15:06:08.062 log: {"act":"off","ts":1566342000920,"scene":"110"}
21.08 15:06:08.066 log: {"val":0,"ts":1566342001056}
21.08 15:06:08.069 log: {"act":"on","ts":1566369165938,"scene":"mTimeOut_TurnOn_byTime"}
21.08 15:06:08.073 log: {"val":1,"ts":1566369166059}
21.08 15:06:08.077 log: {"act":"prop:auto","act_val":0,"ts":1566369166060}
21.08 15:06:08.081 log: {"act":"toggle","ts":1566369530254,"login":"admin"}
21.08 15:06:08.084 log: {"val":0,"ts":1566369530362}
21.08 15:06:08.088 log: {"act":"prop:auto","act_val":0,"ts":1566369530362}
21.08 15:06:08.092 log: {"act":"prop: auto ","act_val":1,"ts":1566373131164}Я так понял, что нужное мне время (последнего выключения актюатора) содержится в том массиве, в котором val = 0 (вероятно это именно состояние канала контроллера). Однако в случае если журнал устройства чист и мы его обновляем, например, командой dev.off(), то в журнале появляется лишь {"act":"off","ts":1566342000920,"scene":"ХХХ"} - вероятно это состояние устройства на мнемосхеме. Поэтому в итоге анализ журнала и вычисление времени последнего выключения устройства получился довольно сложным:
let lasttime = 0; //Время последнего отключения устройства в мс let logArr = dev.getLog(10); //Чтение последних 10 записей из журнала актюатора в массив let allts = []; //Пустой массив для сбора времени выключения актюатора из его журнала //Перебор массива из записей журнала актюатора с поиском времени его отключения logArr.forEach(item => { let durArr = JSON.stringify(item); let obj = JSON.parse(durArr); //this.log(durArr); //Для отладки //Если актюатор был отключен, то заносим время его отключения в массив if(obj.val === 0 || obj.act == "off") { allts.push(obj.ts); } }); //Берем из массива времени самое последнее значение lasttime = allts[allts.length - 1]; //Если время не определено (журнал устройства чист), то обновляем журнал устройства if(lasttime === undefined && dev.isOff()) dev.off();
Ок, с этим разобрался. Другой вопрос - где найти нижеследующее? Точнее как это сделать? Или возможность пока не реализована? @intrapro: > @Alex_Jet: > > > 1\. Реализации "cron" для сценариев (запуск сценариев для проверки состояния устройств) > Будет в конце месяца для простых и мультисценариев (пока без блок-схем) Также интересует еще следующее: @intrapro: > @Alex_Jet: > > > 4\. Доступности из сценариев пользовательских журналов (создавать журналы можно, но писать в них логи пока никак) > > Концепция журналов будет пересматриваться, пока по срокам не ясно Хотел бы для каждой навороченной подсистемы (отопление, вентиляция) иметь свой журнал чтобы дебажить и анализировать правильность работы.