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. Deutsch
  3. ioBroker Allgemein
  4. Servicemeldungen in vis

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    10
    1
    182

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

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

Servicemeldungen in vis

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
90 Beiträge 30 Kommentatoren 25.6k Aufrufe 11 Watching
  • Ä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.
  • G Offline
    G Offline
    galferiz
    schrieb am zuletzt editiert von
    #53

    @Homoran:

    …

    • .vis-Widgets

    • javascript (Skripting)

    • javascript-Adapter

    Wo hakt es jetzt? `

    Eine gute Frage :(

    Ok, ich fass nochmal zusammen:

    A) Javascript Editor installiert

    B) Script Ordner (nicht Common oder Global) anlegt, Script eingefügt.

    /*  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]');
    var SelectorERROR = $('channel[state.id=*.ERROR]');
    
    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);
        });
    
        SelectorERROR.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);
    });
    
    SelectorERROR.on(function(obj) {          // bei Zustandänderung *.ERROR in allen Gewerken
        countService(obj);
    });
    
    // alternative Abfrage jede Minute
    schedule("*/15 * * * *", function () {
        countService();
    });
    
    // Ausführung bei Scriptstart
    countService();</true>
    

    C) Variablen anlegen? - Die sollten eigentlich durch das Script selbst angelegt werden!?

    ->siehe p3.PNG

    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'
    });
    

    D) Widget anlegen wie oben beschrieben (Import):

    [{"tpl":"tplHtml","data":{"visibility-cond":"==","visibility-val":1,"refreshInterval":"0","html":"{javascript.0.Servicemeldungen.Homematic.Text}","visibility-groups-action":"hide","g_signals":false,"signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"g_gestures":false},"style":{"left":"368px","top":"111px","width":"409px","height":"106px","color":"rgb(255, 255, 255)","text-align":"left","text-shadow":"none","font-family":"Arial, Helvetica, sans-serif","font-style":"normal","font-variant":"normal","font-weight":"bold","font-size":"18px","line-height":"21px","letter-spacing":"0","word-spacing":"0px","z-index":"20"},"widgetSet":"basic"}]
    
    

    Einfach importieren und im Feld HTML Deinen Datenpunkt eintragen (siehe p4.PNG/p5.PNG/p6.PNG)

    Von welchen Datenpunkt reden wir genau. Ich denke hier liegt der Fehler !?

    Es wird derzeit nur undefined ausgegeben.

    Grüße

    Thomas

    PS: Gedankenspiel, macht es hier nicht auch Sinn zukünftig einen eigenständigen Adapter zu schaffen? Bitte nicht gleich Federn und Teeren ;-)
    1935_p1.png
    1935_p2.png
    1935_p3.png
    1935_p4.png
    1935_p6.png

    Nach Weihnachten ist vor Weihnachten

    M 1 Antwort Letzte Antwort
    0
    • HomoranH Nicht stören
      HomoranH Nicht stören
      Homoran
      Global Moderator Administrators
      schrieb am zuletzt editiert von
      #54

      Werde ich mal heute wenn ich am pc sitze irgendwo nachstellen und mich dann melden.

      @galferiz:

      macht es hier nicht auch Sinn zukünftig einen eigenständigen Adapter zu schaffe `
      Ein widget müsste reichen. Aber Bluefox hat im moment genug zu tun.

      Gruß

      Rainer

      kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

      1 Antwort Letzte Antwort
      0
      • HomoranH Nicht stören
        HomoranH Nicht stören
        Homoran
        Global Moderator Administrators
        schrieb am zuletzt editiert von
        #55

        @galferiz:

        Beitrag von galferiz » 04.02.2017, 12:32

        Homoran hat geschrieben:

        …

        • .vis-Widgets

        • javascript (Skripting)

        • javascript-Adapter

        Wo hakt es jetzt?

        Eine gute Frage `

        Aus dem Zusammenhang gerissen ;)

        Die Frage bezog sich auf den Text davor

        @Homoran:

        ich bin froh über Feedback, um die Lücken in der Doku zu füllen.

        …

        Wo hakt es jetzt? `

        Nämlich auf die Doku!

        Gruß

        Rainer

        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

        1 Antwort Letzte Antwort
        0
        • G Offline
          G Offline
          galferiz
          schrieb am zuletzt editiert von
          #56

          Jepp - gehört nicht zum Beitrag ;-)

          Nach Weihnachten ist vor Weihnachten

          1 Antwort Letzte Antwort
          0
          • G Offline
            G Offline
            galferiz
            schrieb am zuletzt editiert von
            #57

            Nabend Leute,

            Ich wollte nur nochmal nachmelden, daß je nach verwendeten Brower oder iOBroker-APP erhält man unterschiedliche Ergebnisse.

            Das kann durchaus einer der Gründe sein, warum soviele Leute mal hier mal da Probleme mit Einstellungen haben, die bei anderen Nutzen problemlos funktionieren.

            Ich habe derzeit 3 verschiede Lösungenmöglichkeiten entdeckt.

            Je nachdem wie man die Widgets -

            • basic String

            • basic HTML

            • basic String (unescapted)

            • Value List HTML Style

            befüttert, kommen hier unterschiedliche Ergebnisse heraus.

            Dabei sind greift man trotzdem jedesmal den selben Datenpunkt von Pix Script ab.

            Ich untersuch das nochmal weiter. Ähnliche Phänomene hab ich auch in Bezug auf iFrames schon bemerkt.

            Weis ja nicht, ob dies schonal irgendwo weiter thematisiert worden ist, aber dies Problem dürften zumindestens die Webdesigner unter Euch kennen.

            Nicht umsonst gibt es für einige optische Lösungen oft Browser Abfragen im Hintergund, um die richtige Darstellung der Websites zu gewährleisten.

            Nach Weihnachten ist vor Weihnachten

            1 Antwort Letzte Antwort
            0
            • M Offline
              M Offline
              mike2712
              schrieb am zuletzt editiert von
              #58

              Hallo,

              seit kurzem habe ich folgendes Problem mit dem Script Service-Meldungen.

              Folgender Fehler wird angegeben:

              Hat jemand anders das selbe Problem, weiß jemand woran es liegen könnte? Von java habe absolut keine Ahnung, das hat eigentlich immer problemlos funktioniert, auch ist mir nicht bewusst etwas wesentliches geändert zu haben, außer Updates.

              ! 11:54:26.551 [error] javascript.0 script.js.Allgemein.Servicemeldungen: TypeError: Cannot read property 'split' of undefined at count (script.js.Allgemein.Servicemeldungen:45:30) at script.js.Allgemein.Servicemeldungen:64:9 at Object.result.each (C:\Users\Mike Holtgrefe\node_modules\iobroker.javascript\javascript.js:1202:33) at countService (script.js.Allgemein.Servicemeldungen:63:20) at script.js.Allgemein.Servicemeldungen:106:1

              Hier das komplette Script, ist aber so aus dem Forum.

              /*  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 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
                          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

              ioBroker im Docker auf Qnap TS-453A 16GB Ram 4-Bay

              1 Antwort Letzte Antwort
              0
              • S Offline
                S Offline
                SchuetzeSchulz
                schrieb am zuletzt editiert von
                #59

                Also ichbin wie von galferiz beschrieben vorgegangen und es funktioniert perfekt :)

                1 Antwort Letzte Antwort
                0
                • C Offline
                  C Offline
                  chka
                  schrieb am zuletzt editiert von
                  #60

                  Ich bekomme in der Log diverse Warnungsmeldungen angezeigt:````
                  javascript.0 2017-07-17 06:36:33.088 warn State "hm-rpc.1.CUX9000002.0.LOWBAT" not found
                  javascript.0 2017-07-17 06:36:33.087 warn State "hm-rpc.1.CUX0200107.0.UNREACH" not found
                  javascript.0 2017-07-17 06:36:33.087 warn State "hm-rpc.1.CUX0200105.0.UNREACH" not found
                  javascript.0 2017-07-17 06:36:33.087 warn State "hm-rpc.1.CUX0200101.0.UNREACH" not found
                  javascript.0 2017-07-17 06:36:33.087 warn State "hm-rpc.1.CUX0200002.0.UNREACH" not found

                  
                  Suche ich nach den Datenpunkte gibt es diese, allerdings gibt es auf dem darauffolgenden Gerät nicht! Wird aber so nicht angezeigt.
                  
                  BSP: hm-rpc.1.CUX9000002.0.LOWBAT gibt es hm-rpc.1.CUX900****2****001.0.LOWBAT gibt es nicht.
                  
                   ![883_bildschirmfoto_2017-07-17_um_06.44.53.png](/assets/uploads/files/883_bildschirmfoto_2017-07-17_um_06.44.53.png) 
                  
                  Ich möchte ungern auf dauen den Log Modus auf Error setzen.

                  INTEL NUC BOXNUC6I3SYH i3-6100U - Proxmox

                  Speicher: Transcend MTS800 M.2 SSD 128GB SATA III, MLC

                  RAM: 40Gig Crucial 8GB DDR4 CT2K8G4SFS824A + 32GB DDR4CT32G4SFD8266

                  1 Antwort Letzte Antwort
                  0
                  • nieIPN Offline
                    nieIPN Offline
                    nieIP
                    schrieb am zuletzt editiert von
                    #61

                    Hallo

                    dieser Beitrag zieht sich ja nun schon über längere Zeit. Nach dem Lesen sehe ich zwar einige Posts weiter oben so eine Art Schritt für Schritt Anleitung. Eine Frage die ich gern vor dem Einrichten beantwortet hätte ist aber noch offen …

                    Kann ich mit dem Script nur Meldungen anzeigen oder auch quittieren. Eine reine Anzeige nutzt mir nichts.

                    1 Antwort Letzte Antwort
                    0
                    • D Offline
                      D Offline
                      DiJaexxl
                      schrieb am zuletzt editiert von
                      #62

                      Nur anzeigen

                      Gruss aus Bensberg

                      Dirk

                      1 Antwort Letzte Antwort
                      0
                      • GoerschG Offline
                        GoerschG Offline
                        Goersch
                        schrieb am zuletzt editiert von
                        #63

                        @chka: Versuche mal bitte folgendes (so helfe ich mir immer)

                        1. das Objekt editieren

                        2. den Schreib-Modus aktivieren

                        3. als Wert true oder false eintragen

                        4. den Schreib-Modus wieder deaktivieren

                        Problem ist nicht das fehlende Objekt, sondern der null-Wert des Objekts.

                        Allgemein: Das Skript erzeugt nach einem Neustart des Adapters massenhaft events bzgl. "unreachable". Das mag bei 30,40 Geräten noch kein Problem sein; bei mir hängen aber fast 170 HM Geräte an der CCU. Ich bekomme dann immer eine "You are sending too fast" Meldung. Lösung hab ich allerdings auch nicht.

                        1 Antwort Letzte Antwort
                        0
                        • C Offline
                          C Offline
                          chka
                          schrieb am zuletzt editiert von
                          #64

                          Wird das nicht beim neu scannen der Geräte wieder überschrieben?

                          INTEL NUC BOXNUC6I3SYH i3-6100U - Proxmox

                          Speicher: Transcend MTS800 M.2 SSD 128GB SATA III, MLC

                          RAM: 40Gig Crucial 8GB DDR4 CT2K8G4SFS824A + 32GB DDR4CT32G4SFD8266

                          1 Antwort Letzte Antwort
                          0
                          • GoerschG Offline
                            GoerschG Offline
                            Goersch
                            schrieb am zuletzt editiert von
                            #65

                            hab ich nicht beobachtet

                            1 Antwort Letzte Antwort
                            0
                            • MeistertrM Offline
                              MeistertrM Offline
                              Meistertr
                              Developer
                              schrieb am zuletzt editiert von
                              #66

                              ich hab auch das Problem mit den Warmeldungen, dass der State nicht gefunden wurde (erst seit javascript update) Das problem ist nicht der wert Null. Sonder die Abfrage des States der cuxd Geräte. der Unterpunkt 0.XXX Schein einfach nicht da zu sein obwohl er unter Objekte aufgeführt ist. Weiß jemand wie man die die cuxd Geräte von der Abfrage entkoppeln kann? Finde es irgendwie nciht so toll wenn mein gesamter log immer gelb ist :)

                              1 Antwort Letzte Antwort
                              0
                              • D Offline
                                D Offline
                                deifel
                                schrieb am zuletzt editiert von
                                #67

                                Hallo zusammen,

                                seit einigen Tagen funktioniert das Script bei mir leider nicht mehr (keine Änderung am System - nur Update der Adapter in Iobroker.

                                Es stehen bei mir immer diesselben Geräte als "unreach" drin, obwohl der Status korrekt ist bzw. es keine Servicemeldungen gibt (oder andere).

                                Das Log beim Start des Scriptes sieht so aus:

                                Log
                                
                                21:43:00.898	[info]	javascript.0 Stop script script.js.common.Servicemeldungen
                                21:43:01.157	[info]	javascript.0 Start javascript script.js.common.Servicemeldungen
                                21:43:01.158	[warn]	javascript.0 at count (script.js.common.Servicemeldungen:39:22)
                                21:43:01.158	[warn]	javascript.0 at script.js.common.Servicemeldungen:47:9
                                21:43:01.158	[warn]	javascript.0 at script.js.common.Servicemeldungen:51:22
                                21:43:01.159	[warn]	javascript.0 at count (script.js.common.Servicemeldungen:39:22)
                                21:43:01.159	[warn]	javascript.0 at script.js.common.Servicemeldungen:59:9
                                21:43:01.159	[info]	javascript.0 script.js.common.Servicemeldungen: Homematic-Servicemeldungen: hm-rpc.0.KEQ0509324.0.UNREACH,
                                hm-rpc.0.KEQ0510087.0.UNREACH,
                                hm-rpc.0.KEQ0510208.0.UNREACH,
                                hm-rpc.0.KEQ0576159.0.UNREACH,
                                hm-rpc.0.KEQ1039611.0.UNREACH,
                                hm-rpc.0.LEQ0420281.0.UNREACH,
                                hm-rpc.0.NEQ1662995.0.UNREACH,
                                21:43:01.160	[info]	javascript.0 script.js.common.Servicemeldungen: Anzahl Homematic-Servicemeldungen: 7
                                21:43:01.160	[info]	javascript.0 script.js.common.Servicemeldungen: registered 455 subscriptions and 1 schedule
                                

                                Kann mir jemand einen Tip geben, woran das liegen könnte?

                                Ich nutze das Script hier aus dem Thread und es hat bislang problemlos funktioniert.

                                /*  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>
                                

                                Oder ist das ein allgemeiner Fehler?

                                Danke im Voraus

                                Frank

                                1 Antwort Letzte Antwort
                                0
                                • D Offline
                                  D Offline
                                  deifel
                                  schrieb am zuletzt editiert von
                                  #68

                                  Hallo nochmals,

                                  ist wirklich keiner da, der mir hier evtl. weiterhelfen kann und bin ich der einzige, bei dem dieses Problem besteht?

                                  Im Übrigen zeigt es bei mir auch seit längerem schon nur noch die Seriennummer des Gerätes an und keine ID (Name) mehr.

                                  Und somit weiß ich natürlich nie, welches Gerät gerade nicht erreichbar ist etc…

                                  Wäre toll, wenn mir jemand nen Tipp hat, wo ich da nach dem Fehler suchen könnte...

                                  Vielen Dank und schöne Weihnachten

                                  Frank

                                  1 Antwort Letzte Antwort
                                  0
                                  • GoerschG Offline
                                    GoerschG Offline
                                    Goersch
                                    schrieb am zuletzt editiert von
                                    #69

                                    unreach: schau mal in die Objekte und setze für die betroffenen Geräte den "STICKY_UNREACH" Status auf "false".

                                    ID anstatt Name:

                                    Ändere in````
                                    function count(id)

                                    
                                    die Zeile
                                    

                                    text = text + id + ",
                                    ";

                                    
                                    gegen
                                    

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

                                    1 Antwort Letzte Antwort
                                    0
                                    • M Offline
                                      M Offline
                                      Marty56
                                      schrieb am zuletzt editiert von
                                      #70

                                      Noch ein Variante mit geringfügigen Änderungen,

                                      1. Ausgabe für Telegram formatiert

                                      2. Statt der ID werden die Namen der Homematic Geräte ausgegeben

                                      3. Abfrage des Konfigurationsstatus und des Stick_Unreach Bits habe ich weggelassen, weil für mich nicht so relevant.

                                      instanz = 'javascript.0.';
                                      var idAnzahl = instanz + 'Servicemeldungen.Homematic.Anzahl',
                                          idText =   instanz + 'Servicemeldungen.Homematic.Text';
                                      
                                      createState(idAnzahl, 0, {
                                          name: 'Homematic Servicemeldungen Anzahl',
                                          desc: 'Zahl der Homematic Servicemeldungen',
                                          type: 'number'
                                      });
                                      createState(idText, "", {
                                          name: 'Homematic Servicemeldungen Text',
                                          desc: 'Liste der Geräte, die Servicemeldungen produzieren',
                                          type: 'string'
                                      });
                                      
                                      var SelectorUNREACH         = $('channel[state.id=*.UNREACH]');
                                      var SelectorLOWBAT          = $('channel[state.id=*.LOWBAT]');
                                      
                                      function countService(obj) {
                                          var anzahl    = 0;
                                          var text      = "";
                                          var delimiter = "";
                                      
                                          // Klartext Name ermitteln
                                          function getname(id) {
                                              var tokens      =  [];
                                              var object = getObject(id);
                                          	tokens          =  object.common.name.split(":");
                                          	return tokens[0];
                                          }
                                      
                                          function count(id,cause) {
                                              var status = getState(id).val;
                                              if (status) { 
                                                  text = text + delimiter + getname(id) + " " + cause + " " ;
                                                  delimiter = "\n"; // Neue Zeile für Telegram
                                                  ++anzahl;
                                              }
                                          }
                                      
                                          SelectorUNREACH.each(function (id, i) {count(id,"ist nicht erreichbar");});
                                          SelectorLOWBAT.each(function (id, i) {count(id,"hat schwache Batterie");});
                                      
                                          if (!anzahl) text = "keine Servicemeldungen";
                                      
                                          log("Homematic-Servicemeldungen: " + text);
                                          //log("Anzahl Homematic-Servicemeldungen: " + anzahl);
                                      
                                          setState(idText, text); 
                                          setState(idAnzahl, anzahl);
                                          setState('telegram.0.communicate.response', text);
                                      }
                                      
                                      countService();
                                      SelectorUNREACH.on(function(obj)        {countService(obj);});
                                      SelectorLOWBAT.on(function(obj)         {countService(obj);});
                                      
                                      

                                      HW:NUC (16 GB Ram)
                                      OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

                                      1 Antwort Letzte Antwort
                                      1
                                      • hg6806H Offline
                                        hg6806H Offline
                                        hg6806
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #71

                                        Hallo zusammen,

                                        würde gerne zu den Service Meldungen auch noch einige Meldungen anzeigen lassen.

                                        Im Moment habe ich für jede Meldung ein eigenes Feld in VIS, dass dann entspr. angezeigt wird, wenn es akut ist.

                                        Das kostet aber viel Platz, da für jede Meldung ein eigener Platz reserviert wird.

                                        Besser wäre es eben das mit den Servicemeldungen zu verbinden, die dann entsprechend von oben beginnen nach unten rutschen.

                                        Eigene Meldungen wären z.B. Wasser zu kalt/heiß, Luftfeuchtigkeit zu hoch, Fenster geschlossen halt, etc. D.h. ich lasse etwas anzeigen, wenn ein Wert unter/überschritten wird.

                                        Wäre cool, wenn man das irgendwie mit einbinden könnte.

                                        Danke für Tipps

                                        1 Antwort Letzte Antwort
                                        0
                                        • sigi234S Online
                                          sigi234S Online
                                          sigi234
                                          Forum Testing Most Active
                                          schrieb am zuletzt editiert von
                                          #72

                                          viewtopic.php?f=21&t=13209

                                          Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                          Immer Daten sichern!

                                          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
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          856

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          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