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
    649

  • 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.
  • S Offline
    S Offline
    smoker_vvo
    wrote on last edited by
    #321

    Благодарствуем!

    1 Reply Last reply
    0
    • S Offline
      S Offline
      smoker_vvo
      wrote on last edited by
      #322

      Все бы ничего, только версии 3.3.6 в обновлении нет….

      Adapter    "knx"           : 0.8.3
      Adapter    "km200"         : 0.4.3
      Controller "js-controller" : 1.0.0    , installed 1.0.0
      Adapter    "javascript"    : 3.2.6    , installed 3.2.6
      Adapter    "innogy-smarthome": 0.1.17
      Adapter    "influxdb"      : 1.4.3
      
      1 Reply Last reply
      0
      • S Offline
        S Offline
        smoker_vvo
        wrote on last edited by
        #323

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

        1 Reply Last reply
        0
        • S Offline
          S Offline
          smoker_vvo
          wrote on last edited by
          #324

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

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

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

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

          // Erstellen der Variablen
          createState('Alarm.Pumpe.offen.Grenzwert', 2, {
              name: 'Время двери сигнализации открыт',
              desc: 'Время не сообщается в течение нескольких минут, пока открыты двери',
              type: 'number',
              unit: 'min'
          });
          var idWohnungstuerGrenzwert = 3,
              idWohnungstuer = "javascript.0.Arduino3.DI"; // kann auch TFK mit STATE sein
          
          // Funktion von ruhr70 zur Wiederholung
          // http://forum.iobroker.net/viewtopic.php?f=21&p=28068#p28068
          function wiederholungAnsage() {
              sendTo("telegram.0", 'Дверь все еще открыта!');
              log('В квартире дверь все еще открыта еще минуту. Пожалуйста, закройте!');
          }
          
          // обнаружение открытых дверей (JavaScript Variante triggert über Statusvariable, nicht TFK selbst)
          var timer = null;
          on(idWohnungstuer, function(obj) {
              var grenzwert = parseInt(getState(idWohnungstuerGrenzwert).val,10),meldung;
                  if (obj.state.val === true) { // Дверь открыта
                  if (!timer) {
                      log('Дверь: Таймер двери запущен (2min)');
                      timer = setTimeout(function () { // таймер запускается
                          if(timer) clearTimeout(timer);
                          timer = null;
                          timer = setInterval(wiederholungAnsage, 60000);
                          sendTo("telegram.0", 'Дверь открыта!');
                          setState("sayit.0.tts.text", "ru;100;" + 'Дверь открыта!');
                          meldung = 'Входная дверь для 2 мин открыт!';
                          log(meldung);
                          log('Timer');
                      }, grenzwert * 60 * 1000); //Таймер в течение нескольких минут
                  } // Запрос End таймера
              } else { // Дверь закрылась, таймер останавливается
                  if (timer) {
                      clearTimeout(timer);
                      clearInterval(timer);
                      timer = null;
                      sendTo("telegram.0", 'Таймер двери квартиры остановился.');
                      meldung = 'Дверь: Таймер двери остановлен';
                  }
                  log(meldung);
                  log('End');
              } // Конец состояния двери запроса
          });
          
          
          1 Reply Last reply
          0
          • I Offline
            I Offline
            instalator
            wrote on last edited by
            #325

            @smoker_vvo:

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

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

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

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

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

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

            http://blog.instalator.ru/

            1 Reply Last reply
            0
            • S Offline
              S Offline
              smoker_vvo
              wrote on last edited by
              #326

              как?

              1 Reply Last reply
              0
              • BluefoxB Offline
                BluefoxB Offline
                Bluefox
                wrote on last edited by
                #327
                
                var counterId = 'motorTimeCounter'; // имя переменной счётчика. Появится в "javascript.0.motorTimeCounter"
                createState(counterId, {common: {type: 'number', unit: 'sec'}}, 0); // создаём, если надо переменную
                
                on('motor.state', function (obj) { // при изменении состояния мотора
                	if (!obj.state.val && obj.stateOld && obj.stateOld.val) { // если состояние изменилось с ON => OFF то 
                		var timeMs = obj.state.ts - obj.stateOld.ts; // считаем время 
                		setState(counterId, getState(counterId).val + timeMs / 1000, true); // и добавляем к существующему
                	}
                });
                
                1 Reply Last reply
                0
                • BluefoxB Offline
                  BluefoxB Offline
                  Bluefox
                  wrote on last edited by
                  #328

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

                  ! ````
                  <xml xmlns="http://www.w3.org/1999/xhtml"><block type="create" id="svECADP@D_LS~g[6T?n." x="13" y="63"><field name="NAME">motorCounter</field>
                  <statement name="STATEMENT"><block type="on_ext" id="OzG(WNC}y*:JL:!bvMgN"><mutation items="1"></mutation>
                  <field name="CONDITION">false</field>
                  <field name="ACK_CONDITION">true</field>
                  <value name="OID0"><shadow type="field_oid" id="aPODLp31t6i%07OAjKcc"><field name="oid">javascript.0.boolTest</field></shadow></value>
                  <statement name="STATEMENT"><block type="controls_if" id="N(GTE?/Qq^tiAefHhGo"><value name="IF0"><block type="logic_compare" id="1ySRjIFq!qlsFEikh@9."><field name="OP">EQ</field>
                  <value name="A"><block type="on_source" id="5,uId0is]chxW+2tq,l5"><field name="ATTR">oldState.val</field></block></value>
                  <value name="B"><block type="logic_boolean" id="p+knOuq|Bhhp6[N0+d-A"><field name="BOOL">TRUE</field></block></value></block></value>
                  <statement name="DO0"><block type="update" id="l-EoA#o@sAQW=i;.knE9"><mutation delay_input="false"></mutation>
                  <field name="OID">javascript.0.motorCounter</field>
                  <field name="WITH_DELAY">FALSE</field>
                  <value name="VALUE"><block type="math_arithmetic" id=")}{oRaa%=9fTN
                  .0g@,="><field name="OP">ADD</field>
                  <value name="A"><shadow type="math_number" id=",f%0CvZv9qk(sbd:-hmI"><field name="NUM">1</field></shadow>
                  <block type="get_value" id="Ty#h:khrIoRj/Wm@w0Q-"><field name="ATTR">val</field>
                  <field name="OID">javascript.0.motorCounter</field></block></value>
                  <value name="B"><shadow type="math_number" id="E7v{Kyc.pPHl^|bohgU"><field name="NUM">1</field></shadow> <block type="math_arithmetic" id="~#~514BVd(vQsjrm6-?G"><field name="OP">DIVIDE</field> <value name="A"><shadow type="math_number" id="n7-[AqhR8fGgSg6M.=cW"><field name="NUM">1</field></shadow> <block type="math_arithmetic" id="M^d?]c-+!gs%M-AWNeMk"><field name="OP">MINUS</field> <value name="A"><shadow type="math_number" id=".fyZQ/wCR9IY9MmQ=X2_"><field name="NUM">1</field></shadow> <block type="on_source" id="+1R15yCYBce/A]wmSd7b"><field name="ATTR">state.ts</field></block></value> <value name="B"><shadow type="math_number" id="xd?;d7uEQ@Fmh=%Oo(-"><field name="NUM">1</field></shadow>
                  <block type="on_source" id="[Wn~yS.QQ|AZev|iD,v0"><field name="ATTR">oldState.ts</field></block></value></block></value>
                  <value name="B"><shadow type="math_number" id="S-T+6}o-dVpjnGakd!K!"><field name="NUM">1000</field></shadow></value></block></value></block></value></block></statement></block></statement></block></statement></block></xml>

                  1 Reply Last reply
                  0
                  • V Offline
                    V Offline
                    ValG
                    wrote on last edited by
                    #329

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

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

                    1 Reply Last reply
                    0
                    • H Offline
                      H Offline
                      Haus
                      wrote on last edited by
                      #330

                      @ValG:

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

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

                      blockly

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

                      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
                      • A Offline
                        A Offline
                        Adav
                        wrote on last edited by
                        #331

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

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

                          @Adav:

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

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

                          http://blog.instalator.ru/

                          1 Reply Last reply
                          0
                          • A Offline
                            A Offline
                            Adav
                            wrote on last edited by
                            #333

                            @instalator:

                            @Adav:

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

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

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

                              1 Reply Last reply
                              0
                              • A Offline
                                A Offline
                                Adav
                                wrote on last edited by
                                #335

                                @spectrekr:

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

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

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

                                  @spectrekr:

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

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

                                  http://blog.instalator.ru/

                                  1 Reply Last reply
                                  0
                                  • A Offline
                                    A Offline
                                    Adav
                                    wrote on last edited by
                                    #337

                                    @instalator:

                                    @spectrekr:

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

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

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

                                      ! ````
                                      var fs = require('fs');
                                      var date = formatDate(new Date(res.result[0].ReceivingDateTime), 'YYYY-MM-DD');
                                      readFile ('/opt/iobroker/log/iobroker.log.'+date, function (error, bytes) {
                                      if(bytes.indexOf('Ошибка') > 0){
                                      exec('/bin/bash /opt/iobroker/tmp/restart.sh');
                                      }
                                      })

                                      Примерно так.
                                      1 Reply Last reply
                                      0
                                      • I Offline
                                        I Offline
                                        instalator
                                        wrote on last edited by
                                        #339

                                        @Adav:

                                        @instalator:

                                        @spectrekr:

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

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

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

                                        http://blog.instalator.ru/

                                        1 Reply Last reply
                                        0
                                        • A Offline
                                          A Offline
                                          Adav
                                          wrote on last edited by
                                          #340

                                          Вернулся к вопросу с рестартом сервиса nut (о чем выше). Спасибо spectrekr и instalator за два варианта решения проблемы. Но я нашел третий вариант, на мой взгляд проще. Отслеживается одна из переменных (в принципе любая, но лучше константа), приходящих от драйвера nut, и если она не обновлялась дольше, чем два цикла опроса (в моем случае цикл 5 сек), то идет команда на рестарт сервиса на удаленном сервере. Вроде работает… В скрипте это так (может кому пригодится):

                                          //---------------------------Restart nut------------------
                                          var nut_timer_timeout_ms = 12 * 1000;
                                          var nut_timer_id = null;
                                          
                                          on({id: "nut.0.input.transfer-low", change: "eq"}, function (obj) { 
                                          if (nut_timer_id) {
                                              clearTimeout(nut_timer_id);
                                                            }
                                              nut_timer_id = setTimeout(function () {
                                                 exec('ssh root@192.168.118.115 service nut-driver restart');       
                                                 sendTo('telegram.0', {
                                                    text:'Сервис NUT на сервере System завис и перезагружен.',
                                                    disable_notification:   true
                                              });          
                                              nut_timer_id = null;   
                                             	}, nut_timer_timeout_ms);      
                                          });
                                          
                                          1 Reply Last reply
                                          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

                                          304

                                          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