Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Vorlage] Servicemeldungen Volume2

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Servicemeldungen Volume2

    This topic has been deleted. Only users with topic management privileges can see it.
    • L
      looxer01 @emil70 last edited by looxer01

      @emil70
      Hi
      es scheint, dass du viele Geräte hast und damit viele Datenpunkte.
      Bei mir sind es 270 Datenpunkte bei 80 Geräten.
      Bei dir sind es 565 Datenpunkte - wieviel Geräte hast du ?

      Die Meldung kommt nur beim Start des Scripts. Das kannst du aktzeptieren die Warnmeldung in den Einstellungen des Javascript Adapters hochsetzen.

      vG Looxer

      Edit:
      Alternativ kannst du diese Einstellung verwenden:
      // wenn GeraeteIDTrigger auf true gestellt wird, dann wird fuer jeden Datenpukt mit Relevanz fuer eine Servicemeldung eine subscription angelegt.
      // Vorteil ist, dass auch eine Historie und ein Log fuer Servicemeldungen geschrieben werden kann: Nachteil: bei 80 CCU Geraeten ungefaehr 300 Susbsriptions
      // Wenn die variable auf false steht, dann wird auf hm.rega.0.maintenance eine subsription angelegt: Vorteil: 1 Subscription , Nachteil: keine Servicemeldungs Historie
      const GeraeteIDTrigger = false;
      bei false wird nicht über die Geräte-IDs getriggert.
      Das hat aber dann funktional Einschränkungen zur Folge:

      • keine vergangene Servicemeldungen
      • kein Externes Log
      E Samson71 2 Replies Last reply Reply Quote 0
      • E
        emil70 @looxer01 last edited by emil70

        @looxer01 sagte in [Vorlage] Servicemeldungen Volume2:

        habe ca 130 Homematic Geräte, wenn du die meinst

        Schau ich mir mal an

        Edit:

        const GeraeteIDTrigger = true; 
        

        steht so

        Edit 2: bei

        const GeraeteIDTrigger = false; 
        

        kommt die Meldung nicht

        L 1 Reply Last reply Reply Quote 0
        • Samson71
          Samson71 Global Moderator @looxer01 last edited by

          @looxer01
          Die Info ist für mich ziemlich wichtig. Danke. Ich komme erst am WE zum Testen, aber dann mit gut 180 Geräten. Das dürfte dann deutlich heftiger ausfallen als mit nur 80. Da werde ich dann auf jeden Fall besser auf die Historie verzichten.

          L 1 Reply Last reply Reply Quote 0
          • L
            looxer01 @emil70 last edited by

            @emil70 sagte in [Vorlage] Servicemeldungen Volume2:

            kommt die Meldung nicht

            genau, da wird nur eine einzige subscription geschrieben.

            1 Reply Last reply Reply Quote 0
            • L
              looxer01 @Samson71 last edited by looxer01

              @samson71 sagte in [Vorlage] Servicemeldungen Volume2:

              Da werde ich dann auf jeden Fall besser auf die Historie verzichten.

              teste doch beides und schau mal ob sich in der performance Unterschiede zeigen.
              Ich bin eher der Meinung, dass die Zahl der Subscriptions vermutlich nicht so ausschlaggebend ist.
              Sie kosten etwas (minimal) Speicher.
              Die Performance wird konsumiert, wenn subscriptions ausgelöst werden und wenn dies oft passiert.

              BTW: ich habe eine Sicherheit eingebaut , wenn es mehr als 50 IDS sind, die innerhalb kurzer Zeit ausgelöst werden.
              Dann pausiert das script für 5 Minuten, bis dann irgendwann der workload abgearbeitet ist.
              So möchte ich verhindern, dass es einen overload in Extremsituationen gibt
              (z.B. bei Stromausfall und einer USV, die CCU und iobroker alive hält. In dieser Situation gäbe es eine Menge Servicemeldungen)

              vG Looxer

              Edit:
              Ich hatte für eine ganze Zeit das alte Servicemeldungssript parallel im Einsatz und damit mehr als doppelt soviel IDs subcribed. (ca 570 subscriptions). Ich habe keinen Unterschied bemerkt, allerdings habe ich einen recht performanten Rechner.

              1 Reply Last reply Reply Quote 0
              • L
                looxer01 last edited by

                Hi

                Ich habe im ersten post noch ein script eingestellt, das die Batterien eurer Geräte checkt.
                Wenn ihr Geräte habt, die noch nicht in der Liste des Servicemeldungsscripts enthalten sind, dann werden diese gelistet
                Ihr könnt die mir dann mitteilen, idealerweise gleich Native Bezeichnung (aus dem Script) und der Bezeichnung der
                Batterien. Wird dann in das Servicemeldungsscript eingepflegt.

                vG Looxer

                1 Reply Last reply Reply Quote 0
                • rantanplan
                  rantanplan @looxer01 last edited by

                  @looxer01 Schönes Script!

                  Es wäre noch gut, wenn man eine Messenger Instanz und einen Empfänger eintragen könnte.
                  Ich habe es mit Telegram probiert und da bekommen alle eine Meldung.
                  Oder habe ich etwas übersehen?

                  Grüße

                  L 1 Reply Last reply Reply Quote 0
                  • L
                    looxer01 @rantanplan last edited by

                    @rantanplan
                    Hi, bin gerade beruflich unterwegs.
                    Anschauen kann ich mir das nächste Woche.
                    Was meinst du mit , dass alle eine Meldung bekommen?

                    Vg looxer

                    rantanplan Quarkmax 2 Replies Last reply Reply Quote 0
                    • rantanplan
                      rantanplan @looxer01 last edited by

                      @looxer01 sagte in [Vorlage] Servicemeldungen Volume2:

                      Was meinst du mit , dass alle eine Meldung bekommen?

                      Hi, ich habe mehrere Telegram-Benutzer, die unterschiedliche Meldungen aus ioBroker bekommen.
                      Die Servicemeldungen aus Deinem Script werden an alle Benutzer gesendet, die in der Instanz Telegram.0 eingetragen sind.

                      Grüße

                      1 Reply Last reply Reply Quote 0
                      • Quarkmax
                        Quarkmax @looxer01 last edited by

                        @looxer01

                        zum Batteriescript als Ergänzung

                        2x AAA: , 'HmIP-STV', 'HmIP-WKP'
                        2x AA: , 'ELV-SH-SW1-BAT'
                        3x AA: , 'HmIP-ASIR-2'
                        

                        Danke

                        1 Reply Last reply Reply Quote 1
                        • L
                          looxer01 last edited by looxer01

                          Hi,
                          neue Versionen sind online.

                          Servicmeldungsscript Version 1.05:

                          • Fix fuer Status 0 fuer historische Meldungen. Text aus Tabelle: StandardstatusMessages verwendet // Text angepasst in Tabelle fuer 0
                          • Batteriemeldung erweitert
                          • Telegram Instanz und User hinzugefügt
                          • WICHTIGE Aenderung fuer REGA subscription: Intelligenterer Umgang bei vielen Aenderungen von Anzahl der Servicmeldungen aus der CCU

                          Batteriescript Version 1.1

                          • doppelte Listungen verhindert, wenn alle Geräte gelistet werden
                          • Native IDs für aa und aaa batterien hinzugefügt // Danke an Quarkmax
                          1 Reply Last reply Reply Quote 4
                          • Knallochse
                            Knallochse last edited by Knallochse

                            Ich habe eine Sabotage Meldung provoziert. Die Nachricht wird auch versendet (Telegram) aber der Zähler (Anzahl_SABOTAGE) steht bei mir auf 0

                            Screenshot 2024-11-11 071658.png

                            Es wäre super, wenn man noch die Anzahl der zu überwachenden Instanzen konfigurieren könnte.
                            Ich habe 4 rpc Instanzen.
                            rpc.0 = CUxD
                            rpc.1 = Homematic
                            rpc.2 = Homematic IP
                            rpc.3 = Virtuelle (Gruppen)

                            L 1 Reply Last reply Reply Quote 0
                            • L
                              looxer01 @Knallochse last edited by looxer01

                              @knallochse
                              Hi,
                              bei Homematic classic werden die Sabotage Meldungen unter MessageType "Error" geführt und da ist auch der Zähler bei dir auf 1. Das ist anders bei HMIP. Da werden die Sabotage Meldungen unter Sabotage geführt.
                              Ich könnte das zwar code technisch abfangen. Das wäre aber irgendwie schon sehr Spaghetti.

                              zu den instanzen.
                              CUxD. Das sind ja vermutlich keine HM-Geräte, die darunter laufen. Da also die Datenstrukturen vermutlich anders sind, sind dann auch die Meldungen nicht identisch. Ich habe keine Ahnung wie das funktioniert.

                              Die anderen schaue ich mir an.
                              Die virtuellen Gruppen habe ich z.Zt draußengelassen. Der Mehrwert bei Meldungen zur Gruppe ist ohnehin fragwürdig. Allerdings sind die nur auskommentiert im Coding und lassen sich einfach aktivieren.

                              vG Looxer

                              Edit: also eigentlich lassen sich die Instanzen ja jetzt schon konfigurieren.
                              Im Grunde müssen ja nur die vorgegebenen Instanzen um 1 erhöht werden.
                              Das befindet sich in den "Experteneinstellungen":

                              const idsUNREACH = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id));
                              // @ts-ignore
                              // $('state[id=hm-rpc.2.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id)); // auskommentiert keine Gruppenmeldungen
                              
                              const idsSTICKY_UNREACH = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.2.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));      // auskommentiert keine Gruppenmeldungen
                              
                              const idsConfig_Pending = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));
                              // @ts-ignore
                              // $('state[id=hm-rpc.2.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));   // auskommentiert keine Gruppenmeldungen
                              
                              const idsUPDATE_PENDING_ALARM = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id)); 
                              // @ts-ignore
                              //$('state[id=hm-rpc.2.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id)); // auskommentiert keine Gruppenmeldungen
                              
                              const idsLOWBAT_ALARM = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.LOWBAT_ALARM]').each(id =>  idsLOWBAT_ALARM.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.LOW_BAT_ALARM]').each(id => idsLOWBAT_ALARM.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.2.*.LOW_BAT_ALARM]').each(id => idsLOWBAT_ALARM.push(id));                   // auskommentiert keine Gruppenmeldungen
                              
                              const idsDEVICE_IN_BOOTLOADER_ALARM = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.DEVICE_IN_BOOTLOADER_ALARM]').each(id => idsDEVICE_IN_BOOTLOADER_ALARM.push(id)); // nur HM-Classic
                              
                              const idsERROR = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.ERROR]').each(id => idsERROR.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.ERROR]').each(id => idsERROR.push(id));
                              // @ts-ignore
                              // $('state[id=hm-rpc.2.*.ERROR]').each(id => idsERROR.push(id));                               // auskommentiert keine Gruppenmeldungen
                              
                              const idsFAULT_REPORTING = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.FAULT_REPORTING]').each(id => idsFAULT_REPORTING.push(id));              // nur HM-Classic
                              
                              const idsSABOTAGE_ALARM = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));
                              // @ts-ignore
                              //$('state[id=hm-rpc.2.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));              // auskommentiert keine Gruppenmeldungen
                              
                              const idsERROR_NON_FLAT_POSITIONING_ALARM = [];
                              // @ts-ignore
                              $('state[id=hm-rpc.0.*.ERROR_NON_FLAT_POSITIONING_ALARM]').each(id => idsERROR_NON_FLAT_POSITIONING_ALARM.push(id));
                              // @ts-ignore
                              $('state[id=hm-rpc.1.*.ERROR_NON_FLAT_POSITIONING_ALARM]').each(id => idsERROR_NON_FLAT_POSITIONING_ALARM.push(id));
                              
                              
                              Knallochse 1 Reply Last reply Reply Quote 0
                              • Knallochse
                                Knallochse @looxer01 last edited by Knallochse

                                @looxer01 sagte in [Vorlage] Servicemeldungen Volume2:

                                @knallochse
                                Hi,
                                bei Homematic classic werden die Sabotage Meldungen unter MessageType "Error" geführt und da ist auch der Zähler bei dir auf 1. Das ist anders bei HMIP. Da werden die Sabotage Meldungen unter Sabotage geführt.
                                Ich könnte das zwar code technisch abfangen. Das wäre aber irgendwie schon sehr Spaghetti.

                                Dann hab ich es verstanden. Ich bräuchte keine Änderung.

                                zu den instanzen.
                                CUxD. Das sind ja vermutlich keine HM-Geräte, die darunter laufen. Da also die Datenstrukturen vermutlich anders sind, sind dann auch die Meldungen nicht identisch. Ich habe keine Ahnung wie das funktioniert.

                                Eine Überwachung der CUxD Geräte vom Skript ist nicht nötig. Aber die rpc.0 Instanz wird ja überwacht, und die Geräte zur Überwachung befinden sich ja in anderen Instanzen. Wird dann noch alles richtig zugeordnet bzw. überwacht?

                                Die anderen schaue ich mir an.
                                Die virtuellen Gruppen habe ich z.Zt draußengelassen. Der Mehrwert bei Meldungen zur Gruppe ist ohnehin fragwürdig. Allerdings sind die nur auskommentiert im Coding und lassen sich einfach aktivieren.

                                In den Gruppen befinden sich ja die einzelnen Geräte und diese werden ja schon überwacht.

                                vG Looxer

                                L 1 Reply Last reply Reply Quote 0
                                • Knallochse
                                  Knallochse last edited by

                                  Von meiner Seite vielen Dank für dein Skript. Schön, dass du dich der Sache annimmst.

                                  1 Reply Last reply Reply Quote 1
                                  • L
                                    looxer01 @Knallochse last edited by looxer01

                                    @knallochse sagte in [Vorlage] Servicemeldungen Volume2:

                                    Eine Überwachung vom Skript ist nicht nötig. Aber die rpc.0 Instanz wird ja überwacht, und die Geräte zur Überwachung befinden sich ja in anderen Instanzen. Wird dann noch alles richtig zugeordnet bzw. überwacht?

                                    ich denke ja. Dann muß also CuxD einfach nur auschgeschlossen werden.

                                    @knallochse sagte in [Vorlage] Servicemeldungen Volume2:

                                    In den Gruppen befinden sich ja die einzelnen Geräte und diese werden ja schon überwacht.

                                    genau, also ist die Hinzunahme der Gruppen nicht notwendig.

                                    Ich habe für dich die Configuration im folgenden Code gemacht. Diesen müßtest du durch den Vorhandenen ersetzen.

                                    const idsUNREACH = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id));
                                    // @ts-ignore
                                    // $('state[id=hm-rpc.3.*.UNREACH_ALARM]').each(id => idsUNREACH.push(id)); // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsSTICKY_UNREACH = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));
                                    // @ts-ignore
                                    //$('state[id=hm-rpc.3.*.STICKY_UNREACH_ALARM]').each(id => idsSTICKY_UNREACH.push(id));      // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsConfig_Pending = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));
                                    // @ts-ignore
                                    // $('state[id=hm-rpc.3.*.CONFIG_PENDING_ALARM]').each(id => idsConfig_Pending.push(id));   // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsUPDATE_PENDING_ALARM = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id)); 
                                    // @ts-ignore
                                    //$('state[id=hm-rpc.3.*.UPDATE_PENDING_ALARM]').each(id => idsUPDATE_PENDING_ALARM.push(id)); // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsLOWBAT_ALARM = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.LOWBAT_ALARM]').each(id =>  idsLOWBAT_ALARM.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.LOW_BAT_ALARM]').each(id => idsLOWBAT_ALARM.push(id));
                                    // @ts-ignore
                                    //$('state[id=hm-rpc.3.*.LOW_BAT_ALARM]').each(id => idsLOWBAT_ALARM.push(id));                   // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsDEVICE_IN_BOOTLOADER_ALARM = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.DEVICE_IN_BOOTLOADER_ALARM]').each(id => idsDEVICE_IN_BOOTLOADER_ALARM.push(id)); // nur HM-Classic
                                    
                                    const idsERROR = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.ERROR]').each(id => idsERROR.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.ERROR]').each(id => idsERROR.push(id));
                                    // @ts-ignore
                                    // $('state[id=hm-rpc.3.*.ERROR]').each(id => idsERROR.push(id));                               // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsFAULT_REPORTING = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.FAULT_REPORTING]').each(id => idsFAULT_REPORTING.push(id));              // nur HM-Classic
                                    
                                    const idsSABOTAGE_ALARM = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));
                                    // @ts-ignore
                                    //$('state[id=hm-rpc.3.*.SABOTAGE_ALARM]').each(id => idsSABOTAGE_ALARM.push(id));              // auskommentiert keine Gruppenmeldungen
                                    
                                    const idsERROR_NON_FLAT_POSITIONING_ALARM = [];
                                    // @ts-ignore
                                    $('state[id=hm-rpc.1.*.ERROR_NON_FLAT_POSITIONING_ALARM]').each(id => idsERROR_NON_FLAT_POSITIONING_ALARM.push(id));
                                    // @ts-ignore
                                    $('state[id=hm-rpc.2.*.ERROR_NON_FLAT_POSITIONING_ALARM]').each(id => idsERROR_NON_FLAT_POSITIONING_ALARM.push(id));
                                    
                                    1 Reply Last reply Reply Quote 1
                                    • Knallochse
                                      Knallochse last edited by

                                      @looxer01 Vielen Dank.
                                      Ich habe den Code durch deinen ersetzt. Ich beobachte das ganze mal eine Weile.
                                      Schade, dass sich Batteriemeldungen schlecht simulieren lassen.

                                      L 1 Reply Last reply Reply Quote 0
                                      • L
                                        looxer01 @Knallochse last edited by

                                        @knallochse
                                        sehr gerne.
                                        Ich mache die Instanz wahrscheinlich noch variabel. Dann ist es einfacher anzupassen für alle die, die CuxD verwenden

                                        1 Reply Last reply Reply Quote 1
                                        • L
                                          looxer01 last edited by looxer01

                                          Hi,
                                          Version 1.06 ist online:

                                          • GruppenSelektoren auskommentiert fuer unreach#
                                          • Korrektur fuer REGA subcription:Timer variable zuruecksetzen
                                          • HM-Classic Sabotage counts werden umgeleitet von error auf Sabotage
                                          • Instanzen zur Selektion sind jetzt als Variable definiert - z.B. um CuxD auszuschliessen

                                          Looxer01

                                          Knallochse 1 Reply Last reply Reply Quote 2
                                          • Knallochse
                                            Knallochse @looxer01 last edited by Knallochse

                                            @looxer01 mit der 1.6 scheint der Zähler bei Auslösen eines Sabotage Aktors nicht mehr zu funktionieren
                                            Screenshot 2024-11-12 214454.png

                                            in der Nachricht (Telegram) steht SABOTAGE

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            662
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            12
                                            219
                                            17364
                                            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