Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    661

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

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

Scheduled Pinned Locked Moved ioBroker скрипты
358 Posts 29 Posters 116.1k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • L Offline
    L Offline
    Lstt
    wrote on last edited by
    #145

    Дело в скрипте, это работает чётко:

    var fs = require('fs'),
    request = require('request');
    
    var download = function(uri, filename, callback){
    
      var r = request({
        url: uri,
        headers: {
          'accept': 'image/*',
          'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36',
        }
      }).pipe(fs.createWriteStream(filename));
      r.on('error', function(err) {console.log(err)})
      r.on('close', callback);
    };
    
    on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
    download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
      console.log('Сamera 1 copying done');
      sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
      });
    
     download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
        console.log('Camera 2 copying done!');
        sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
      });
     download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
        console.log('Camera 3 copying done!');
        sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
      }); 
      download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
        console.log('Camera 4 copying done!');
        sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
    });
    });
    
    
    1 Reply Last reply
    0
    • H Offline
      H Offline
      Haus
      wrote on last edited by
      #146

      Записываю в log_heat.txt "log_heat", может как то по другому надо ? ( log_heat может быть много, в зависимости от условий по скрипту)

      function getTimeAsString(d) {
          var date = d || new Date();
          return ('0' + (date.getMonth() + 1)).slice(-2) + '/' + ('0' + date.getDate()).slice(-2) + ' '+ ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);
      }
      
      function script (addTimestamp) {
          var fs = require('fs');
          var log_heat;
          log_heat = ( getTimeAsString() + ' ' + 'Температура бака');
          fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n");
      
          log_heat = ( getTimeAsString() + ' ' + 'Температура бакаaaaaaaaaaaaaa');
          fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n");
      }    
      
      function start () {
          var request = require ( 'request' );
          request ( 'http://192.168.1.11/avr_temp_out.php', function ( error, response, body ) {
              if ( !error && response.statusCode == 200 ) {
                  //setState ( toaid, body );
                  log('1 avr_temp_out: ' + body);
              }
              setTimeout ( function () {
                  script ();
                  }, 1000 );
          });
      }
      setInterval ( function () {
          start ();
      }, 30000 );
      

      js-controller: 1.5.7 / node.js: v8.15.1/ npm: 6.4.1

      admin: 3.6.0

      javascript: 4.1.10

      web: 2.4.1 vis: 1.1.10

      cloud: 2.6.2

      Server: DELL FX170 / linux: Debian 9.5 Stretch

      Adapter: MegaD-2561, Mega-ES…

      1 Reply Last reply
      0
      • S Offline
        S Offline
        spectrekr
        wrote on last edited by
        #147

        Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

        on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
            if (getState('admin.0.info.updatesNumber').val > 0){
                sendTo('telegram', obj.val);
                log(obj.val);
            }
        });
        
        
        1 Reply Last reply
        0
        • aurodionovA Offline
          aurodionovA Offline
          aurodionov
          wrote on last edited by
          #148

          @spectrekr:

          Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

          on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
              if (getState('admin.0.info.updatesNumber').val > 0){
                  sendTo('telegram', obj.val);
                  log(obj.val);
              }
          });
          
          ```` `  
          

          Вроде id: лишние

          Пишу с пульта….

          Пишу с пульта….

          1 Reply Last reply
          0
          • S Offline
            S Offline
            spectrekr
            wrote on last edited by
            #149

            Так везде и всегда так подписываюсь на изменения, и в примерах так описано. Да и он отслеживает изменения и запускает на выполнение, только вот, насколько я понял, значение объекта в текст не может перевести.

            1 Reply Last reply
            0
            • I Offline
              I Offline
              instalator
              wrote on last edited by
              #150

              @spectrekr:

              Так везде и всегда так подписываюсь на изменения, и в примерах так описано. Да и он отслеживает изменения и запускает на выполнение, только вот, насколько я понял, значение объекта в текст не может перевести. `
              Obj.val.toString()

              Высокий уровень Децибел вреден для здоровья!

              http://blog.instalator.ru/

              1 Reply Last reply
              0
              • I Offline
                I Offline
                instalator
                wrote on last edited by
                #151

                @spectrekr:

                Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

                on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
                    if (getState('admin.0.info.updatesNumber').val > 0){
                        sendTo('telegram', obj.val);
                        log(obj.val);
                    }
                });
                
                ```` `  
                
                on({id: 'admin.0.info.updatesNumber', change: 'any'}, function (obj) {
                    if (obj.newState.val > 0){
                        sendTo('telegram', (obj.newState.val).toString());
                        log(obj.newState.val);
                    }
                });
                

                А если так?

                Высокий уровень Децибел вреден для здоровья!

                http://blog.instalator.ru/

                1 Reply Last reply
                0
                • S Offline
                  S Offline
                  spectrekr
                  wrote on last edited by
                  #152

                  Сейчас поставил по-первому способу, если не пойдет, буду пробовать вторым способом. Осталось дождаться какого нибудь обновления :-)

                  1 Reply Last reply
                  0
                  • BluefoxB Offline
                    BluefoxB Offline
                    Bluefox
                    wrote on last edited by
                    #153

                    @spectrekr:

                    Сейчас поставил по-первому способу, если не пойдет, буду пробовать вторым способом. Осталось дождаться какого нибудь обновления :-) `
                    Как instalator написал: obj.newState.val правильно

                    Также работает obj.state.val

                    1 Reply Last reply
                    0
                    • S Offline
                      S Offline
                      spectrekr
                      wrote on last edited by
                      #154

                      Блин, уже мозг взрывается. Пытаюсь выполнить команду через exec

                      var cmd = "'/usr/src/git/git_upd.sh "+ obn + ' ' + date_obn + "'";
                              log(cmd);
                              child = exec (cmd,
                                  function (error, stdout, stderr){
                                      if (error !== null) {
                                          log(error);
                                      }
                      
                      

                      В логе получаю

                      ! 11:14:16.421 [info] javascript.0 script.js.Скрипт1: '/usr/src/git/git_upd.sh sayit 2016.5.16'
                      ! 11:14:16.422 [info] javascript.0 script.js.Скрипт1: Error: Command failed: /bin/sh -c '/usr/src/git/git_upd.sh sayit 2016.5.16' /bin/sh: 1: /usr/src/git/git_upd.sh sayit 2016.5.16: not found
                      В консоле от этого же юзера, под которым работает сервер, эта команда без проблем выполняется.

                      ! cubie@Cubian:/usr/src/git$ /bin/sh -c '/usr/src/git/git_upd.sh sayit 2016.5.12'
                      ! GermanBluefox, Sat May 14 15:39:12 2016 +0200 : ### 1.0.0 (2016-05-14) * (bluefox) Make the type of mp3 as file

                      upd: Разобрался, сделал обходным путем.

                      1 Reply Last reply
                      0
                      • S Offline
                        S Offline
                        spectrekr
                        wrote on last edited by
                        #155

                        делаю функцию.

                        ! ````
                        var get_ver_upd = function (drv){
                        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("Не парсится!");
                        result = null;
                        }
                        // log(result[drv].meta);
                        request(result[drv].meta, function (error, response, body) {
                        if (!error && response.statusCode == 200) {
                        var result_ver;
                        try {
                        result_ver = JSON.parse(body)
                        } catch (err) {
                        log("Не парсится!");
                        result_ver = null;
                        }
                        // log(result_ver.common.version);
                        return result_ver.common.version;
                        }
                        });
                        }
                        });
                        }
                        }

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

                        ver_n = get_ver_upd(obn);
                        log(ver_n);

                        ver_n объявлена глобально.
                        1 Reply Last reply
                        0
                        • I Offline
                          I Offline
                          instalator
                          wrote on last edited by
                          #156

                          @spectrekr:

                          делаю функцию.

                          ! ````
                          var get_ver_upd = function (drv){
                          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("Не парсится!");
                          result = null;
                          }
                          // log(result[drv].meta);
                          request(result[drv].meta, function (error, response, body) {
                          if (!error && response.statusCode == 200) {
                          var result_ver;
                          try {
                          result_ver = JSON.parse(body)
                          } catch (err) {
                          log("Не парсится!");
                          result_ver = null;
                          }
                          // log(result_ver.common.version);
                          return result_ver.common.version;
                          }
                          });
                          }
                          });
                          }
                          }

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

                          ver_n = get_ver_upd(obn);
                          log(ver_n);

                          ver_n объявлена глобально. `  
                          

                          ! ````
                          function get_ver_upd (drv){
                          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("Не парсится!");
                          result = null;
                          }
                          // log(result[drv].meta);
                          request(result[drv].meta, function (error, response, body) {
                          if (!error && response.statusCode == 200) {
                          var result_ver;
                          try {
                          result_ver = JSON.parse(body)
                          } catch (err) {
                          log("Не парсится!");
                          result_ver = null;
                          }
                          // log(result_ver.common.version);
                          return result_ver.common.version;
                          }
                          });
                          }
                          });
                          }
                          }

                          Высокий уровень Децибел вреден для здоровья!

                          http://blog.instalator.ru/

                          1 Reply Last reply
                          0
                          • I Offline
                            I Offline
                            instalator
                            wrote on last edited by
                            #157

                            ! function get_ver_upd (drv, callback){ 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("Не парсится!"); result = null; } // log(result[drv].meta); request(result[drv].meta, function (error, response, body) { if (!error && response.statusCode == 200) { var result_ver; try { result_ver = JSON.parse(body) } catch (err) { log("Не парсится!"); result_ver = null; } // log(result_ver.common.version); callback (result_ver.common.version); } }); } }); } } ! get_ver_upd(obn, function(n){ log(n); }); !

                            Высокий уровень Децибел вреден для здоровья!

                            http://blog.instalator.ru/

                            1 Reply Last reply
                            0
                            • S Offline
                              S Offline
                              spectrekr
                              wrote on last edited by
                              #158

                              Возник другой вопрос, а как заставить цикл ждать отработки всех функций внутри цикла?

                              ! ```
                              for (var i = 0; i < obn.length; i++) { get_info(obn[i], function(readme, ver_c){ log(readme); log(ver_c); }); get_ver_upd(obn[i], function(ver_n){ log(ver_n); });
                              а выводит как попало
                              ! >! ~~[spoiler]~~16:35:56.441 [info] javascript.0 script.js.update: https://github.com/ioBroker/ioBroker.mq ... /README.md
                              ! 16:35:56.442 [info] javascript.0 script.js.update: 1.0.3
                              ! 16:35:56.442 [info] javascript.0 script.js.update: https://github.com/iobroker/ioBroker.ja ... /README.md
                              ! 16:35:56.442 [info] javascript.0 script.js.update: 2.0.6
                              ! 16:35:56.705 [info] javascript.0 script.js.update: 2.1.0
                              ! 16:35:56.713 [info] javascript.0 script.js.update: 1.0.3[/spoiler]
                              И еще попутно, почему не присваивает значение?
                              ~~[code]~~get_ver_upd(obn, function(n){ ver_n = n; }); [/code][/i][/i]

                              1 Reply Last reply
                              0
                              • BluefoxB Offline
                                BluefoxB Offline
                                Bluefox
                                wrote on last edited by
                                #159
                                `var ready = 0;
                                for (var i = 0; i < obn.length; i++) {
                                            ready++;
                                            get_info(obn[i], function(readme, ver_c){
                                                log(readme);
                                                log(ver_c);
                                                if (!--ready) {
                                                     log('finished');
                                                }
                                            });
                                            ready++;
                                            get_ver_upd(obn[i], function(ver_n){
                                                log(ver_n);
                                                if (!--ready) {
                                                     log('finished');
                                                }
                                            });
                                }`[/i][/i]
                                
                                1 Reply Last reply
                                0
                                • S Offline
                                  S Offline
                                  spectrekr
                                  wrote on last edited by
                                  #160

                                  Странно отрабатывает, да еще и 1 раз только finished пишет.

                                  ! 17:35:17.349 [info] javascript.0 script.js.update: https://github.com/ioBroker/ioBroker.mq … /README.md
                                  ! 17:35:17.349 [info] javascript.0 script.js.update: 1.0.3
                                  ! 17:35:17.349 [info] javascript.0 script.js.update: https://github.com/iobroker/ioBroker.ja … /README.md
                                  ! 17:35:17.349 [info] javascript.0 script.js.update: 2.0.6
                                  ! 17:35:17.612 [info] javascript.0 script.js.update: 2.1.0
                                  ! 17:35:17.613 [info] javascript.0 script.js.update: 1.0.3
                                  ! 17:35:17.613 [info] javascript.0 script.js.update: finished
                                  А по поводу передать значение не подскажешь?

                                  1 Reply Last reply
                                  0
                                  • BluefoxB Offline
                                    BluefoxB Offline
                                    Bluefox
                                    wrote on last edited by
                                    #161

                                    Давай весь скрипт. Хватит кусками выдавать. :)

                                    Там функции get_ver_upd и get_info надо менять

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      spectrekr
                                      wrote on last edited by
                                      #162

                                      @Bluefox:

                                      Давай весь скрипт. Хватит кусками выдавать. :)

                                      Там функции get_ver_upd и get_info надо менять `

                                      ! ```
                                      `var request = require('request');
                                      var fs = require('fs');
                                      var path, obn, readme, ver_c, ver_n;
                                      ! function get_info(obn){
                                      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) {
                                      log("Не парсится!");
                                      result = null;
                                      }
                                      return result.common.readme, result.common.version;
                                      }
                                      });
                                      }
                                      }
                                      ! function get_ver_upd (drv){
                                      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("Не парсится!");
                                      result = null;
                                      }
                                      request(result[drv].meta, function (error, response, body) {
                                      if (!error && response.statusCode == 200) {
                                      var result_ver;
                                      try {
                                      result_ver = JSON.parse(body);
                                      } catch (err) {
                                      log("Не парсится!");
                                      result_ver = null;
                                      }
                                      return result_ver.common.version;
                                      }
                                      });
                                      }
                                      });
                                      }
                                      }
                                      ! function get_chang(readme, ver_c, ver_n, callback){
                                      log(readme);
                                      log(ver_c);
                                      log(ver_n);

                                      }

                                      ! on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
                                      var str = 'Доступно обновления для:\n';
                                      if (getState('admin.0.info.updatesNumber').val > 1){
                                      obn = obj.state.val.split(',');
                                      /* for (var i = 0; i < obn.length; i++) {
                                      get_info(obn[i], function(readme, ver_c){
                                      log(readme);
                                      log(ver_c);
                                      });
                                      get_ver_upd(obn[i], function(ver_n){
                                      log(ver_n);
                                      });
                                      */
                                      var ready = 0;
                                      for (var i = 0; i < obn.length; i++) {
                                      ready++;
                                      get_info(obn[i], function(r, v){
                                      // log(r);
                                      readme = r;
                                      // log(v);
                                      ver_c = v;
                                      if (!--ready) {
                                      log('finished');
                                      }
                                      });
                                      ready++;
                                      get_ver_upd(obn[i], function(v){
                                      log(ver_n);
                                      ver_n = v;
                                      if (!--ready) {
                                      log('finished');
                                      }
                                      });
                                      }
                                      }
                                      if (getState('admin.0.info.updatesNumber').val == 1){
                                      obn = obj.state.val;
                                      get_info(obn, function(r, v){
                                      // log(r);
                                      readme = r;
                                      // log(v);
                                      ver_c = v;
                                      });
                                      get_ver_upd(obn, function(v){
                                      // log(v);
                                      ver_n = v;
                                      });
                                      get_chang(readme, ver_c, ver_n);
                                      }
                                      });`
                                      Это то что на данный момент. Соответственно в function get_chang будет дальнейшая обработка.[/i][/i][/i][/i]

                                      1 Reply Last reply
                                      0
                                      • BluefoxB Offline
                                        BluefoxB Offline
                                        Bluefox
                                        wrote on last edited by
                                        #163

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

                                        ! ```
                                        `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
                                        0
                                        • E Offline
                                          E Offline
                                          electric
                                          wrote on last edited by
                                          #164

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

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

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

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

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          347

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe