Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Вопросы по написанию скриптов

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      smoker_vvo last edited by

      Усе, разрулил….

      1 Reply Last reply Reply Quote 0
      • S
        smoker_vvo last edited by

        Всем привет. нужен некий ХЕЛП. Суть задачи - получить счетчик моторесурса некого устройства.

        как я это вижу: Сработал насос и начался отсчет времени, насос выключился, счет остановился.

        показания по идее должны суммироваться…..

        Для начала нарыл вот такой скрипт..... Но не понимаю как запустить счетчик...

        // 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');
            } // Конец состояния двери запроса
        });
        
        
        1 Reply Last reply Reply Quote 0
        • I
          instalator last edited by

          @smoker_vvo:

          Всем привет. нужен некий ХЕЛП. Суть задачи - получить счетчик моторесурса некого устройства.

          как я это вижу: Сработал насос и начался отсчет времени, насос выключился, счет остановился.

          показания по идее должны суммироваться…..

          Для начала нарыл вот такой скрипт..... Но не понимаю как запустить счетчик... `
          Надо не отсчет запускать, а запоминать время включения и отключения (изменения состояния насоса).

          и соответсвенно суммировать их в переменную

          1 Reply Last reply Reply Quote 0
          • S
            smoker_vvo last edited by

            как?

            1 Reply Last reply Reply Quote 0
            • Bluefox
              Bluefox last edited by

              
              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); // и добавляем к существующему
              	}
              });
              
              1 Reply Last reply Reply Quote 0
              • Bluefox
                Bluefox last edited by

                Или так:
                48_2017-06-22_13_11_27-iobroker.admin.png

                ! ````
                <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>

                1 Reply Last reply Reply Quote 0
                • V
                  ValG last edited by

                  дилетантский вопрос - а куда записывать скрипты? во вкладку "Скрипты-Показать код" ничего не записывается

                  можно поправить блок Sentdo?

                  1 Reply Last reply Reply Quote 0
                  • H
                    Haus last edited by

                    @ValG:

                    дилетантский вопрос - а куда записывать скрипты? во вкладку "Скрипты-Показать код" ничего не записывается

                    можно поправить блок Sentdo? `
                    http://www.iobroker.net/docu/?page_id=6703&lang=ru

                    blockly

                    http://www.iobroker.net/docu/?s=blockly&lang=de

                    1 Reply Last reply Reply Quote 0
                    • A
                      Adav last edited by

                      Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart?

                      1 Reply Last reply Reply Quote 0
                      • I
                        instalator last edited by

                        @Adav:

                        Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart? ` а какие объекты драйвер nut создаёт? Connection создаёт?

                        1 Reply Last reply Reply Quote 0
                        • A
                          Adav last edited by

                          @instalator:

                          @Adav:

                          Установил в ioBroker драйвер nut для работы с бесперебойником. Есть проблема - изредка (где-то раз в неделю) сервис nut на удаленной машине имеет свойство глючить и отваливаться. Ну и как следствие - в ioBroker в логах вижу ошибки. Есть ли какая-нибудь возможность отслеживать скриптом в логе ошибки и по данному событию отправлять команду на удаленную машину service nut-driver restart? а какие объекты драйвер nut создаёт? Connection создаёт?
                          Там много всякого создается, касаемо самого бесперебойника. Connection - не получится использовать, при этой ошибке как бы все нормально, драйвер зелененький. Вот поэтому и спросил про возможность отслеживать события в логе. Собственно, удаленный сервис nut работает (поэтому и драйвер не ругается на соединение), но при этом перестает отдавать данные (что и видно в логе). Помогает только рестарт сервиса.

                          1 Reply Last reply Reply Quote 0
                          • S
                            spectrekr last edited by

                            Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия.

                            1 Reply Last reply Reply Quote 0
                            • A
                              Adav last edited by

                              @spectrekr:

                              Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. `

                              Как это сделать? Есть примеры? С действием тоже вопрос - через exec надо отправить команду на удаленную машину (со своим паролем и логином), а не выполнять локально.

                              1 Reply Last reply Reply Quote 0
                              • I
                                instalator last edited by

                                @spectrekr:

                                Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. ` лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                                1 Reply Last reply Reply Quote 0
                                • A
                                  Adav last edited by

                                  @instalator:

                                  @spectrekr:

                                  Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                                  Это было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис.

                                  1 Reply Last reply Reply Quote 0
                                  • S
                                    spectrekr last edited by

                                    ! ````
                                    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');
                                    }
                                    })

                                    Примерно так.
                                    1 Reply Last reply Reply Quote 0
                                    • I
                                      instalator last edited by

                                      @Adav:

                                      @instalator:

                                      @spectrekr:

                                      Ну как вариант через readfile читать лог файл и парсить, при обнаружении ошибки выполнять уже необходимые действия. лучше сделать доработку драйвера чтобы создавался объект еррор например и в него писать что нет данных от бесперебойника

                                      Это было бы идеально, но тут вопрос к разработчику… Как вариант - отслеживать состояние сервиса непосредственно на удаленной машине bash скриптом, но тут я тоже не тяну сделать самостоятельно. По идее можно делать запрос upsc и если нет данных - перегружать сервис. `
                                      Задай ему вопрос на гитхабе https://github.com/Apollon77/ioBroker.nut/issues

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        Adav last edited by

                                        Вернулся к вопросу с рестартом сервиса 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);      
                                        });
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • A
                                          andrey99986 last edited by

                                          Есть ли возможность активировать и дезактивировать запись значений в БД (драйвер sql) объекта по условию - в зависимости от состояния другого объекта?

                                          Например есть объект "Security" и "megad.0.Sensor1".

                                          Надо чтобы состояние объекта "megad.0.Sensor1" писалось в БД только когда getState("Security").val == true.

                                          1 Reply Last reply Reply Quote 0
                                          • H
                                            Haba last edited by

                                            оно?

                                            {
                                              "_id": "mysensors.0.61.255_ARDUINO_NODE.I_BATTERY_LEVEL",
                                              "common": {
                                                "name": "2.2.0-beta.I_BATTERY_LEVEL",
                                                "type": "number",
                                                "role": "value",
                                                "min": 0,
                                                "max": 100,
                                                "unit": "%",
                                                "def": 100,
                                                "read": true,
                                                "write": false,
                                                "custom": {
                                                  "sql.0": {
                                            

                                            "enabled": true,

                                                   "changesOnly": true,
                                                    "debounce": 1000,
                                                    "retention": 31536000,
                                                    "changesRelogInterval": 0,
                                                    "changesMinDelta": "",
                                                    "storageType": ""
                                                  }
                                                }
                                              },
                                              "native": {
                                                "id": "61",
                                                "childId": "255",
                                                "subType": "S_ARDUINO_NODE",
                                                "subTypeNum": 17,
                                                "varType": "I_BATTERY_LEVEL",
                                                "varTypeNum": 0
                                              },
                                              "type": "state",
                                              "acl": {
                                                "object": 1638,
                                                "state": 1638
                                              }
                                            }
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            610
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            86711
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo