NEWS
Вопросы по написанию скриптов
-
Благодарствуем!
-
Все бы ничего, только версии 3.3.6 в обновлении нет….
Adapter "knx" : 0.8.3 Adapter "km200" : 0.4.3 Controller "js-controller" : 1.0.0 , installed 1.0.0 Adapter "javascript" : 3.2.6 , installed 3.2.6 Adapter "innogy-smarthome": 0.1.17 Adapter "influxdb" : 1.4.3 -
Усе, разрулил….
-
Всем привет. нужен некий ХЕЛП. Суть задачи - получить счетчик моторесурса некого устройства.
как я это вижу: Сработал насос и начался отсчет времени, насос выключился, счет остановился.
показания по идее должны суммироваться…..
Для начала нарыл вот такой скрипт..... Но не понимаю как запустить счетчик...
// Erstellen der Variablen createState('Alarm.Pumpe.offen.Grenzwert', 2, { name: 'Время двери сигнализации открыт', desc: 'Время не сообщается в течение нескольких минут, пока открыты двери', type: 'number', unit: 'min' }); var idWohnungstuerGrenzwert = 3, idWohnungstuer = "javascript.0.Arduino3.DI"; // kann auch TFK mit STATE sein // Funktion von ruhr70 zur Wiederholung // http://forum.iobroker.net/viewtopic.php?f=21&p=28068#p28068 function wiederholungAnsage() { sendTo("telegram.0", 'Дверь все еще открыта!'); log('В квартире дверь все еще открыта еще минуту. Пожалуйста, закройте!'); } // обнаружение открытых дверей (JavaScript Variante triggert über Statusvariable, nicht TFK selbst) var timer = null; on(idWohnungstuer, function(obj) { var grenzwert = parseInt(getState(idWohnungstuerGrenzwert).val,10),meldung; if (obj.state.val === true) { // Дверь открыта if (!timer) { log('Дверь: Таймер двери запущен (2min)'); timer = setTimeout(function () { // таймер запускается if(timer) clearTimeout(timer); timer = null; timer = setInterval(wiederholungAnsage, 60000); sendTo("telegram.0", 'Дверь открыта!'); setState("sayit.0.tts.text", "ru;100;" + 'Дверь открыта!'); meldung = 'Входная дверь для 2 мин открыт!'; log(meldung); log('Timer'); }, grenzwert * 60 * 1000); //Таймер в течение нескольких минут } // Запрос End таймера } else { // Дверь закрылась, таймер останавливается if (timer) { clearTimeout(timer); clearInterval(timer); timer = null; sendTo("telegram.0", 'Таймер двери квартиры остановился.'); meldung = 'Дверь: Таймер двери остановлен'; } log(meldung); log('End'); } // Конец состояния двери запроса }); -
Всем привет. нужен некий ХЕЛП. Суть задачи - получить счетчик моторесурса некого устройства.
как я это вижу: Сработал насос и начался отсчет времени, насос выключился, счет остановился.
показания по идее должны суммироваться…..
Для начала нарыл вот такой скрипт..... Но не понимаю как запустить счетчик... `
Надо не отсчет запускать, а запоминать время включения и отключения (изменения состояния насоса).и соответсвенно суммировать их в переменную
-
как?
-
var counterId = 'motorTimeCounter'; // имя переменной счётчика. Появится в "javascript.0.motorTimeCounter" createState(counterId, {common: {type: 'number', unit: 'sec'}}, 0); // создаём, если надо переменную on('motor.state', function (obj) { // при изменении состояния мотора if (!obj.state.val && obj.stateOld && obj.stateOld.val) { // если состояние изменилось с ON => OFF то var timeMs = obj.state.ts - obj.stateOld.ts; // считаем время setState(counterId, getState(counterId).val + timeMs / 1000, true); // и добавляем к существующему } }); -
Или так:

! ````
<xml xmlns="http://www.w3.org/1999/xhtml"><block type="create" id="svECADP@D_LS~g[6T?n." x="13" y="63"><field name="NAME">motorCounter</field>
<statement name="STATEMENT"><block type="on_ext" id="OzG(WNC}y*:JL:!bvMgN"><mutation items="1"></mutation>
<field name="CONDITION">false</field>
<field name="ACK_CONDITION">true</field>
<value name="OID0"><shadow type="field_oid" id="aPODLp31t6i%07OAjKcc"><field name="oid">javascript.0.boolTest</field></shadow></value>
<statement name="STATEMENT"><block type="controls_if" id="N(GTE?/Qq^tiAefHhGo"><value name="IF0"><block type="logic_compare" id="1ySRjIFq!qlsFEikh@9."><field name="OP">EQ</field>
<value name="A"><block type="on_source" id="5,uId0is]chxW+2tq,l5"><field name="ATTR">oldState.val</field></block></value>
<value name="B"><block type="logic_boolean" id="p+knOuq|Bhhp6[N0+d-A"><field name="BOOL">TRUE</field></block></value></block></value>
<statement name="DO0"><block type="update" id="l-EoA#o@sAQW=i;.knE9"><mutation delay_input="false"></mutation>
<field name="OID">javascript.0.motorCounter</field>
<field name="WITH_DELAY">FALSE</field>
<value name="VALUE"><block type="math_arithmetic" id=")}{oRaa%=9fTN.0g@,="><field name="OP">ADD</field>
<value name="A"><shadow type="math_number" id=",f%0CvZv9qk(sbd:-hmI"><field name="NUM">1</field></shadow>
<block type="get_value" id="Ty#h:khrIoRj/Wm@w0Q-"><field name="ATTR">val</field>
<field name="OID">javascript.0.motorCounter</field></block></value>
<value name="B"><shadow type="math_number" id="E7v{Kyc.pPHl^|bohgU"><field name="NUM">1</field></shadow> <block type="math_arithmetic" id="~#~514BVd(vQsjrm6-?G"><field name="OP">DIVIDE</field> <value name="A"><shadow type="math_number" id="n7-[AqhR8fGgSg6M.=cW"><field name="NUM">1</field></shadow> <block type="math_arithmetic" id="M^d?]c-+!gs%M-AWNeMk"><field name="OP">MINUS</field> <value name="A"><shadow type="math_number" id=".fyZQ/wCR9IY9MmQ=X2_"><field name="NUM">1</field></shadow> <block type="on_source" id="+1R15yCYBce/A]wmSd7b"><field name="ATTR">state.ts</field></block></value> <value name="B"><shadow type="math_number" id="xd?;d7uEQ@Fmh=%Oo(-"><field name="NUM">1</field></shadow>
<block type="on_source" id="[Wn~yS.QQ|AZev|iD,v0"><field name="ATTR">oldState.ts</field></block></value></block></value>
<value name="B"><shadow type="math_number" id="S-T+6}o-dVpjnGakd!K!"><field name="NUM">1000</field></shadow></value></block></value></block></value></block></statement></block></statement></block></statement></block></xml> -
дилетантский вопрос - а куда записывать скрипты? во вкладку "Скрипты-Показать код" ничего не записывается
можно поправить блок Sentdo? `
http://www.iobroker.net/docu/?page_id=6703&lang=rublockly
-
Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart?
-
Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart? ` а какие объекты драйвер nut создаёт? Connection создаёт?
-
Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart?
а какие объекты драйвер nut создаёт? Connection создаёт?
Там много всякого создается, касаемо самого бесперебойника. Connection - не получится использовать, при этой ошибке как бы все нормально, драйвер зелененький. Вот поэтому и спросил про возможность отслеживать события в логе. Собственно, удаленный сервис nut работает (поэтому и драйвер не ругается на соединение), но при этом перестает отдавать данные (что и видно в логе). Помогает только рестарт сервиса. -
Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. `
Как это сделать? Есть примеры? С действием тоже вопрос - через exec надо отправить команду на удаленную машину (со своим паролем и логином), а не выполнять локально.
-
Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. ` лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника
-
Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия.
лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойникаЭто было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис.
-
! ````
var fs = require('fs');
var date = formatDate(new Date(res.result[0].ReceivingDateTime), 'YYYY-MM-DD');
readFile ('/opt/iobroker/log/iobroker.log.'+date, function (error, bytes) {
if(bytes.indexOf('Ошибка') > 0){
exec('/bin/bash /opt/iobroker/tmp/restart.sh');
}
})Примерно так. -
Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия.
лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойникаЭто было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис. `
Задай ему вопрос на гитхабе https://github.com/Apollon77/ioBroker.nut/issues -
Вернулся к вопросу с рестартом сервиса nut (о чем выше). Спасибо spectrekr и instalator за два варианта решения проблемы. Но я нашел третий вариант, на мой взгляд проще. Отслеживается одна из переменных (в принципе любая, но лучше константа), приходящих от драйвера nut, и если она не обновлялась дольше, чем два цикла опроса (в моем случае цикл 5 сек), то идет команда на рестарт сервиса на удаленном сервере. Вроде работает… В скрипте это так (может кому пригодится):
//---------------------------Restart nut------------------ var nut_timer_timeout_ms = 12 * 1000; var nut_timer_id = null; on({id: "nut.0.input.transfer-low", change: "eq"}, function (obj) { if (nut_timer_id) { clearTimeout(nut_timer_id); } nut_timer_id = setTimeout(function () { exec('ssh root@192.168.118.115 service nut-driver restart'); sendTo('telegram.0', { text:'Сервис NUT на сервере System завис и перезагружен.', disable_notification: true }); nut_timer_id = null; }, nut_timer_timeout_ms); });
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden