Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Servicemeldungen - All inclusive für Homematic -

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    Servicemeldungen - All inclusive für Homematic -

    This topic has been deleted. Only users with topic management privileges can see it.
    • dslraser
      dslraser Forum Testing Most Active last edited by

      merci

      1 Reply Last reply Reply Quote 0
      • dslraser
        dslraser Forum Testing Most Active last edited by

        Ich habe jetzt erstmal pushover installiert und eingerichtet (7 Tage Testversion). Bisher habe ich alles über Telegram gemacht.

        Pushover habe ich erstmal nur eine Instanz und das im Script auch so geändert. Ich verstehe gerade die Prio Geschichte noch nicht bzw. weiß noch nicht wie ich dafür Pushover einrichten müsste.

        Das Script ist gestartet…nun warte ich mal auf eine Meldung, die man ja eigentlich nicht will.

        Oder könnte man eine Meldung provozieren ? Vielleicht irgendwo ne leere Batterie rein, oder einfach ein Gerät unerreichbar machen...?

        1 Reply Last reply Reply Quote 0
        • cash
          cash Most Active last edited by

          Du kannst theoretisch einfach den Datenpunkt XXX_ALRAM außer bei ERROR auf 1 setzen. Wirft dir zwar ein Fehler ins log aber so geht es. Nach spätestens 3 Minuten wird der Wert dann von der rega dann wieder korrigiert.

          Du kannst das Script auch mit Telegram nutzen, musst Du nur etwas anpassen. Ich nutze nur Pushover und das auch schon sehr lange. Jede Pushover Instanz hat einen eigenen Schlüssel bei mir so das je nach Instanz ein anderer Icon kommt. Man kann auch je Instanz ein anderen Sound benutzen. Nutze ich nicht da ich den eh nie höre weil alles auf die Uhr bei mir kommt.

          Wenn Du Debug auf true stellst und unten „beim Starten“ beabeitest sollte er zumindest auch im Log zeigen wieviel Geräte überwacht werden…

          1 Reply Last reply Reply Quote 0
          • dslraser
            dslraser Forum Testing Most Active last edited by

            Es wird bei mir nicht alles aus der Instanz gefunden….(mögliche lowbat sind 0 ??)

            Bei den anderen Werten werden 65 Geräte gefunden.

            3822_bildschirmfoto_2019-02-02_um_18.10.58.png

            Das zeigt mein herrkömmliches Script

            3822_bildschirmfoto_2019-02-02_um_18.16.01.png

            PS: ich habe auch keine Wert den ich zum testen auf 1 stellen kann ? Das sind alles true/false Werte ? Auf rpc.0 habe ich ausschließlich HMIP Geräte

            1 Reply Last reply Reply Quote 0
            • cash
              cash Most Active last edited by

              Zeig mal von die entsprechenden Datenpunkte von einem Gerät? Ich habe nur die klassischen Homematic Geräte. Welche Version von den beiden Instanzen sind installiert. Bitte die beiden auch nochmal stopppen und starten. Es muss von allen Fehlerpunkten ein zugehröigen _ALARM geben. Diese können die Werte 0, 1 und 2 haben.

              1 Reply Last reply Reply Quote 0
              • dslraser
                dslraser Forum Testing Most Active last edited by

                Hier mal ein optischer Fensterkontakt. Die Instanzen habe ich neu gestartet und auch die Adapter aktualisiert, inklusive upload.

                Auf rpc.0 habe ich HMIP und auf rpc.1 normale Homematic(die habe ich aber noch nicht im Script)

                3822_bildschirmfoto_2019-02-02_um_18.58.31.png

                3822_bildschirmfoto_2019-02-02_um_18.59.23.png

                3822_bildschirmfoto_2019-02-02_um_19.03.12.png

                1 Reply Last reply Reply Quote 0
                • dslraser
                  dslraser Forum Testing Most Active last edited by

                  Ach, ich seh schon, da war ja was….....

                  LOWBAT . und LOW_BAT

                  1 Reply Last reply Reply Quote 0
                  • cash
                    cash Most Active last edited by

                    Korrekt. LOW_BAT_ALRAM solltest Du verwenden…

                    Es scheint also das bei den IP-Geräten die Bezeichnung anstelle von LOWBAT einfach LOW_BAT ist. Ich muss mal gucken wir ich da bei mir einbaue. Mich würde die Debug Ausgabe interessieren ob er die Batterien ermittelt wenn Du es auf LOW_BAT_ALARM angepasst hast.

                    1 Reply Last reply Reply Quote 0
                    • cash
                      cash Most Active last edited by

                      SABOTAGE_ALRAM muss ich auch noch aufnehmen…

                      1 Reply Last reply Reply Quote 0
                      • dslraser
                        dslraser Forum Testing Most Active last edited by Negalein

                        @cash:

                        Korrekt. LOW_BAT_ALRAM solltest Du verwenden…

                        Es scheint also das bei den IP-Geräten die Bezeichnung anstelle von LOWBAT einfach LOW_BAT ist. Ich muss mal gucken wir ich da bei mir einbaue. Mich würde die Debug Ausgabe interessieren ob er die Batterien ermittelt wenn Du es auf LOW_BAT_ALARM angepasst hast. `

                        Hier mal der "Klassiker" wo es bei mir funktioniert

                        createState('zählenLowbat.möglicheLOWBAT', 0);   // wenn benötigt: Anzahl der vorhandenen Geräte
                        createState('zählenLowbat.anzahlLOWBAT', 0);     // wenn benötigt: Anzahl der vorhandenen LOWBAT
                        createState('zählenLowbat.textLOWBAT', " ");     // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                        var cacheSelectorLOWBAT  = $('channel[state.id=*.LOWBAT]');
                        var cacheSelectorLOW_BAT  = $('channel[state.id=*.LOW_BAT]');   // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt
                        function countLowbat(obj) {
                           // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                           var moeglicheLOWBAT = 0;
                           var anzahlLOWBAT    = 0;
                           var textLOWBAT      = [];
                           if (obj) {
                              log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);  // Info im Log, welcher Zustand sich geändert hat
                           } else {
                              log('Ausgelöst bei Timer'); 
                           } 
                           cacheSelectorLOWBAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *.LOWBAT
                              var status = getState(id).val;                                  // Zustand *.LOWBAT abfragen (jedes Element)
                              var obj    = getObject(id);
                              if (status === true) {                                          // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                 textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
                              }                
                              log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                              ++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                           }); 
                           cacheSelectorLOW_BAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                              var status = getState(id).val;                                  // Zustand *.LOW_BAT abfragen (jedes Element)
                              var obj    = getObject(id);
                              if (status === true) {                                          // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                 textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
                        
                                 ++anzahlLOWBAT                  // DAS HIER FEHLTE
                        
                              }                
                              log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                              ++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                           }); 
                           // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                           log("Text: " + textLOWBAT);
                           log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  anzahlLOWBAT);
                           // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                           setState("zählenLowbat.textLOWBAT",     textLOWBAT.join(',
                        ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
                           setState("zählenLowbat.anzahlLOWBAT",   textLOWBAT.length);        // Schreibt die aktuelle Anzahl der Geräte im System
                           setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT);          // Schreibt die aktuelle Anzahl der vorhandene Geräte 
                        
                           if(anzahlLOWBAT > 0)  setTimeout(telegram,2000);                        // NEU EINGEFÜGT. Telegram wird um 2 Sekunden verzögert geschickt um sicherzugehen, dass alles andere vorher erledigt ist und auch nur, sofern es leere Batterien gibt (was du in deinem Versuch ja quasi simulierst)
                        }
                        cacheSelectorLOWBAT.on(function(obj) {    // bei Zustandänderung *. LOWBAT in allen Gewerken
                           countLowbat(obj);
                        });
                        cacheSelectorLOW_BAT.on(function(obj) {    // bei Zustandänderung *. LOW_BAT in allen Gewerken
                           countLowbat(obj);   
                        });
                        schedule("0 */6 * * *", function () {                                  //ausgelöst alle 6 Stunden
                           countLowbat();
                        });
                        >! // TELEGRAM ALS FUNKTION NEU EINGEFÜGT:
                            function telegram() {
                                 var telegramtext = getState("zählenLowbat.textLOWBAT").val.replace(/
                        /g , "\n");  // telegram Liste formatieren, entfernt den HTML Zeilenumbruch und ersetzt mit Zeilenumbruch Telegram
                        
                                 telegramtext = telegramtext.replace(/_DEV:0.LOW_BAT/g, "");
                                        sendTo('telegram.0', {                                                             // Nachricht per Telegram senden
                                        text: "Komponenten mit geringem Ladestand:\n\n" + telegramtext        
                                        });
                            }
                        //Bei Scriptstart
                        countLowbat();
                        
                        1 Reply Last reply Reply Quote 0
                        • cash
                          cash Most Active last edited by

                          In dem Select wird auf die Datenpunkte ohne ALARM geprüft. Kann man machen. Allerdings war das bei meinen Tests nicht bei allen Fehlermeldungen korrekt. Vorallen UNREACH bzw STICKY_UNREACH. Deshalb nutze ich die *_ALRAM.

                          1 Reply Last reply Reply Quote 0
                          • dslraser
                            dslraser Forum Testing Most Active last edited by

                            @cash:

                            In dem Select wird auf die Datenpunkte ohne ALARM geprüft. Kann man machen. Allerdings war das bei meinen Tests nicht bei allen Fehlermeldungen korrekt. Vorallen UNREACH bzw STICKY_UNREACH. Deshalb nutze ich die *_ALRAM. ` Dein Script ist ja auch gut so.

                            (ich wollte Dir nur den LOWBAT und LOW_BAT Unterschied nochmal zeigen, weil ich mich wieder daran erinnert habe das HMIP anders ist.)

                            1 Reply Last reply Reply Quote 0
                            • cash
                              cash Most Active last edited by

                              Ich schicke Dir Morgen nochmal eine Liste mit weiteren Fehlertypen. Auf die könntest Du dann bitte in den Objekten mal filtern. Ich habe da noch welche die ich bei mir nicht zuordnen konnte. Ich vermute das wird dann alles IP-Fehlertypen sein.

                              ich werde mir wohl doch auch ein paar IP-Geräte kaufen müssen :mrgreen:

                              1 Reply Last reply Reply Quote 0
                              • dslraser
                                dslraser Forum Testing Most Active last edited by

                                okay[emoji16]

                                1 Reply Last reply Reply Quote 0
                                • cash
                                  cash Most Active last edited by

                                  @dslraser

                                  Bitte mal unter Objekte nach folgenden Sachen filtern:

                                  U_SOURCE_FAIL

                                  USBH_POWERFAIL

                                  ERROR_SABOTAGE

                                  STICKY_SABOTAGE

                                  ERROR_REDUCED

                                  ERROR_NON_FLAT_POSITIONING

                                  ERROR_SABOTAGE

                                  SABOTAGE (solltest Du haben unter 0)

                                  LOW_BAT (solltest Du haben unter 0)

                                  Falls Du Treffer hast würde mich interessieren welche Geräte das sind und unter welchen Kanal der Treffer ist.

                                  Filtern einfach:

                                  ! 1407_bildschirmfoto_2019-02-02_um_22.19.20.png

                                  1 Reply Last reply Reply Quote 0
                                  • dslraser
                                    dslraser Forum Testing Most Active last edited by

                                    Ich habe nur Treffer von diesen beiden…:(alle anderen Suchbegriffe bleiben leer)
                                    3822_bildschirmfoto_2019-02-02_um_22.32.24.png
                                    3822_bildschirmfoto_2019-02-02_um_22.32.45.png

                                    1 Reply Last reply Reply Quote 0
                                    • cash
                                      cash Most Active last edited by

                                      was hast Du unter hm.rpc.0 und hm.rpc.1?

                                      Unter 0 sind die IP-Geräte und unter 1 normale Homematic? Oder ist das Cuxd oder virtuelle Gruppen?

                                      Werde Deine beiden Fehlermeldungen Morgen oder Übermorgen einbauen. Weiß schon wie ich das umsetze. Die Ermittlung der Batterien lagere ich aus. So kann ich es dann für LOWBAT und LOW_BAT nutzen.

                                      1 Reply Last reply Reply Quote 0
                                      • dslraser
                                        dslraser Forum Testing Most Active last edited by

                                        LOW_BAT habe ich jetzt drin

                                        sobald ich mehr dazu nehme werden mir wieder 0 mögliche Geräte angezeigt.

                                        ! ````
                                        // jshint maxerr:1000
                                        /**************************

                                        • Verschickt eine Pushmittteilung bei auftretenden Servicemeldungen bei Homematic-Geräten
                                        • 28.01.19 V1.00 Erste Version
                                        • 30.01.19 V1.01 Bei LowBAT Meldungen wird nun auch der Typ und somit die nötigen Batterien ermittelt
                                        •               UNREACH hinzugefügt
                                          
                                        •               STICKY_UNREACH hinzugefügt
                                          
                                        •               CONFIG_PENDING hinzugefügt
                                          
                                        • 31.01.19 V1.02 Pushnachricht optimiert bei LOWBAT
                                        • 01.02.19 V1.03 UPDATE_PENDING hinzugefügt
                                        •               DEVICE_IN_BOOTLOADER hinzugefügt
                                          
                                        •               ERROR hinzugefügt
                                          
                                        •               FAULT_REPORTING hinzugefügt
                                          
                                        •               Debugging erweitert
                                          
                                        • 01.02.19 V1.04 Fehler behoben bei ERROR und FAULT_REPORTING
                                        • 02.02.19 V1.05 Status Texte für ERRPR und FAULT_Reporting hinzugefügt
                                          Pushmitteilung optimiert für ERROR und FAULT_Reporting
                                          Anpassung Debugtexte
                                          Prio ist pro Fehlertyp einstellbar
                                          **************************/
                                          var logging = true;
                                          var debugging = true;
                                          var sendpush = true;
                                          var autoAck = false; //Löschen bestätigbarer Kommunikationsstörungen (true = an, false = aus)

                                        ! //pro Fehlertyp kann eine andere Prio genutzt werden
                                        var prio_LOWBAT = 0;
                                        var prio_UNREACH = 0;
                                        var prio_STICKY_UNREACH = 0;
                                        var prio_CONFIG_PENDING = 0;
                                        var prio_UPDATE_PENDING = 0;
                                        var prio_DEVICE_IN_BOOTLOADER = 0;
                                        var prio_ERROR = 0;
                                        var prio_FAULT_REPORTING = 0;
                                        ! var _prio;
                                        var _titel;
                                        var _message;
                                        var _device = 'TPhone';
                                        //var _device = 'All';
                                        ! //Ab hier eigentliches Script
                                        var cacheSelectorLOWBAT = $('channel[state.id=hm-rpc.0..0.LOW_BAT_ALARM$]');
                                        var cacheSelectorUNREACH = $('channel[state.id=hm-rpc.0.
                                        .0.UNREACH_ALARM$]');
                                        var cacheSelectorSTICKY_UNREACH = $('channel[state.id=hm-rpc.0..0.STICKY_UNREACH_ALARM$]');
                                        var cacheSelectorCONFIG_PENDING = $('channel[state.id=hm-rpc.0.
                                        .0.CONFIG_PENDING_ALARM$]');
                                        var cacheSelectorUPDATE_PENDING = $('channel[state.id=hm-rpc.0..0.CONFIG_PENDING_ALARM$]');
                                        var cacheSelectorDEVICE_IN_BOOTLOADER = $('channel[state.id=hm-rpc.0.
                                        .0.DEVICE_IN_BOOTLOADER_ALARM$]');
                                        var cacheSelectorERROR = $('channel[state.id=hm-rpc.0..1.ERROR$]');
                                        var cacheSelectorFAULT_REPORTING = $('channel[state.id=hm-rpc.0.
                                        .4.FAULT_REPORTING$]');
                                        ! function send_pushover_V4 (_device, _message, _titel, _prio) {
                                        var pushover_Instanz = 'pushover.0';
                                        if (_prio === 0){pushover_Instanz = 'pushover.0'}
                                        else if (_prio == 1){pushover_Instanz = 'pushover.1'}
                                        else if (_prio == 2){pushover_Instanz = 'pushover.2'}
                                        else {pushover_Instanz = 'pushover.3'}
                                        sendTo(pushover_Instanz, {
                                        device: _device,
                                        message: _message,
                                        title: _titel,
                                        priority: _prio,
                                        retry: 60,
                                        expire: 600,
                                        html: 1
                                        });
                                        }
                                        ! function LOWBAT(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = 'Batterie ok';
                                        }
                                        else if (status == 1){
                                        status_text = 'Batterie niedrig';
                                        }
                                        else if (status == 2){
                                        status_text = 'Batterie ok';
                                        }
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
                                        var Batterie;
                                        var cr2016 = 'HM-RC-4,HM-RC-4-B,HM-RC-Key3,HM-RC-Key3-B,HM-RC-P1,HM-RC-Sec3,HM-RC-Sec3-B,ZEL STG RM HS 4';
                                        var cr2032 = 'HM-PB-2-WM,HM-PB-4-WM,HM-PBI-4-FM,HM-SCI-3-FM,HM-Sec-TiS,HM-SwI-3-FM,HmIP-FCI1';
                                        var lr14x2 = 'HM-Sec-Sir-WM,HM-OU-CFM-TW';
                                        var lr44x2 = "HM-Sec-SC,HM-Sec-SC2,HM-Sec-SC-2,HM-Sec-RHS";
                                        var lr6x2 = "HM-CC-VD,HM-CC-RT-DN,HM-Sec-WDS,HM-Sec-WDS-2,HM-CC-TC,HM-Dis-TD-T,HB-UW-Sen-THPL-I,HM-TC-IT-WM-W-EU,HM-WDS40-TH-I,HM-WDS40-TH-I-2,HM-WDS10-TH-O,HmIP-SMI,HMIP-eTRV,HM-WDS30-OT2-SM-2,HmIP-SMO,HmIP-SMO-A,HmIP-SPI,HmIP-eTRV-2,HmIP-SPDR,HmIP-SWD";
                                        var lr6x3 = "HmIP-SWO-PL,HM-Sec-MDIR,HM-Sec-MDIR-2,HM-Sec-SD,HM-Sec-Key,HM-Sec-Key-S,HM-Sec-Key-O,HM-Sen-Wa-Od,HM-Sen-MDIR,HM-Sen-MDIR-O,HM-Sen-MDIR-O-2,HM-WDS100-C6-O,HM-WDS100-C6-O-2,HM-WDS100-C6-O-2,HmIP-ASIR,HmIP-SWO-B";
                                        var lr6x4 = "HM-CCU-1,HM-ES-TX-WM,HM-WDC7000";
                                        var lr3x1 = "HM-RC-4-2,HM-RC-4-3,HM-RC-Key4-2,HM-RC-Key4-3,HM-RC-Sec4-2,HM-RC-Sec4-3,HM-Sec-RHS-2,HM-Sec-SCo,HmIP-KRC4,HmIP-KRCA,HmIP-RC8,HmIP-SRH,HMIP-SWDO";
                                        var lr3x2 = "HM-Dis-WM55,HM-Dis-EP-WM55,HM-PB-2-WM55,HM-PB-2-WM55-2,HM-PB-6-WM55,HM-PBI-2-FM,HM-RC-8,HM-Sen-DB-PCB,HM-Sen-EP,HM-Sen-MDIR-SM,HM-Sen-MDIR-WM55,HM-WDS30-T-O,HM-WDS30-OT2-SM,HmIP-STH,HmIP-STHD,HMIP-WRC2,HMIP-WRC6,HMIP-WTH,HMIP-WTH-2,HmIP-SAM,HmIP-SLO,HMIP-SWDO-I,HmIP-FCI6";
                                        var lr3x3 = "HM-PB-4Dis-WM,HM-PB-4Dis-WM-2,HM-RC-Dis-H-x-EU,HM-Sen-LI-O";
                                        var lr3x3a = "HM-RC-19,HM-RC-19-B,HM-RC-12,HM-RC-12-B,HM-RC-12-W";
                                        var block9 = "HM-LC-Sw1-Ba-PCB,HM-LC-Sw4-PCB,HM-MOD-EM-8,HM-MOD-Re-8,HM-Sen-RD-O,HM-OU-CM-PCB,HM-LC-Sw4-WM";
                                        var fixed = "HM-Sec-SD-2,HMIP-SWSD";
                                        var recharge = "HM-Sec-Win,HM-Sec-SFA-SM";
                                        var Treffer1 = cr2016.search(native_type);
                                        var Treffer2 = cr2032.search(native_type);
                                        var Treffer3 = lr14x2.search(native_type);
                                        var Treffer4 = lr44x2.search(native_type);
                                        var Treffer5 = lr6x2.search(native_type);
                                        var Treffer6 = lr6x3.search(native_type);
                                        var Treffer7 = lr6x4.search(native_type);
                                        var Treffer8 = lr3x1.search(native_type);
                                        var Treffer9 = lr3x2.search(native_type);
                                        var Treffer10 = lr3x3.search(native_type);
                                        var Treffer11 = lr3x3a.search(native_type);
                                        var Treffer12 = block9.search(native_type);
                                        var Treffer13 = fixed.search(native_type);
                                        var Treffer14 = recharge.search(native_type);
                                        if(Treffer1 >= 0){Batterie = '1x CR2016';}
                                        else if(Treffer2 >= 0){Batterie = '1x CR2032';}
                                        else if(Treffer3 >= 0){Batterie = '2x LR14';}
                                        else if(Treffer4 >= 0){Batterie = '2x LR44/AG13';}
                                        else if(Treffer5 >= 0){Batterie = '2x LR6/AA';}
                                        else if(Treffer6 >= 0){Batterie = '3x LR6/AA';}
                                        else if(Treffer7 >= 0){Batterie = '4x LR6/AA';}
                                        else if(Treffer8 >= 0){Batterie = '1x LR3/AAA';}
                                        else if(Treffer9 >= 0){Batterie = '2x LR3/AAA';}
                                        else if(Treffer10 >= 0){Batterie = '3x LR3/AAA';}
                                        else if(Treffer11 >= 0){Batterie = '3x AAA Akkus - bitte laden';}
                                        else if(Treffer12 >= 0){Batterie = '9Volt Block leer oder unbestimmt';}
                                        else if(Treffer13 >= 0){Batterie = 'Festbatterie leer';}
                                        else if(Treffer14 >= 0){Batterie = 'Akku entladen - bitte aufladen';}
                                        else{Batterie = 'unbekannt';}
                                        var meldungsart = id.split('.')[4];
                                        //const native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;

                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Spannung Batterien/Akkus gering. '+Batterie+'\n';
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu +' ---' +Batterie);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_LOWBAT;
                                                _titel = 'Servicemeldung';
                                                _message = 'Batteriewarnung ausgelöst von: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function UNREACH(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorUNREACH.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = status;
                                        }
                                        else {
                                        status_text = status;
                                        }

                                            var obj    = getObject(id);
                                            var common_name =  getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                            var id_name = id.split('.')[2];
                                            var meldungsart = id.split('.')[4];
                                            var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                            var datum_neu;
                                            if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                            var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
                                        
                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Kommunikation gestört. '+'\n';
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit UNREACH ' +Gesamt +' Stück, davon Geräte mit UNREACH: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_UNREACH;
                                                 _titel = 'Servicemeldung';
                                                _message = 'Kommunikation gestört von: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit UNREACH: ' +Gesamt +' Stück, davon Geräte mit UNREACH: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function STICKY_UNREACH(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorSTICKY_UNREACH.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = status;
                                        }
                                        else {
                                        status_text = status;
                                        }
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;

                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                if(autoAck){
                                                    _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Meldung über bestätigbare Kommunikationsstörung gelöscht. '+'\n';
                                                }
                                                else {
                                                    _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - bestätigbare Kommunikationsstörung. '+'\n';    
                                                }
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit STICKY_UNREACH ' +Gesamt +' Stück, davon Geräte mit STICKY_UNREACH: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = 0; 
                                                _titel = 'Servicemeldung';
                                                _message = 'Kommunikation war gestört: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit STICKY_UNREACH ' +Gesamt +' Stück, davon Geräte mit STICKY_UNREACH: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function CONFIG_PENDING(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorCONFIG_PENDING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = status;
                                        }
                                        else {
                                        status_text = status;
                                        }
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;

                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Konfigurationsdaten stehen zur Übertragung an. '+'\n';
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit CONFIG_PENDING ' +Gesamt +' Stück, davon Geräte mit CONFIG_PENDING: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_UPDATE_PENDING; 
                                                 _titel = 'Servicemeldung';
                                                _message = 'CONFIG_PENDING: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit CONFIG_PENDING ' +Gesamt +' Stück, davon Geräte mit CONFIG_PENDING: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function UPDATE_PENDING(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorUPDATE_PENDING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = status;
                                        }
                                        else {
                                        status_text = status;
                                        }
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;

                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Update verfügbar. '+'\n';
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit UPDATE_PENDING ' +Gesamt +' Stück, davon Geräte mit UPDATE_PENDING: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_UPDATE_PENDING; 
                                                 _titel = 'Servicemeldung';
                                                _message = 'UPDATE_PENDING: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit UPDATE_PENDING ' +Gesamt +' Stück, davon Geräte mit UPDATE_PENDING: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function DEVICE_IN_BOOTLOADER(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorDEVICE_IN_BOOTLOADER.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        if(status === 0){
                                        status_text = status;
                                        }
                                        else {
                                        status_text = status;
                                        }
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;

                                            if (status === 1) {      // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                                ++Betroffen;
                                                text.push(id_name + ' ' +common_name);                           // Zu Array hinzufügen
                                                _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - Gerät startet neu. '+'\n';
                                        
                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit DEVICE_IN_BOOTLOADER ' +Gesamt +' Stück, davon Geräte mit DEVICE_IN_BOOTLOADER: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_DEVICE_IN_BOOTLOADER; 
                                                 _titel = 'Servicemeldung';
                                                _message = 'DEVICE_IN_BOOTLOADER: '+'\n';
                                                _message = _message +  _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit Batteriewarnung ' +Gesamt +' Stück, davon Geräte mit LOWBAT: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function ERROR(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorERROR.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
                                        if((native_type == 'HM-Sec-RHS') || (native_type == 'HM-Sec-RHS-2') || (native_type == 'HM-Sec-SC') || (native_type == 'HM-Sec-SC-2') ||
                                        (native_type == 'HM-Sec-SCo') || (native_type == 'HM-Sec-MD') || (native_type == 'HM-Sec-MDIR') || (native_type == 'HM-Sec-MDIR-2')){
                                        if(status == 7){
                                        status_text = 'Sabotage';
                                        }
                                        else {
                                        status_text = 'ERROR mit dem Wert: ' +status;
                                        }
                                        }
                                        else if ((native_type=='HM-Sec-Key') || (native_type=='HM-Sec-Key-S') || (native_type=='HM-Sec-Key-O')){
                                        if(status == 1){
                                        status_text = 'Einkuppeln fehlgeschlagen';
                                        }
                                        else if(status == 2){
                                        status_text = 'Motorlauf abgebrochen';
                                        }
                                        else {
                                        status_text = 'ERROR mit dem Wert: ' +status;
                                        }
                                        }
                                        else if (native_type=='HM-CC-VD'){
                                        if(status == 1){
                                        status_text = 'Ventil Antrieb blockiert';
                                        }
                                        else if(status == 2){
                                        status_text = 'Ventil nicht montiert';
                                        }
                                        else if(status == 3){
                                        status_text = 'Stellbereich zu klein';
                                        }
                                        else if(status == 4){
                                        status_text = 'Batteriezustand niedrig';
                                        }
                                        else {
                                        status_text = 'ERROR mit dem Wert: ' +status;
                                        }
                                        }
                                        else {
                                        status_text = 'ERROR mit dem Wert: ' +status;
                                        }
                                        if (status > 0) { // wenn Zustand größer 0, dann wird die Anzahl der Geräte hochgezählt
                                        ++Betroffen;
                                        text.push(id_name + ' ' +common_name); // Zu Array hinzufügen
                                        _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - '+status_text +'. '+'\n';

                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit ERROR ' +Gesamt +' Stück, davon Geräte mit ERROR: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_ERROR; 
                                                 _titel = 'Servicemeldung';
                                                _message = _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit ERROR ' +Gesamt +' Stück, davon Geräte mit ERROR: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! function FAULT_REPORTING(obj) {
                                        // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                        var Gesamt = 0;
                                        var Betroffen = 0;
                                        var text = [];
                                        var _message_tmp = ' ';

                                        if (obj) {
                                        log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                        } else {
                                        log('Ausgelöst durch Scriptneustart.');
                                        }

                                        ! cacheSelectorFAULT_REPORTING.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                        var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                        var status_text;
                                        var obj = getObject(id);
                                        var common_name = getObject(id).common.name.substr(0, obj.common.name.indexOf(':'));
                                        var id_name = id.split('.')[2];
                                        var meldungsart = id.split('.')[4];
                                        var datum = formatDate(getState(id).lc, "TT.MM.JJ SS:mm:ss");
                                        var datum_neu;
                                        if(datum < '01.01.71 01:00:00'){datum_neu = '-';}else{datum_neu = datum +' Uhr';}
                                        var native_type = getObject(id.substring(0, id.lastIndexOf('.') - 2)).native.TYPE;
                                        if(native_type == 'HM-CC-RT-DN'){
                                        if(status === 0){
                                        status_text = 'keine Störung';
                                        }
                                        else if(status == 1){
                                        status_text = 'Ventil blockiert';
                                        }
                                        else if(status == 2){
                                        status_text = 'Einstellbereich Ventil zu groß';
                                        }
                                        else if(status == 3){
                                        status_text = 'Einstellbereich Ventil zu klein';
                                        }
                                        else if(status == 4){
                                        status_text = 'Kommunikationsfehler';
                                        }
                                        else if(status == 6){
                                        status_text = 'Spannung Batterien/Akkus gering';
                                        }
                                        else if(status == 7){
                                        status_text = 'Fehlstellung Ventil';
                                        }
                                        else{
                                        status_text = 'FAULT_REPORTING mit dem Wert: ' +status;
                                        }
                                        }
                                        else{
                                        status_text = 'FAULT_REPORTING mit dem Wert: ' +status;
                                        }
                                        if (status > 0) { // wenn Zustand größer 0, dann wird die Anzahl der Geräte hochgezählt
                                        ++Betroffen;
                                        text.push(id_name + ' ' +common_name); // Zu Array hinzufügen
                                        _message_tmp = _message_tmp +common_name +' ('+id_name +')' + ' - ' +status_text +'. '+'\n';

                                            }  
                                            ++Gesamt;                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                            if(debugging){
                                                log(' Geräte Nr. ' +i + ': Serien-Nr. ' +id_name +' --- Name: '+ common_name +' --- '+native_type +' --- Typ: '+meldungsart +' --- Status: ' +status +' ' +status_text +' --- seit: '+datum_neu);
                                            }
                                        
                                        }); 
                                        

                                        ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                        if(Betroffen > 0){
                                        if(logging){
                                        log('Anzahl möglicher Geräte mit FAULT_REPORTING ' +Gesamt +' Stück, davon Geräte mit FAULT_REPORTING: '+Betroffen + ' Stück.');
                                        log('Betroffene Geräte: ' + text.join(', '));

                                           }
                                           //Push verschicken
                                            if(sendpush){
                                                _prio = prio_FAULT_REPORTING; 
                                                 _titel = 'Servicemeldung';
                                                _message = _message_tmp;
                                        
                                                //_message =  "Ausgelöst von: "+'test' +"test2";
                                                send_pushover_V4(_device, _message, _titel, _prio);
                                            }
                                        }
                                        else{
                                            if(debugging){
                                                log('Anzahl möglicher Geräte mit FAULT_REPORTING ' +Gesamt +' Stück, davon Geräte mit FAULT_REPORTING: '+Betroffen + ' Stück.');
                                        
                                            }
                                        }
                                        

                                        }

                                        ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
                                        LOWBAT(obj);
                                        });
                                        /

                                        cacheSelectorUNREACH.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        UNREACH(obj);
                                        });
                                        ! cacheSelectorSTICKY_UNREACH.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        STICKY_UNREACH(obj);
                                        });
                                        ! cacheSelectorCONFIG_PENDING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        CONFIG_PENDING(obj);
                                        });
                                        ! cacheSelectorUPDATE_PENDING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        UPDATE_PENDING(obj);
                                        });
                                        ! cacheSelectorDEVICE_IN_BOOTLOADER.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        DEVICE_IN_BOOTLOADER(obj);
                                        });
                                        cacheSelectorERROR.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        ERROR(obj);
                                        });
                                        cacheSelectorFAULT_REPORTING.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                        FAULT_REPORTING(obj);
                                        });
                                        */
                                        ! //beim Start
                                        LOWBAT();
                                        //UNREACH();
                                        //STICKY_UNREACH();
                                        //CONFIG_PENDING();
                                        //UPDATE_PENDING();
                                        //DEVICE_IN_BOOTLOADER();
                                        //ERROR();
                                        //FAULT_REPORTING();
                                        ! ````

                                        3822_bildschirmfoto_2019-02-02_um_23.22.46.png

                                        IN rpc.0 sind HMIP und in rpc.1 sind normale

                                        (kann aber sein das da noch cuxd und virtuelle rum schwirren, ich habe schon länger nicht aktualisiert bzw. gelöscht. Ich hatte cuxd und virtuell mal probiert.

                                        Kann aber sein das da auch Heizgruppen von der CCU drinn sind ,die sind ja auch virtuell)
                                        3822_bildschirmfoto_2019-02-02_um_23.26.26.png

                                        PS: in allen Kommentaren steht noch LOWBAT, das sollten wir/Du noch korrigieren) 😄

                                        1 Reply Last reply Reply Quote 0
                                        • cash
                                          cash Most Active last edited by

                                          Du hast LOW_BAT sowohl in hm.rpc.0 und 1.

                                          Klapp mal bitte bei Instanzen auf. Und bitte auch jeweils ein Gerät damit ich sehe in welchen Kanal dann etwas ist.

                                          ! 1407_bildschirmfoto_2019-02-03_um_09.48.13.png

                                          Und was heißt sobald ich mehr dazu nehme werden mir wieder 0 mögliche Geräte angezeigt?

                                          1 Reply Last reply Reply Quote 0
                                          • cash
                                            cash Most Active last edited by

                                            Neuer Tag neue Version.

                                            Im erstenPost habe ich das aktualisierte Script mit der Version 1.06 vom 03.02.19 veröffentlicht.

                                            Bitte den kompletten Beitrag nochmal lesen. Ich habe Änderungen in der Grundkonfig vorgenommen die man anpassen sollte.

                                            Folgende Sachen habe ich verändert:

                                            03.02.19 V1.06 Batterien ermitteln in eigene function ausgelagert

                                            • LOW_BAT aufgenommen

                                            • SABOTAGE aufgenommen

                                            • Neu Configmöglichkeit onetime für einmaliges prüfem

                                            • Neue Configmöglichkeit observation für Dauerhafte Überwachung

                                            • Fehler CONFIG_PENDING behoben

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            906
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript
                                            93
                                            1038
                                            231876
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo