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.
    • Bluefox
      Bluefox last edited by

      Не жалей букв на названия 😉

      ! ```
      `var request = require('request');
      var fs = require('fs');
      var path, obn, readme, ver_c, ver_n;
      ! function get_info(obn, cb){
      path = 'iobroker/node_modules/iobroker.' + obn;

      if (fs.existsSync(path)) {
      	fs.readFile(path + "/io-package.json", function (error, data) {
      		if (!error) {
      			var result;
      			try {
      				result = JSON.parse(data);
      			} catch (err) {
      				console.error("Не парсится!");
      				return cb(obn);
      			}
      			cb(obn, result.common.readme, result.common.version);
      		} else {
      			console.error(error);
      			cb(obn);
      		}
      	});
      } else {
      	cb(obn);
      }
      

      }

      ! function get_ver_upd (drv, cb) {
      var path_upd = 'iobroker/node_modules/iobroker.js-controller/conf/sources-dist.json';
      if (fs.existsSync(path_upd)) {
      fs.readFile(path_upd, function (error, data) {
      if (!error) {
      var result;
      try {
      result = JSON.parse(data);
      } catch (err) {
      log("Не парсится!");
      return cb(drv);
      }
      request(result[drv].meta, function (error, response, body) {
      if (!error && response.statusCode == 200) {
      var result_ver;
      try {
      result_ver = JSON.parse(body);
      } catch (err) {
      console.error("Не парсится!");
      return cb(drv);
      }
      cb(drv, result_ver.common.version);
      } else {
      console.error(error);
      cb(drv);
      }
      });
      } else {
      console.error(error);
      cb(drv);
      }
      });
      } else {
      cb(drv);
      }
      }
      ! function get_chang(readme, ver_c, ver_n, callback){
      log(readme);
      log(ver_c);
      log(ver_n);
      callback && callback();
      }
      ! function processData(data, callback) {
      if (data && !data instanceof Array) {
      // convert data
      var arr = [];
      for (var a in data) {
      data[a].name = a;
      arr.push(data[a]);
      }
      data = arr;
      }

      if (!data || !data.length) {
      	callback && callback();
      	return;
      }
      
      var task = data.pop();
      
      get_chang(task.readme, task.version, task.versionUpdate, function () {
      	setTimeout(function () {
      		processData(data, callback);
      	}, 0);
      });
      

      }

      ! on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
      var str = 'Доступно обновления для:\n';
      if (getState('admin.0.info.updatesNumber').val) {
      obn = obj.state.val.split(',');
      var ready = 0;
      var data = {};
      for (var i = 0; i < obn.length; i++) {
      ready++;
      get_info(obn[i], function(adapter, r, v){
      if (r) {
      data[adapter] = data[adapter] || {};
      data[adapter].readme = r;
      data[adapter].version = v;
      }
      ! if (!--ready) {
      processData(arr);
      }
      });
      ready++;
      get_ver_upd(obn[i], function(adapter, v){
      if (v) {
      data[adapter] = data[adapter] || {};
      data[adapter].versionUpdate = v;
      }
      if (!--ready) {
      processData(data);
      }
      });
      }
      }
      ! });`[/i][/i]

      1 Reply Last reply Reply Quote 0
      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            956
                                            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