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
    11
    1
    508

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

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

Servicemeldungen in vis

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
90 Beiträge 30 Kommentatoren 25.7k 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.
  • M Offline
    M Offline
    mike2712
    schrieb am zuletzt editiert von
    #12

    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

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

    1 Antwort Letzte Antwort
    0
    • P Offline
      P Offline
      pix
      schrieb am zuletzt editiert von Negalein
      #13

      Hallo Mike,

      ersetze mal Zeile 41

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

      durch

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

      Gruß

      Pix

      ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

      1 Antwort Letzte Antwort
      0
      • eric2905E Offline
        eric2905E Offline
        eric2905
        schrieb am zuletzt editiert von
        #14

        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

        Roses are red, violets are blue,

        if I listen to metal, my neighbours do too

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

          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

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

          1 Antwort Letzte Antwort
          0
          • sissiwupS Offline
            sissiwupS Offline
            sissiwup
            schrieb am zuletzt editiert von
            #16

            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> 
            

            MfG

            Sissi

            –-----------------------------------------

            1 CCU3 1 CCU2-Gateway 1 LanGateway 1 Pi-Gateway 1 I7 für ioBroker/MySQL


            1 Antwort Letzte Antwort
            0
            • H Offline
              H Offline
              Harry-IO-HM
              schrieb am zuletzt editiert von
              #17

              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 Antwort Letzte Antwort
              0
              • P Offline
                P Offline
                PrinzEisenherz1
                schrieb am zuletzt editiert von
                #18

                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

                Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

                1 Antwort Letzte Antwort
                0
                • P Offline
                  P Offline
                  PrinzEisenherz1
                  schrieb am zuletzt editiert von
                  #19

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

                  Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

                  1 Antwort Letzte Antwort
                  0
                  • S Offline
                    S Offline
                    Sven2013
                    schrieb am zuletzt editiert von
                    #20

                    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 Antwort Letzte Antwort
                    0
                    • P Offline
                      P Offline
                      PrinzEisenherz1
                      schrieb am zuletzt editiert von
                      #21

                      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

                      Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

                      1 Antwort Letzte Antwort
                      0
                      • S Offline
                        S Offline
                        Sven2013
                        schrieb am zuletzt editiert von
                        #22

                        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 Antwort Letzte Antwort
                        0
                        • P Offline
                          P Offline
                          PrinzEisenherz1
                          schrieb am zuletzt editiert von
                          #23

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

                          Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

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

                            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 Antwort Letzte Antwort
                            0
                            • Z Offline
                              Z Offline
                              Zippolighter
                              schrieb am zuletzt editiert von
                              #25

                              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 Antwort Letzte Antwort
                              0
                              • Z Offline
                                Z Offline
                                Zippolighter
                                schrieb am zuletzt editiert von
                                #26

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

                                Hoffe Ihr habt ne Idee

                                Danke

                                1 Antwort Letzte Antwort
                                0
                                • S Offline
                                  S Offline
                                  Smartuser
                                  schrieb am zuletzt editiert von
                                  #27

                                  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 Antwort Letzte Antwort
                                  0
                                  • Z Offline
                                    Z Offline
                                    Zippolighter
                                    schrieb am zuletzt editiert von
                                    #28

                                    Das sieht bei mir aber nicht wirklich gut aus. Keine Zeilenumbrüche z.B. mache ich da noch was falsch

                                    1304_screenshot_144.jpg

                                    1 Antwort Letzte Antwort
                                    0
                                    • Z Offline
                                      Z Offline
                                      Zippolighter
                                      schrieb am zuletzt editiert von
                                      #29

                                      Kann mir bei dem Problem keiner helfen??

                                      Nutzt Ihr alle keine Ansicht im ioBroker wo die Servicemeldungen angezeigt werden??

                                      Danke

                                      1 Antwort Letzte Antwort
                                      0
                                      • eric2905E Offline
                                        eric2905E Offline
                                        eric2905
                                        schrieb am zuletzt editiert von
                                        #30

                                        Moin,

                                        am "br" in spitzen Klammer (sorry, muss ich so schreiben - Tapatalk baut das "br" wie html ein …. und schon ist eine neue Zeile im Posting ...) erkenne ich, das Du eine html-Rückgabe verarbeitest.

                                        Nutzt Du denn auch ein html-Widget zur Darstellung?

                                        Gruß,

                                        Eric

                                        Von unterwegs getippert.

                                        Roses are red, violets are blue,

                                        if I listen to metal, my neighbours do too

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

                                          Hallo eric,

                                          Lt. Screenshot und text ist es ein basic html.

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

                                          793

                                          Online

                                          32.5k

                                          Benutzer

                                          81.8k

                                          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