Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.6k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.1k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.8k

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

Geplant Angeheftet Gesperrt Verschoben ioBroker скрипты
358 Beiträge 29 Kommentatoren 108.8k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • S Offline
    S Offline
    smoker_vvo
    schrieb am zuletzt editiert von
    #323

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

    1 Antwort Letzte Antwort
    0
    • S Offline
      S Offline
      smoker_vvo
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      0
      • I Offline
        I Offline
        instalator
        schrieb am zuletzt editiert von
        #325

        @smoker_vvo:

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

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

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

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

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

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

        http://blog.instalator.ru/

        1 Antwort Letzte Antwort
        0
        • S Offline
          S Offline
          smoker_vvo
          schrieb am zuletzt editiert von
          #326

          как?

          1 Antwort Letzte Antwort
          0
          • BluefoxB Offline
            BluefoxB Offline
            Bluefox
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • BluefoxB Offline
              BluefoxB Offline
              Bluefox
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              0
              • V Offline
                V Offline
                ValG
                schrieb am zuletzt editiert von
                #329

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

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

                1 Antwort Letzte Antwort
                0
                • H Offline
                  H Offline
                  Haus
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  0
                  • A Offline
                    A Offline
                    Adav
                    schrieb am zuletzt editiert von
                    #331

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

                    1 Antwort Letzte Antwort
                    0
                    • I Offline
                      I Offline
                      instalator
                      schrieb am zuletzt editiert von
                      #332

                      @Adav:

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

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

                      http://blog.instalator.ru/

                      1 Antwort Letzte Antwort
                      0
                      • A Offline
                        A Offline
                        Adav
                        schrieb am zuletzt editiert von
                        #333

                        @instalator:

                        @Adav:

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

                        1 Antwort Letzte Antwort
                        0
                        • S Offline
                          S Offline
                          spectrekr
                          schrieb am zuletzt editiert von
                          #334

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

                          1 Antwort Letzte Antwort
                          0
                          • A Offline
                            A Offline
                            Adav
                            schrieb am zuletzt editiert von
                            #335

                            @spectrekr:

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

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

                            1 Antwort Letzte Antwort
                            0
                            • I Offline
                              I Offline
                              instalator
                              schrieb am zuletzt editiert von
                              #336

                              @spectrekr:

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

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

                              http://blog.instalator.ru/

                              1 Antwort Letzte Antwort
                              0
                              • A Offline
                                A Offline
                                Adav
                                schrieb am zuletzt editiert von
                                #337

                                @instalator:

                                @spectrekr:

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

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

                                1 Antwort Letzte Antwort
                                0
                                • S Offline
                                  S Offline
                                  spectrekr
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • I Offline
                                    I Offline
                                    instalator
                                    schrieb am zuletzt editiert von
                                    #339

                                    @Adav:

                                    @instalator:

                                    @spectrekr:

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

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

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

                                    http://blog.instalator.ru/

                                    1 Antwort Letzte Antwort
                                    0
                                    • A Offline
                                      A Offline
                                      Adav
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • A Offline
                                        A Offline
                                        andrey99986
                                        schrieb am zuletzt editiert von
                                        #341

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

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

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

                                        1 Antwort Letzte Antwort
                                        0
                                        • H Offline
                                          H Offline
                                          Haba
                                          schrieb am zuletzt editiert von
                                          #342

                                          оно?

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

                                          "enabled": true,

                                                 "changesOnly": true,
                                                  "debounce": 1000,
                                                  "retention": 31536000,
                                                  "changesRelogInterval": 0,
                                                  "changesMinDelta": "",
                                                  "storageType": ""
                                                }
                                              }
                                            },
                                            "native": {
                                              "id": "61",
                                              "childId": "255",
                                              "subType": "S_ARDUINO_NODE",
                                              "subTypeNum": 17,
                                              "varType": "I_BATTERY_LEVEL",
                                              "varTypeNum": 0
                                            },
                                            "type": "state",
                                            "acl": {
                                              "object": 1638,
                                              "state": 1638
                                            }
                                          }
                                          
                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          828

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe