Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Servicemeldungen in vis

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Servicemeldungen in vis

    This topic has been deleted. Only users with topic management privileges can see it.
    • P
      pix last edited by Negalein

      Mit dem HTML-Widget geht das so: 261_bildschirmfoto_2016-03-04_um_13.25.39.jpg

      Hier sind meine Widgets für den UNREACH Datenpunkt. Sind zwei übereinander. Musst die Datenpunkte anpassen, habe eine etwas anderen Ordnerstruktur.

      Datenpunkt Anzahl und Datenpunkt Text sind relevant

      [{"tpl":"tplMetroTileString","data":{"visibility-cond":"==","visibility-val":1,"bg_class_true":"ribbed-yellow","bg_class_false":"bg-transparent","icon_class_true":"icon-thumbs-down","icon_class_false":"icon-thumbs-up","badge_bg_class_true":"","badge_bg_class_false":"","icon_badge_true":"","icon_badge_false":"","brand_bg_class_true":"","brand_bg_class_false":"","name":"Unreach","visibility-oid":"","content_prepend":"Unreach  ","content_append":"","content_oid":"javascript.0.Servicemeldungen.Homematic.UNREACH.Anzahl","label_prepend":"von ","label_append":" Geräten","label_id":"javascript.0.Servicemeldungen.Homematic.UNREACH.moegliche","state_oid":"javascript.0.Servicemeldungen.Homematic.UNREACH.Anzahl","transform":false,"select_on_true":false,"icon":"/vis.0/main/img/schritte.png","icon_width":"50%","icon_height":"50%","icon_false":"","icon_top":"52","icon_left":"44","hover":false,"badge_top":"0","badge_left":"0","gestures-offsetX":0,"gestures-offsetY":0,"gestures-swiping-value":"","gestures-rotating-value":"","gestures-pinching-value":"","gestures-swipeRight-value":"","gestures-swipeLeft-value":"","gestures-swipeUp-value":"","gestures-swipeDown-value":"","gestures-rotateLeft-value":"","gestures-rotateRight-value":"","gestures-pinchIn-value":"","gestures-pinchOut-value":""},"style":{"left":"222px","top":"363px","width":"137px","height":"137px","z-index":"15","font-family":"","color":"","font-size":""},"widgetSet":"metro"},{"tpl":"tplMetroTileDialogStatic","data":{"visibility-cond":"==","visibility-val":1,"hover":false,"transform":"true","bg_class":"bg-transparent","icon_class":"","icon_badge":"","badge_bg_class":"","brand_bg_class":"","dialog_draggable":"true","dialog_icon_class":"","name":"Unreach Dialog liegt oben","label":"","content_oid":"","html":"{javascript.0.Servicemeldungen.Homematic.UNREACH.Text}","dialog_width":"800px","dialog_height":"500px","dialog_title":"CCU Kommunikationsstörungen","dialog_shadow":true,"gestures-offsetX":0,"gestures-offsetY":0,"gestures-swiping-value":"","gestures-rotating-value":"","gestures-pinching-value":"","gestures-swipeRight-value":"","gestures-swipeLeft-value":"","gestures-swipeUp-value":"","gestures-swipeDown-value":"","gestures-rotateLeft-value":"","gestures-rotateRight-value":"","gestures-pinchIn-value":"","gestures-pinchOut-value":""},"style":{"left":"222px","top":"363px","z-index":"30","width":"137px","height":"137px"},"widgetSet":"metro"}]
      

      Gruß,

      Pix

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

        Hallo Pix,

        ich habe dein Script für Servicemeldungen in er Verwendung. Alles funktioniert soweit super.

        Allerdings bekomme ich die Servicemeldungen immer so angezeigt:

        m-rpc.0.LEQ1112192.0.CONFIG_PENDING,

        hm-rpc.0.MEQ0211699.0.CONFIG_PENDING,

        Hast du für mich eine Idee wie ich diese Meldungen im Klartext mit dem dazugehörigen Namen auslesen kann?

        Gruß Sven

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

          Hallo,

          @Sven2013:

          Hallo Pix,

          ich habe dein Script für Servicemeldungen in er Verwendung. Alles funktioniert soweit super.

          Allerdings bekomme ich die Servicemeldungen immer so angezeigt:

          m-rpc.0.LEQ1112192.0.CONFIG_PENDING,

          hm-rpc.0.MEQ0211699.0.CONFIG_PENDING,

          Hast du für mich eine Idee wie ich diese Meldungen im Klartext mit dem dazugehörigen Namen auslesen kann?

          Gruß Sven `

          ich habe das selbe Problem, gibt es da für eine Lösung ?

          Lg Mike

          1 Reply Last reply Reply Quote 0
          • P
            pix last edited by

            Welches Skript nutzt du genau? Kannst du das hier nochmal (in Code-Tags und ggf. Spoiler-Tags) posten?

            Dann kann man es anpassen.

            Gruß

            Pix

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

              Hallo,

              @pix:

              Welches Skript nutzt du genau? Kannst du das hier nochmal (in Code-Tags und ggf. Spoiler-Tags) posten?

              Dann kann man es anpassen.

              Gruß

              Pix `

              denke das ist das aktuellste hier aus diesem Thread.

              /*  System Homematic Servicemeldungen
              Skript erstellt Variablen Service.Homematic.*
              http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153
              
              erstellt: 04.08.2015 von paul53
              angepasst von pix
              05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173
              04.02.2016 Instanz Variable
              */
              
              instanz = 'javascript.0.';
              
              // Service Meldungen
              
              createState('Servicemeldungen.Homematic.Anzahl', 0, {
                  name: 'Homematic Servicemeldungen Anzahl',
                  desc: 'Zahl der Homematic Servicemeldungen',
                  type: 'number'
              });
              createState('Servicemeldungen.Homematic.Text', "", {
                  name: 'Homematic Servicemeldungen Text',
                  desc: 'Liste der Geräte, die Servicemeldungen produzieren',
                  type: 'string'
              });
              
              var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl',
                  idText =   instanz + 'Servicemeldungen.Homematic.Text';
              
              var SelectorUNREACH = $('channel[state.id=*.UNREACH]');
              var SelectorSTICKY_UNREACH = $('channel[state.id=*.STICKY_UNREACH]');
              var SelectorLOWBAT = $('channel[state.id=*.LOWBAT]');
              var SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]');
              
              function countService(obj) {
                  var anzahl    = 0;
                  var text      = "";
              
                  function count(id) {
                      var status = getState(id).val;                // Zustand abfragen (jedes Element)
                      if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                          text = text + id + ",
              ";                   // Zu String hinzufügen
                          ++anzahl;                                  // Zählt die Anzahl der Service-Alarme
                      }
                  }
              
                  SelectorUNREACH.each(function (id, i) {
                      count(id);
                   });
              
                  SelectorSTICKY_UNREACH.each(function (id, i) {
                      var status = getState(id).val;                // Zustand abfragen (jedes Element)
                      if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                          log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true> gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.');
                          setState(id, false); // STICKY_UNREACH werden gelöscht
                      }
                  });
              
                  SelectorLOWBAT.each(function (id, i) {
                      count(id);
                  });
              
                  SelectorCONFIG_PENDING.each(function (id, i) {
                      count(id);
                  });
              
                  // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben
                  log("Homematic-Servicemeldungen: " + text);
                  log("Anzahl Homematic-Servicemeldungen: " + anzahl);
              
                  // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert 
                  if (!anzahl) { 
                      text = "keine Servicemeldungen";
                  }
                  setState(idText, text);          // Schreibt die IDs der Datenpunkte mit Service Meldung
                  setState(idAnzahl, anzahl);      // Schreibt die aktuelle Anzahl der Service Meldungen
              }   
              
              SelectorUNREACH.on(function(obj) {          // bei Zustandänderung *.UNREACH in allen Gewerken
                  countService(obj);
              });
              
              SelectorSTICKY_UNREACH.on(function(obj) {   // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken
                  countService(obj);
              });
              
              SelectorLOWBAT.on(function(obj) {          // bei Zustandänderung *.LOWBAT in allen Gewerken
                  countService(obj);
              });
              
              SelectorCONFIG_PENDING.on(function(obj) {   // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken
                  countService(obj);
              });
              
              // alternative Abfrage jede Minute
              schedule("*/15 * * * *", function () {
                  countService();
              });
              
              // Ausführung bei Scriptstart
              countService();</true>
              

              Lg Mike

              1 Reply Last reply Reply Quote 0
              • P
                pix last edited by Negalein

                Hallo Mike,

                ersetze mal Zeile 41

                text = text + id + ",
                ";                   // Zu String hinzufügen
                

                durch

                text = text + getObject(id).common.name + ",
                ";
                

                Gruß

                Pix

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

                  Moin Pix,

                  super - das war's.

                  Ich habe für mich noch eine kleine Änderung eingebaut :

                  Es wird nur der Text bis zum Doppelpunkt ausgegeben - somit entfällt die Kanalnummer.

                  Die Meldung als solches habe ich dann wieder abgefangen und angehängt.

                  Daraus ergibt sich bei mir eine Meldung wie "Terrasse_Markise ==> UNREACH".

                  Hier die überarbeitete Funktion "count" (ab Zeilen 38 bis 44 aus dem Originalscript) :

                      function count(id) {
                          var status = getState(id).val;                // Zustand abfragen (jedes Element)
                          if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                              var temptext = getObject(id).common.name;
                              var Geraet = temptext.split(':');
                              text = text + Geraet[0] + " ==> ";
                              temptext = Geraet[1];
                              Geraet = temptext.split('.');
                              text = text + Geraet[1] + "
                  ";
                              ++anzahl;                                  // Zählt die Anzahl der Service-Alarme
                          }
                      }
                  
                  

                  Gruß,

                  Eric

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

                    vielen Dank Pix,

                    @pix:

                    Hallo Mike,

                    ersetze mal Zeile 41

                    text = text + id + ",
                    ";                   // Zu String hinzufügen
                    ````durch
                    

                    text = text + getObject(id).common.name + ",
                    ";

                    
                    Gruß
                    
                    Pix `  
                    

                    funktioniert.

                    Lg Mike

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

                      Kann es sein, dass sich das Skript selbst triggert?

                      Es wird immer eine "Sticky Unreach" Meldung pro Durchlauf weniger.

                      Am Ende läuft das Skript pro Schedul bei mir 20mal und erzeugt u.a. Fehler.

                      Es werden nach Restart des ioBrokers um 4:00 bei mir ca. 20.000 Zeilen Debug von diesen Skript erzeugt!

                      2016-10-08 04:24:41.387  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Homematic-Servicemeldungen: VD-02:0.UNREACH,
                      
                      2016-10-08 04:24:41.388  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Anzahl Homematic-Servicemeldungen: 1
                      2016-10-08 04:24:41.606  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0381127.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:41.607  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0381249.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:41.609  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0288775.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:41.612  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Homematic-Servicemeldungen: VD-02:0.UNREACH,
                      
                      2016-10-08 04:24:41.613  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Anzahl Homematic-Servicemeldungen: 1
                      2016-10-08 04:24:41.970  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0381127.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:41.972  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0381249.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:41.975  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Homematic-Servicemeldungen: VD-02:0.UNREACH,
                      
                      2016-10-08 04:24:41.977  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Anzahl Homematic-Servicemeldungen: 1
                      2016-10-08 04:24:42.251  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0381249.0.STICKY_UNREACH wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreicc
                      hbar.
                      2016-10-08 04:24:42.254  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Homematic-Servicemeldungen: VD-02:0.UNREACH,
                      
                      2016-10-08 04:24:42.255  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Anzahl Homematic-Servicemeldungen: 1
                      2016-10-08 04:24:42.498  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Homematic-Servicemeldungen: VD-02:0.UNREACH,
                      
                      2016-10-08 04:24:42.499  - ^[[32minfo^[[39m: javascript.0 script.js.servicemeldungen: Anzahl Homematic-Servicemeldungen: 1
                      2016-10-08 04:24:49.849  - ^[[32minfo^[[39m: hm-rpc.0 setValue ["HEQ0113716:0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.854  - ^[[32minfo^[[39m: hm-rpc.0 setValue ["HEQ0133715:0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.859  - ^[[32minfo^[[39m: hm-rpc.0 setValue ["HEQ0133983:0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.860  - ^[[31merror^[[39m: hm-rpc.0 binrpc -> setValue ["0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.861  - ^[[31merror^[[39m: hm-rpc.0 Error: You are sending too fast
                      2016-10-08 04:24:49.863  - ^[[32minfo^[[39m: hm-rpc.0 setValue ["HEQ0134546:0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.864  - ^[[31merror^[[39m: hm-rpc.0 binrpc -> setValue ["0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.864  - ^[[31merror^[[39m: hm-rpc.0 Error: You are sending too fast
                      2016-10-08 04:24:49.867  - ^[[32minfo^[[39m: hm-rpc.0 setValue ["HEQ0145780:0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.868  - ^[[31merror^[[39m: hm-rpc.0 binrpc -> setValue ["0","STICKY_UNREACH",false] BOOL
                      2016-10-08 04:24:49.868  - ^[[31merror^[[39m: hm-rpc.0 Error: You are sending too fast</true></true></true></true></true></true> 
                      
                      1 Reply Last reply Reply Quote 0
                      • H
                        Harry-IO-HM last edited by

                        dito, bei mir auch

                        Log voll von…

                        hm-rpc-0	2016-10-23 12:19:00.355	error	Error: You are sending too fast
                        hm-rpc-0	2016-10-23 12:19:00.345	error	binrpc -> setValue ["0","STICKY_UNREACH",false] BOOL
                        
                        1 Reply Last reply Reply Quote 0
                        • P
                          PrinzEisenherz1 last edited by

                          Hi zusammen!

                          Ich nutze aus dem Thread folgendes Script

                          ! ````
                          /* System Homematic Servicemeldungen
                          Skript erstellt Variablen Service.Homematic.*
                          http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153
                          ! erstellt: 04.08.2015 von paul53
                          angepasst von pix
                          05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173
                          04.02.2016 Instanz Variable
                          /
                          ! instanz = 'javascript.0.';
                          var logging = true;
                          // Service Meldungen
                          ! createState('Servicemeldungen.Homematic.Anzahl', 0, {
                          name: 'Homematic Servicemeldungen Anzahl',
                          desc: 'Zahl der Homematic Servicemeldungen',
                          type: 'number'
                          });
                          createState('Servicemeldungen.Homematic.Text', "", {
                          name: 'Homematic Servicemeldungen Text',
                          desc: 'Liste der Geräte, die Servicemeldungen produzieren',
                          type: 'string'
                          });
                          ! var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl',
                          idText = instanz + 'Servicemeldungen.Homematic.Text';
                          ! var SelectorUNREACH = $('channel[state.id=
                          .UNREACH]');
                          var SelectorSTICKY_UNREACH = $('channel[state.id=.STICKY_UNREACH]');
                          var SelectorLOWBAT = $('channel[state.id=
                          .LOWBAT]');
                          var SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]');
                          ! function countService(obj) {
                          var anzahl = 0;
                          var text = "";
                          ! function count(id) {
                          var status = getState(id).val; // Zustand abfragen (jedes Element)
                          if (status) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                          var temptext = getObject(id).common.name;
                          var Geraet = temptext.split(':');
                          text = text + Geraet[0] + " ==> ";
                          temptext = Geraet[1];
                          Geraet = temptext.split('.');
                          text = text + Geraet[1] + "
                          ";
                          ++anzahl; // Zählt die Anzahl der Service-Alarme
                          }
                          }
                          ! SelectorUNREACH.each(function (id, i) {
                          count(id);
                          });

                          SelectorSTICKY_UNREACH.each(function (id, i) {
                              var status = getState(id).val;                // Zustand abfragen (jedes Element)
                              if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                          if (logging) log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true>gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.');
                                  setState(id, false); // STICKY_UNREACH werden gelöscht
                              }
                          });
                          
                          SelectorLOWBAT.each(function (id, i) {
                              count(id);
                          });
                          
                          SelectorCONFIG_PENDING.each(function (id, i) {
                              count(id);
                          });
                          

                          ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben
                          if (logging) log("Homematic-Servicemeldungen: " + text);
                          if (logging) log("Anzahl Homematic-Servicemeldungen: " + anzahl);
                          ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert
                          if (!anzahl) {
                          text = "Es liegen keine Servicemeldungen vor !!";
                          }
                          setState(idText, text); // Schreibt die IDs der Datenpunkte mit Service Meldung
                          setState(idAnzahl, anzahl); // Schreibt die aktuelle Anzahl der Service Meldungen
                          }
                          ! SelectorUNREACH.on(function(obj) { // bei Zustandänderung *.UNREACH in allen Gewerken
                          countService(obj);
                          });
                          ! SelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken
                          countService(obj);
                          });
                          ! SelectorLOWBAT.on(function(obj) { // bei Zustandänderung *.LOWBAT in allen Gewerken
                          countService(obj);
                          });
                          ! SelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung .CONFIG_PENDING in allen Gewerken
                          countService(obj);
                          });
                          ! // alternative Abfrage jede Minute
                          schedule("
                          /15 * * * *", function () {
                          countService();
                          });
                          ! // Ausführung bei Scriptstart
                          countService();</true>

                          
                          Leider werden bei mir bei einer LowBat-Meldung 2 Warnungen angezeigt (von ein und dem selben Gerät)
                          

                          14:50:53.716 [info] javascript.0 script.js.Servicemeldungen: Homematic-Servicemeldungen: Fenster Küche ==> LOWBAT
                          HM-Sec-RHS LEQXXXXXXXX ==> LOWBAT
                          14:50:53.717 [info] javascript.0 script.js.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 2
                          14:50:53.719 [info] javascript.0 script.js.Servicemeldungen: registered 209 subscriptions and 1 schedule

                          
                          Es sind bei mir also nicht zwei unterschiedliche Geräte die angezeigt bzw gezählt werden, sondern ein und das selbe!
                          
                          Wie kann ich das Script ändern das mir das Gerät nur als "Fenster Küche" angezeigt wird und nicht zusätzlich als HM-Sec-RHS LEQXXXXXXXX ?
                          
                          Es stimmt somit auch die Anzahl der LowBat-Meldung. Es müsste eine und nicht zwei sein.
                          
                          Des weiteren ist bei mir der Log auch voll von dem StickyUnreach. Wie bei den anderen Jungs vorher!
                          
                          Gruß
                          
                          Johnny
                          1 Reply Last reply Reply Quote 0
                          • P
                            PrinzEisenherz1 last edited by

                            Hat hier keiner ne Idee was ich da im Script ändern muss das mir das Gerät nur einmal angezeigt wird?

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

                              Hallo Johnny,

                              ich kann leider nicht helfen, da ich grade die selben Probleme damit habe wie du sie beschreibst.

                              Ich habe versucht das Script so zu ändern, das nur noch die Geräte und die Fehlermeldung angereicht werden.

                              Also z.B. Bewegungsmelder - Batterie leer

                              Bei jedem Versuch von mir, habe ich nur noch Fehlermeldungen und dass Script läuft nicht mehr durch.

                              Gruß Sven

                              Gesendet von iPhone mit Tapatalk

                              1 Reply Last reply Reply Quote 0
                              • P
                                PrinzEisenherz1 last edited by

                                Hi Sven,

                                Fehlermeldungen hab ich keine (oder meinst du die unreach?) aber hald die doppelten Batterie leer Nachrichten!

                                Ist aber nur bei Batterie leer der Fall. Zumindest ist es mir da aufgefallen

                                Gruß

                                Johnny

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

                                  Hi, die Fehlermeldung habe ich auch nur wenn ich versuche das Script umzubauen bez. (Aktor - Meldung)

                                  Die doppelten Nachrichten habe ich auch nur bei leeren Batterien.

                                  Gruß Sven

                                  Gesendet von iPhone mit Tapatalk

                                  1 Reply Last reply Reply Quote 0
                                  • P
                                    PrinzEisenherz1 last edited by

                                    hmmm…vielleicht kann sich jemand erbarmen und uns da helfen fg 😉

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

                                      Hallo,

                                      zur Info - habe countid() leicht verändert:

                                      • Komma entfernt

                                      • doppelte Meldungen (z.B. bzgl. LOWBAT) unterdrückt

                                              function count(id) {
                                              var status = getState(id).val;                // Zustand abfragen (jedes Element)
                                              if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                  var dev = getObject(id).common.name;  // device name laden
                                                  var newText = dev.substring(0,dev.indexOf(":")); // erstelle neuen Text - hier : Device Name
                                                  newText = newText + " " + dev.substring(dev.indexOf(".") +1 ); // erstelle neuen Text: hier: Kanalname
                                                  if (text.indexOf(newText) == -1) { // nur wenn das Device/Kanalname noch nicht bereits im Fehlerstring
                                                      text = text + newText + "
                                      ";                   // Zu String hinzufügen
                                                      ++anzahl;                                  // Zählt die Anzahl der Service-Alarme
                                                  }
                                              }
                                          }
                                      
                                      1 Reply Last reply Reply Quote 0
                                      • Z
                                        Zippolighter last edited by

                                        Brauche zu dem Thema bitte Eure hilfe

                                        Habe folgendes Script am laufen (zusammengebaut aus den Stücken hier)

                                        /*  System Homematic Servicemeldungen
                                        Skript erstellt Variablen Service.Homematic.*
                                        http://forum.iobroker.org/viewtopic.php?f=21&t=914#p9153
                                        
                                        erstellt: 04.08.2015 von paul53
                                        angepasst von pix
                                        05.10.2015 STICKY UNREACH wird jetzt auf true gesetzt und damit gelöscht http://forum.iobroker.org/viewtopic.php?f=21&t=914&p=9200&hilit=sticky#p9173
                                        04.02.2016 Instanz Variable
                                        */
                                        
                                        instanz = 'javascript.0.';
                                        
                                        // Service Meldungen
                                        
                                        createState('Servicemeldungen.Homematic.Anzahl', 0, {
                                            name: 'Homematic Servicemeldungen Anzahl',
                                            desc: 'Zahl der Homematic Servicemeldungen',
                                            type: 'number'
                                        });
                                        createState('Servicemeldungen.Homematic.Text', "", {
                                            name: 'Homematic Servicemeldungen Text',
                                            desc: 'Liste der Geräte, die Servicemeldungen produzieren',
                                            type: 'string'
                                        });
                                        
                                        var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl',
                                            idText =   instanz + 'Servicemeldungen.Homematic.Text';
                                        
                                        var SelectorUNREACH = $('channel[state.id=*.UNREACH]');
                                        var SelectorSTICKY_UNREACH = $('channel[state.id=*.STICKY_UNREACH]');
                                        var SelectorLOWBAT = $('channel[state.id=*.LOWBAT]');
                                        var SelectorCONFIG_PENDING = $('channel[state.id=*.CONFIG_PENDING]');
                                        
                                        function countService(obj) {
                                            var anzahl    = 0;
                                            var text      = "";
                                        
                                                function count(id) {
                                                var status = getState(id).val;                // Zustand abfragen (jedes Element)
                                                if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                    var dev = getObject(id).common.name;  // device name laden
                                                    var newText = dev.substring(0,dev.indexOf(":")); // erstelle neuen Text - hier : Device Name
                                                    newText = newText + " " + dev.substring(dev.indexOf(".") +1 ); // erstelle neuen Text: hier: Kanalname
                                                    if (text.indexOf(newText) == -1) { // nur wenn das Device/Kanalname noch nicht bereits im Fehlerstring
                                                        text = text + newText + "
                                        ";                   // Zu String hinzufügen
                                                        ++anzahl;                                  // Zählt die Anzahl der Service-Alarme
                                                    }
                                                }
                                            } 
                                            SelectorUNREACH.each(function (id, i) {
                                                count(id);
                                             });
                                        
                                            SelectorSTICKY_UNREACH.each(function (id, i) {
                                                var status = getState(id).val;                // Zustand abfragen (jedes Element)
                                                if (status) {                        // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                    log('STICKY_UNREACH Meldung: ' + id + ' wurde auf <true> gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.');
                                                    setState(id, false); // STICKY_UNREACH werden gelöscht
                                                }
                                            });
                                        
                                            SelectorLOWBAT.each(function (id, i) {
                                                count(id);
                                            });
                                        
                                            SelectorCONFIG_PENDING.each(function (id, i) {
                                                count(id);
                                            });
                                        
                                            // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon Service zutreffend) ausgegeben
                                            log("Homematic-Servicemeldungen: " + text);
                                            log("Anzahl Homematic-Servicemeldungen: " + anzahl);
                                        
                                            // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert 
                                            if (!anzahl) { 
                                                text = "keine Servicemeldungen";
                                            }
                                            setState(idText, text);          // Schreibt die IDs der Datenpunkte mit Service Meldung
                                            setState(idAnzahl, anzahl);      // Schreibt die aktuelle Anzahl der Service Meldungen
                                        }   
                                        
                                        SelectorUNREACH.on(function(obj) {          // bei Zustandänderung *.UNREACH in allen Gewerken
                                            countService(obj);
                                        });
                                        
                                        SelectorSTICKY_UNREACH.on(function(obj) {   // bei Zustandänderung *.STICKY_UNREACH in allen Gewerken
                                            countService(obj);
                                        });
                                        
                                        SelectorLOWBAT.on(function(obj) {          // bei Zustandänderung *.LOWBAT in allen Gewerken
                                            countService(obj);
                                        });
                                        
                                        SelectorCONFIG_PENDING.on(function(obj) {   // bei Zustandänderung *.CONFIG_PENDING in allen Gewerken
                                            countService(obj);
                                        });
                                        
                                        // alternative Abfrage jede Minute
                                        schedule("*/15 * * * *", function () {
                                            countService();
                                        });
                                        
                                        // Ausführung bei Scriptstart
                                        countService();</true>
                                        

                                        Im Log des Script taucht folgendes auf
                                        ` > 14:26:38.405 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ1310993.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:26:38.406 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:38.406 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:26:38.444 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:38.445 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:26:39.527 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.KEQ0025734.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:26:39.527 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:39.527 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:26:39.556 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:39.557 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:26:41.462 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0484756.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:26:41.463 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:41.463 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:26:41.483 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:26:41.484 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:27:03.163 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ1310993.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:27:03.163 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:27:03.163 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:27:03.163 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0484756.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ1310993.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: STICKY_UNREACH Meldung: hm-rpc.0.MEQ0484756.0.STICKY_UNREACH wurde auf gesetzt. Das Homematic Gerät ist wieder uneingeschränkt erreichbar.

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:27:03.164 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:27:03.201 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        Rollo Arbeitszimmer UNREACH

                                        14:27:03.202 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 3

                                        14:28:16.254 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Stehlampen Essbereich UNREACH

                                        Taster Deckenlicht Arbeitszimmer UNREACH

                                        14:28:16.254 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 2

                                        14:28:17.000 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen: Taster Deckenlicht Arbeitszimmer UNREACH

                                        14:28:17.000 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 1

                                        14:28:17.812 [info] javascript.0 script.js.CCU2.Servicemeldungen: Homematic-Servicemeldungen:

                                        14:28:17.813 [info] javascript.0 script.js.CCU2.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 0 `

                                        Im VIS steht unreach im Widget. Habe basic-html genommen.

                                        Unter HTML habe ich folgendes Eingetragen > {javascript.0.Servicemeldungen.Homematic.UNREACH.Text}
                                        1304_screenshot_139.jpg

                                        Es wird im VIS dann nur undefined angezeigt

                                        Jemand ne Idee was nicht passt.

                                        Danke

                                        1 Reply Last reply Reply Quote 0
                                        • Z
                                          Zippolighter last edited by

                                          Das Fenster sieht bei mir leider immer so aus
                                          1304_screenshot_140.jpg

                                          Hoffe Ihr habt ne Idee

                                          Danke

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

                                            Hallo Zippo,

                                            ich habe das nicht mit dem HTML Widget gemacht sondern mit dem Text-Wert (String Text val)

                                            Und davon 2:

                                            1. als object-id

                                            javascript.0.Servicemeldungen.Homematic.Text
                                            

                                            2. als object-id

                                            javascript.0.Servicemeldungen.Homematic.Anzahl
                                            

                                            Gruß

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            917
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            30
                                            90
                                            23205
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo