Navigation

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

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

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

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

      Ребят, такой вопрос.

      В скрипте создаю переменную и ниже по тексту на нее же подписываюсь.

      Первый раз скрипт не запускается, вываливается с ошибками типа таких:

      ! ReferenceError: 05 18:56:57.056 error at Socket.onpacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:221:12) ReferenceError: 05 18:56:57.056 error at Socket.onevent (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:263:10) ReferenceError: 05 18:56:57.056 error at Socket.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-emitter/index.js:131:20) ReferenceError: 05 18:56:57.056 error at Socket. (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInMemClient.js:45:30) ReferenceError: 05 18:56:57.056 error at Object.that.states.States.change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:2036:80) ReferenceError: 05 18:56:57.056 error at Object.utils.adapter.stateChange (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:215:17) ReferenceError: 05 18:56:57.056 error at checkPatterns (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:537:17) ReferenceError: 05 18:56:57.056 error at getObjectEnums (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2624:45) ReferenceError: 05 18:56:57.056 error at /opt/iobroker/node_modules/iobroker.javascript/javascript.js:541:48 ReferenceError: 05 18:56:57.056 error at Object.subs.callback (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:1207:48) ReferenceError: 05 18:56:57.056 error at Object. (script.js.common.cubietruck:224:23) ReferenceError: 05 18:56:57.056 error poll_ac is not defined message 05 18:56:57.053 error javascript.0.cubietruck.ac.poolinterval [object Object] poll_ac is not defined javascript-0 05 18:56:56.885 error at script.js.common.cubietruck:248:82 javascript-0 05 18:56:56.885 error script.js.common.cubietruck: TypeError: Cannot read property 'val' of null javascript-0 05 18:56:56.874 warn State "javascript.0.cubietruck.ac.poolinterval" not found !
      Второй раз запускаю, все ОК.

      Как заставить сначала создавать, потом подписываться?

      Или есть вариант, что я не правильно понял ошибку?

      Скрипт примерно такой:

      var pool_ac = null; //интервал опроса переменных AC
      createState('cubietruck.ac.poolinterval',10000);
      //Изменение интервала опроса
      on({id: 'javascript.0.cubietruck.ac.poolinterval', change: 'any'}, function (obj) {
          if (obj.newState.val !== '' || typeof obj.newState.val !== "undefined" || parseInt(obj.newState.val) >= 1000){
              clearInterval(poll_ac);
              poll_ac = setInterval(poolAC, parseInt(obj.newState.val));
          } else {
              clearInterval(poll_ac);
          }
      });
      function poolAC () {
         log("test");
      }
      poll_ac = setInterval(poolAC, getState('javascript.0.cubietruck.ac.poolinterval').val);
      
      

      Ошибка по идее на последнюю строчку, т.е. не может получить getState().val хотя в createState('cubietruck.ac.poolinterval',10000); значение по-умолчанию прописано.

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

        var pool_ac = null; //интервал опроса переменных AC
        createState('cubietruck.ac.poolinterval',10000, function () {
            poll_ac = setInterval(poolAC, getState('javascript.0.cubietruck.ac.poolinterval').val);
        });
        
        //Изменение интервала опроса
        on({id: 'javascript.0.cubietruck.ac.poolinterval', change: 'any'}, function (obj) {
            clearInterval(poll_ac);
            if (parseInt(obj.newState.val || 0) >= 1000) {
                poll_ac = setInterval(poolAC, parseInt(obj.newState.val));
            }
        });
        
        function poolAC () {
           log("test");
        }
        
        

        createState - асинхронная функция.

        Наверное надо что-то сделать будет. Ты не первый, кто напоролся на это . :?

        1 Reply Last reply Reply Quote 0
        • E
          electric last edited by

          Возникла проблемка с запуском скриптов.

          Есть такая библиотека, называется https://github.com/EnotionZ/GpiO.

          Она позволяет "подписываться" на изменение порта gpio функцией типа:

          // bind to the "change" event
          gpio4.on("change", function(val) {
             // value will report either 1 or 0 (number) when the value changes
             console.log(val)
          });
          
          

          Однако, если перезапустить скрипт или остановить, а затем опять запустить, этот EventEmitter не останавливается, а запускается еще один экземпляр.

          Есть функция, чтобы отписаться:

          // unbind all callbacks from the "change" event
          gpio4.removeAllListeners("change");
          
          

          Но как её использовать? Может есть функция, которая запускается при остановке скрипта, типа "сборщика мусора"?

          BlueFox, прошу помощи :oops:

          1 Reply Last reply Reply Quote 0
          • E
            electric last edited by

            Спасибо BlueFox, теперь есть специальная функция https://github.com/ioBroker/ioBroker.javascript#onstop.

            Все http://www.iobroker.net/?page_id=4268&lang=ru#__-_GPIO_ioBroker как часы теперь…

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

              Делаю запрос через sql драйвер,

              sendTo('sql.0', 'query','SELECT UDH, UpdatedInDB FROM smsd.inbox WHERE ID = '+ id, function(res) {};

              Результат возвращается в JSON и в итоге UpdatedInDB содержит дату формата 2016-08-25T07:28:07.000Z, а должен быть 2016-08-25 10:28:07. Как получить нужный формат, а то данное значение необходимо для следующего запроса?

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

                @spectrekr:

                Делаю запрос через sql драйвер,

                sendTo('sql.0', 'query','SELECT UDH, UpdatedInDB FROM smsd.inbox WHERE ID = '+ id, function(res) {};

                Результат возвращается в JSON и в итоге UpdatedInDB содержит дату формата 2016-08-25T07:28:07.000Z, а должен быть 2016-08-25 10:28:07. Как получить нужный формат, а то данное значение необходимо для следующего запроса? `

                new Date('2016-08-25T07:28:07.000Z').toLocaleString() => "25.08.2016, 9:28:07"
                

                oder

                formatDate(new Date('2016-08-25T07:28:07.000Z'), 'YYYY-MM-DD hh:mm:ss.sss') => "2016-08-25 09:28:07.000"
                
                1 Reply Last reply Reply Quote 0
                • M
                  MSapogov last edited by

                  Простите за глупый вопрос.

                  Очень хочется получить значение из переменной - squeezebox.0.Children.currentTitle

                  и отправить его в mqtt.0.beeiot.Bee-RGB.lcd.line2

                  И значение из squeezebox.0.Children.volume отправить на mqtt.0.beeiot.Bee-RGB.lcd.line3 добавив слово "Громкость" значение "%".

                  А так -же при появлении события mqtt.0.beeiot.Bee-RGB.gpioint1 неважно какое, главное новое событие - изменить значение squeezebox.0.Children.volume на +1

                  Этакий ваносной пульт от squeezebox по MQTT.

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

                    @MSapogov:

                    Простите за глупый вопрос.

                    Очень хочется получить значение из переменной - squeezebox.0.Children.currentTitle

                    и отправить его в mqtt.0.beeiot.Bee-RGB.lcd.line2 `
                    setState("mqtt.0.beeiot.Bee-RGB.lcd.line2", getState("squeezebox.0.Children.currentTitle").val);

                    @MSapogov:

                    И значение из squeezebox.0.Children.volume отправить на mqtt.0.beeiot.Bee-RGB.lcd.line3 добавив слово "Громкость" значение "%".

                    А так -же при появлении события mqtt.0.beeiot.Bee-RGB.gpioint1 неважно какое, главное новое событие - изменить значение squeezebox.0.Children.volume на +1

                    Этакий ваносной пульт от squeezebox по MQTT. `
                    setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %");

                    @MSapogov:

                    А так -же при появлении события mqtt.0.beeiot.Bee-RGB.gpioint1 неважно какое, главное новое событие - изменить значение squeezebox.0.Children.volume на +1

                    Этакий ваносной пульт от squeezebox по MQTT. `

                    on({id: 'mqtt.0.beeiot.Bee-RGB.gpioint1', change: 'any'}, function (obj) {

                    setState("squeezebox.0.Children.volume", getState("squeezebox.0.Children.volume").val + 1);

                    });

                    Как-то так))

                    1 Reply Last reply Reply Quote 0
                    • M
                      MSapogov last edited by

                      Спасибо!

                      Говорю-же глупый вопрос…

                      А куда это писать? В файлик какой что-ли? Или в WEB интерфейсе где?

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

                        Устанавливаете драйвер javascript и в нем создаете скрипт.

                        1 Reply Last reply Reply Quote 0
                        • M
                          MSapogov last edited by

                          @spectrekr:

                          Устанавливаете драйвер javascript и в нем создаете скрипт. `
                          Установил Javascript Script Engine.

                          Ну никак не пойму как в нем создать скрипт. В настройках драйвера ничего подобного нет. 😞

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

                            @MSapogov:

                            @spectrekr:

                            Устанавливаете драйвер javascript и в нем создаете скрипт. `
                            Установил Javascript Script Engine.

                            Ну никак не пойму как в нем создать скрипт. В настройках драйвера ничего подобного нет. 😞 `
                            В админке должна появиться закладка "Скрипты". Надо принудительно обновить страницу, если не видно.

                            1 Reply Last reply Reply Quote 0
                            • M
                              MSapogov last edited by

                              @andrey99986:

                              @MSapogov:

                              @spectrekr:

                              Устанавливаете драйвер javascript и в нем создаете скрипт. `
                              Установил Javascript Script Engine.

                              Ну никак не пойму как в нем создать скрипт. В настройках драйвера ничего подобного нет. 😞 В админке должна появиться закладка "Скрипты". Надо принудительно обновить страницу, если не видно.
                              Спасибо! А я-то обновлял инфо о драйверах. 🙂

                              И на последок, в какое место вставить cron для строки setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %"); чтобы она выполнялась каждые 2 секунды?

                              Скрипт on({id: 'mqtt.0.beeiot.Bee-RGB.gpioint1', change: 'any'}, function (obj) {

                              setState("squeezebox.0.Children.volume", getState("squeezebox.0.Children.volume").val + 1);

                              }); - работает безупречно!!!

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

                                @MSapogov:

                                И на последок, в какое место вставить cron для строки setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %"); чтобы она выполнялась каждые 2 секунды?

                                Скрипт on({id: 'mqtt.0.beeiot.Bee-RGB.gpioint1', change: 'any'}, function (obj) {

                                setState("squeezebox.0.Children.volume", getState("squeezebox.0.Children.volume").val + 1);

                                }); - работает безупречно!!! `

                                А зачем? согласно документации на https://github.com/ioBroker/ioBroker.javascript

                                Функция "on" запускает "слушатель" на изменение или обновления состояния.

                                Соответственно если запустить в "Скриптах" 1 раз - будет слушать и реагировать всегда.

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

                                  @andrey99986:

                                  А зачем? согласно документации на https://github.com/ioBroker/ioBroker.javascript

                                  Функция "on" запускает "слушатель" на изменение или обновления состояния.

                                  Соответственно если запустить в "Скриптах" 1 раз - будет слушать и реагировать всегда. `

                                  Согласно ТЗ человека.
                                  @MSapogov:

                                  А так -же при появлении события mqtt.0.beeiot.Bee-RGB.gpioint1 неважно какое, главное новое событие - изменить значение squeezebox.0.Children.volume на +1 `

                                  @MSapogov:

                                  И на последок, в какое место вставить cron для строки setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %"); чтобы она выполнялась каждые 2 секунды? `

                                  schedule("*/2 * * * * *", function () {

                                  setState("mqtt.0.beeiot.Bee-RGB.lcd.line3", "Громкость " + getState("squeezebox.0.Children.volume").val + " %");

                                  });

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

                                    Проблема - если в скрипте ошибка, драйвер Javascript начинает бесконечно перезапускаться, в лог пишет одно и то же:

                                    host-home	2016-09-14 12:36:08.572	info	Restart adapter system.adapter.javascript.0 because enabled
                                    host-home	2016-09-14 12:36:08.571	error	instance system.adapter.javascript.0 terminated with code 0 (OK)
                                    javascript-0	2016-09-14 12:36:08.563	info	terminating
                                    Error:	2016-09-14 12:36:08.559	error	at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:78:26)
                                    Error:	2016-09-14 12:36:08.559	error	at errnoException (dns.js:27:10)
                                    Error:	2016-09-14 12:36:08.559	error	getaddrinfo ENOTFOUND 192.168.2.10:8088 192.168.2.10:8088:80
                                    

                                    при этом зайти в "Скрипты" и исправить её невозможно - страница "Скрипты" не загружается.

                                    Что в таких случаях делать?

                                    1 Reply Last reply Reply Quote 0
                                    • E
                                      electric last edited by

                                      @andrey99986:

                                      Проблема - если в скрипте ошибка, драйвер Javascript начинает бесконечно перезапускаться

                                      при этом зайти в "Скрипты" и исправить её невозможно - страница "Скрипты" не загружается.

                                      Что в таких случаях делать? `
                                      Можно попробовать остановить неработающий скрипт и перезапустить драйвер.

                                      Вкладка "Объекты" - далее раскрываем список с нужным экземпляром драйвера (к примеру javascript.0), далее "scriptEnabled" - группа скриптов с искомым и значение true меняем на false.

                                      Перезапускаем драйвер, смотрим где ошибка.

                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        creo last edited by

                                        Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

                                        сам скрипт:

                                        on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                                                if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                                                    log(getState('svetOn').val);
                                                        clearTimeout(timer);
                                                        var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                                                        log(lux_kitchen);
                                                            if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                                                            if (flag_motion_kitchen){
                                                                log('запускаем таймер отключения на 30000');
                                                                timer = setTimeout(function() {
                                                                    setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                                                    flag_motion_kitchen = false;
                                                                    setState('svetOn',0);
                                                                   log("выкл свет по таймеру");
                                                                },
                                                                30000
                                                            );}
                                                            if (obj.newState.val === true && flag_motion_kitchen){
                                                                setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                                                setState('svetOn',3);
                                                                log("вкл свет");
                                                            }
                                                }
                                        });
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • Bluefox
                                          Bluefox last edited by

                                          @creo:

                                          Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

                                          сам скрипт:

                                          on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                                                  if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                                                      log(getState('svetOn').val);
                                                          clearTimeout(timer);
                                                          var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                                                          log(lux_kitchen);
                                                              if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                                                              if (flag_motion_kitchen){
                                                                  log('запускаем таймер отключения на 30000');
                                                                  timer = setTimeout(function() {
                                                                      setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                                                      flag_motion_kitchen = false;
                                                                      setState('svetOn',0);
                                                                     log("выкл свет по таймеру");
                                                                  },
                                                                  30000
                                                              );}
                                                              if (obj.newState.val === true && flag_motion_kitchen){
                                                                  setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                                                  setState('svetOn',3);
                                                                  log("вкл свет");
                                                              }
                                                  }
                                          });
                                          ```` `  
                                          

                                          Просто добавь первой строчкой

                                          перед "if (getState('onSensor').val ==…."

                                          if (obj.state.ack) return;
                                          
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • C
                                            creo last edited by

                                            теперь скрипт дальше чем if (obj.state.ack) return; не отрабатывает&

                                            Даже при приходящем событии о смене статуса

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            952
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            83128
                                            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