Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Script] MessageHandler: Nachrichten protokollieren +VIS

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.5k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

[Script] MessageHandler: Nachrichten protokollieren +VIS

Scheduled Pinned Locked Moved JavaScript
336 Posts 25 Posters 70.1k Views 40 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • T Tirador

    Ich habe ein paar Skript erstellt als Infrastruktur zur Protokollierung von Nachrichten/Ereignissen.
    Zusätzlich gibt es ein MDCSS v2 Widget, dass die protokollierten Nachrichten anzeigt.
    Nachrichten können damit als kompakte Darstellung des globalen Systemzustands in VIS verwendet werden.

    Die Idee ist es, alle relevanten Informationen auf "einen Blick" zu erkennen. Wichtige und kritische Ereignisse werden daher in der Liste zentral oben platziert. Unwichtigere Informationen eher unten.

    Beispiel Vis-Ansicht:
    demo_messagehandler.gif

    Beispiel: Lovelace-Ansicht
    lovelace.png

    Kernfunktionen:

    • Ermöglicht es Nachrichten aus Skripten auszulösen und zu entfernen. Dies kann über zwei Wege erfolgen:

      • Automatisches Erzeugen/Entfernen von Nachrichten über das Javascript MessageStateCreator.

        • Es werden konfigurierte Datenpunkte überwacht und bei konfigurierten Bedingungen Nachrichten erzeugt oder auch entfernt.
        • Die Textausgabe der Nachrichten kann auch konfiguriert werden und dynamisch erzeugt werden.
        • Nachrichten können erst nach einer Verzögerungszeit ausgelöst werden.
        • Nachrichten können kontinuierlich nach einer Wiederholungszeit ausgelöst werden (dient zum erneuten Senden von Pushs per Email / Telegram)
      • Javascript-Funktionen postMessage(..) oder removeMessage(..) für den Einsatz in eigenen Skripten.

    • Es können entweder alle Nachrichten eines Nachrichtentyps protokolliert werden oder immer nur die letzte eingetretende Nachricht.

    • Nachrichten werden nach Prioritäten visuell in VIS dargestellt. Es stehen zwei VIS-Ausgaben zur Verfügung:

      • einfache HTML-Tabelle (ohne Schnickschnack)
    • Lovelace-Kartenausgabe über Markdown-Card mit Datenpunkt {0_userdata.0.messageHandler.messages.markdown}

    • Material Design CSS 2.0 Card für Uhula.

    • Nachrichten können (optional) in VIS global und auch einzeln quittiert werden.

    • Nachrichten können mit einem VIS-View verknüpft werden. Aus dem VIS Widget kann somit direkt in den View verzweigt werden.

    • Mit einer Nachricht können ein oder mehrere Ereignisse ausgelöst werden:

      • Senden einer Email
      • Senden einer Pushover-Nachricht
      • Senden einer Telegram-Pushnachricht
    • Nachrichtendefinition: Nachrichten werden über eine Konfigurationsstruktur definiert und damit wesentliche Eigenschaften der Nachricht bestimmt, darunter:

      • Nachrichtenüberschrift
      • Nachrichtentext
      • Kritikalität (Information, Warnung, Alarm etc.) / Priorität
      • Icon für die VIS Ausgabe
      • Farbe des Icons
      • VIS-View
      • Nachrichtenereignis (Senden eines Telegrams / Email)

    Beispiele für Nachrichten:

    • Alarmanlage ausgelöst!
    • Wasseralarm
    • Erinnerung Fenster lüften!
    • Erinnerung Fenster zu lange geöffnet!
    • Aktuell offene Fenster
    • Aktuell
    • Aktuell offene Türen
    • Lichter angeschaltet
    • Aktive Steckdosen
    • Post im Briefkasten mit Datum letzter Einwurf
    • Nächster Müllabfuhrtermin mit Information zur Tonne
    • DWD Wetterwarnung
    • Bewegung erkannt
    • Internetverbindung Offline
    • Termine des Tages
    • Termine morgen
    • Corona-Statistiken
    • Temperaturen
    • ...

    Sourcen / Anleitung und Projekt auf Github:

    https://github.com/St0Ma/ioBroker-MessageHandler

    In diesem Thread könnt ihr gerne Fragen stellen. Ich versuche im Rahmen meiner Möglichkeiten Support zu geben.

    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    wrote on last edited by sigi234
    #63

    @Tirador

    Warum habe ich unten das noch mal drinnen?

    ERLEDIGT NACH SKRIPT NEUSTART!

    Screenshot (2321)_LI.jpg

    Screenshot (2320).png

    Screenshot (2323).png

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

    T 1 Reply Last reply
    0
    • sigi234S sigi234

      @Tirador

      Warum habe ich unten das noch mal drinnen?

      ERLEDIGT NACH SKRIPT NEUSTART!

      Screenshot (2321)_LI.jpg

      Screenshot (2320).png

      Screenshot (2323).png

      T Offline
      T Offline
      Tirador
      wrote on last edited by Tirador
      #64

      @sigi234 weil du jetzt zwei Nachrichten auslöst. Die eine Nachricht ist aber nicht im MessageHandler definiert. Nachrichten werden aktuell nicht abgelehnt, wenn sie nicht definiert wurden. Das ist Absicht, um solche Zustände auch an der Oberfläche zu erkennen.

      sigi234S 1 Reply Last reply
      0
      • T Tirador

        @sigi234 weil du jetzt zwei Nachrichten auslöst. Die eine Nachricht ist aber nicht im MessageHandler definiert. Nachrichten werden aktuell nicht abgelehnt, wenn sie nicht definiert wurden. Das ist Absicht, um solche Zustände auch an der Oberfläche zu erkennen.

        sigi234S Online
        sigi234S Online
        sigi234
        Forum Testing Most Active
        wrote on last edited by
        #65

        @Tirador sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

        Die eine Nachricht ist aber nicht im MessageHandler definiert.

        Wo muss ich das machen?

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

        T 2 Replies Last reply
        0
        • sigi234S sigi234

          @Tirador sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

          Die eine Nachricht ist aber nicht im MessageHandler definiert.

          Wo muss ich das machen?

          T Offline
          T Offline
          Tirador
          wrote on last edited by
          #66

          @sigi234 schau Mal im aktuellen MessageHandler Skript in Zeile 299. Eine Erklärung, wie das funktioniert ist als Beschreibung im Kopf des Skripts.

          1 Reply Last reply
          0
          • sigi234S sigi234

            @Tirador sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

            Die eine Nachricht ist aber nicht im MessageHandler definiert.

            Wo muss ich das machen?

            T Offline
            T Offline
            Tirador
            wrote on last edited by
            #67

            @sigi234 noch ein Auszug aus der Dokumentation in GitHub

            Konfiguration

            Zur Konfiguration sind zwei Schritte erforderlich:

            1.Die Grundkonfiguration erfolgt über die Festlegung von MESSAGE-IDs (Nachrichten-Ids) in der Konstante MESSAGE_IDS im Javascript "MessageHandler". Optional kann mit den Nachrichten auch ein sogenannten Nachrichtenereignisse ausgelöst werden (z.B. Senden einer Email oder TELEGRAM-Pushnachricht). Hierfür muss den Nachrichten ein sogenanntes msgEvent zugeordnet werden, dass über die Konstante MESSAGE_EVENT unten im Skript konfiguriert wird. Optional kann in der Funktion MessageHandler|doInit() eine Anpassung der KONFIGURATION vorgenommen werden.

            1. Über das Javascript "MessageStateCreator" können Datenpunkte überwacht werden und Nachrichten automatisiert ausgelöst werden. Die Konfiguration erfolgt hierfür im Javascript "MessageStateCreator" über die Konstante MESSAGE_EVENTS. Im Javascript selbst sind auch Beispiele enthalten, wie die Konfiguration durchgeführt wird.
            uwe12489U 1 Reply Last reply
            0
            • T Tirador

              @sigi234 noch ein Auszug aus der Dokumentation in GitHub

              Konfiguration

              Zur Konfiguration sind zwei Schritte erforderlich:

              1.Die Grundkonfiguration erfolgt über die Festlegung von MESSAGE-IDs (Nachrichten-Ids) in der Konstante MESSAGE_IDS im Javascript "MessageHandler". Optional kann mit den Nachrichten auch ein sogenannten Nachrichtenereignisse ausgelöst werden (z.B. Senden einer Email oder TELEGRAM-Pushnachricht). Hierfür muss den Nachrichten ein sogenanntes msgEvent zugeordnet werden, dass über die Konstante MESSAGE_EVENT unten im Skript konfiguriert wird. Optional kann in der Funktion MessageHandler|doInit() eine Anpassung der KONFIGURATION vorgenommen werden.

              1. Über das Javascript "MessageStateCreator" können Datenpunkte überwacht werden und Nachrichten automatisiert ausgelöst werden. Die Konfiguration erfolgt hierfür im Javascript "MessageStateCreator" über die Konstante MESSAGE_EVENTS. Im Javascript selbst sind auch Beispiele enthalten, wie die Konfiguration durchgeführt wird.
              uwe12489U Offline
              uwe12489U Offline
              uwe12489
              wrote on last edited by
              #68

              @Tirador Guten Morgen. Geht das nur mir so? Vers. 0.4 installiert und nichts in der Anzeige...

              T 1 Reply Last reply
              0
              • uwe12489U uwe12489

                @Tirador Guten Morgen. Geht das nur mir so? Vers. 0.4 installiert und nichts in der Anzeige...

                T Offline
                T Offline
                Tirador
                wrote on last edited by
                #69

                @uwe12489 hast du das Skript MessageStateCreator Initial bearbeitet? Wahrscheinlich hast du Fehlermeldungen im Log beim Skriptstart. Der Grund wird sein, dass die Datenpunkte bei dir nicht existieren. Z.b. für die Wassermelder.

                sigi234S 1 Reply Last reply
                0
                • T Tirador

                  @uwe12489 hast du das Skript MessageStateCreator Initial bearbeitet? Wahrscheinlich hast du Fehlermeldungen im Log beim Skriptstart. Der Grund wird sein, dass die Datenpunkte bei dir nicht existieren. Z.b. für die Wassermelder.

                  sigi234S Online
                  sigi234S Online
                  sigi234
                  Forum Testing Most Active
                  wrote on last edited by
                  #70

                  @Tirador sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

                  @uwe12489 hast du das Skript MessageStateCreator Initial bearbeitet? Wahrscheinlich hast du Fehlermeldungen im Log beim Skriptstart. Der Grund wird sein, dass die Datenpunkte bei dir nicht existieren. Z.b. für die Wassermelder.

                  War bei mir auch so, ist es nicht besser alle bis auf eine auszukommentieren?

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

                  T 1 Reply Last reply
                  0
                  • sigi234S sigi234

                    @Tirador sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

                    @uwe12489 hast du das Skript MessageStateCreator Initial bearbeitet? Wahrscheinlich hast du Fehlermeldungen im Log beim Skriptstart. Der Grund wird sein, dass die Datenpunkte bei dir nicht existieren. Z.b. für die Wassermelder.

                    War bei mir auch so, ist es nicht besser alle bis auf eine auszukommentieren?

                    T Offline
                    T Offline
                    Tirador
                    wrote on last edited by
                    #71

                    @sigi234 ja, im Prinzip sind es ja nur Beispiele von Konfiguration. Ich werde das in der Auslieferung ändern.

                    uwe12489U 2 Replies Last reply
                    0
                    • T Tirador

                      @sigi234 ja, im Prinzip sind es ja nur Beispiele von Konfiguration. Ich werde das in der Auslieferung ändern.

                      uwe12489U Offline
                      uwe12489U Offline
                      uwe12489
                      wrote on last edited by
                      #72

                      @Tirador Fehlerscript lesen hilft. Danke.

                      T 1 Reply Last reply
                      0
                      • T Tirador

                        @sigi234 ja, im Prinzip sind es ja nur Beispiele von Konfiguration. Ich werde das in der Auslieferung ändern.

                        uwe12489U Offline
                        uwe12489U Offline
                        uwe12489
                        wrote on last edited by
                        #73

                        @Tirador
                        Auch auf die Gefahr hin, dass ich lästig werde :-/
                        Wie kann ich eine eigen Nachricht "quittierter" machen?

                        uwe12489U T 2 Replies Last reply
                        0
                        • uwe12489U uwe12489

                          @Tirador Fehlerscript lesen hilft. Danke.

                          T Offline
                          T Offline
                          Tirador
                          wrote on last edited by
                          #74

                          @uwe12489 ich habe die Prüfungen verschärft. Der MessageStateCreator startet nicht, wenn Datenpunkte konfiguriert sind, die nicht existieren.

                          1 Reply Last reply
                          0
                          • uwe12489U uwe12489

                            @Tirador
                            Auch auf die Gefahr hin, dass ich lästig werde :-/
                            Wie kann ich eine eigen Nachricht "quittierter" machen?

                            uwe12489U Offline
                            uwe12489U Offline
                            uwe12489
                            wrote on last edited by
                            #75

                            @uwe12489 said in [Script] MessageHandler: Nachrichten protokollieren +VIS:

                            @Tirador
                            Auch auf die Gefahr hin, dass ich lästig werde :-/
                            Wie kann ich eine eigen Nachricht "quittierbar" machen?

                            1 Reply Last reply
                            0
                            • uwe12489U uwe12489

                              @Tirador
                              Auch auf die Gefahr hin, dass ich lästig werde :-/
                              Wie kann ich eine eigen Nachricht "quittierter" machen?

                              T Offline
                              T Offline
                              Tirador
                              wrote on last edited by Tirador
                              #76

                              @uwe12489 dafür musst du im MessageHandler in der Konfiguration der Nachricht das Attribut quit :true setzen.

                              Ein Beispiel ist die Nachricht für den Briefkasten

                              // Post im Briefkasten
                                      LAST_POSTENTRACE_INFO: {msgEvent: ['TELEGRAM'], logType: 'LAST',  severity: 'INFO',  msgHeader: "Briefkasten", msgText: "Neue Post im Briefkasten!", mdIcon: 'drafts', quit: true, mdIconColor: '', fontColor: '', backgroundColor: ''},
                              
                              
                              uwe12489U 1 Reply Last reply
                              0
                              • T Tirador

                                @uwe12489 dafür musst du im MessageHandler in der Konfiguration der Nachricht das Attribut quit :true setzen.

                                Ein Beispiel ist die Nachricht für den Briefkasten

                                // Post im Briefkasten
                                        LAST_POSTENTRACE_INFO: {msgEvent: ['TELEGRAM'], logType: 'LAST',  severity: 'INFO',  msgHeader: "Briefkasten", msgText: "Neue Post im Briefkasten!", mdIcon: 'drafts', quit: true, mdIconColor: '', fontColor: '', backgroundColor: ''},
                                
                                
                                uwe12489U Offline
                                uwe12489U Offline
                                uwe12489
                                wrote on last edited by uwe12489
                                #77

                                @Tirador klappt prima. Danke. Wann werden die ausgeblendeten Nachrichten wieder eingeblendet? Nächster Trigger? Nächster Tag?

                                T 1 Reply Last reply
                                0
                                • uwe12489U uwe12489

                                  @Tirador klappt prima. Danke. Wann werden die ausgeblendeten Nachrichten wieder eingeblendet? Nächster Trigger? Nächster Tag?

                                  T Offline
                                  T Offline
                                  Tirador
                                  wrote on last edited by Tirador
                                  #78

                                  @uwe12489 nächster Trigger mit zutreffender Bedingung.

                                  uwe12489U 1 Reply Last reply
                                  0
                                  • T Tirador

                                    @uwe12489 nächster Trigger mit zutreffender Bedingung.

                                    uwe12489U Offline
                                    uwe12489U Offline
                                    uwe12489
                                    wrote on last edited by
                                    #79

                                    @Tirador :+1:

                                    1 Reply Last reply
                                    0
                                    • UhulaU Offline
                                      UhulaU Offline
                                      Uhula
                                      wrote on last edited by
                                      #80

                                      Interesse an einer Erweiterung des MDCSS zum eleganten Löschen von Einträgen auf Touch-Geräten? Ich versuche gerade ein Swipe/Wisch-Objekt einzubauen, damit könnte man dann Einträge einfach nach links swipen/wischen und sie damit löschen.
                                      swipe_delete.gif

                                      @Tirador Technisch wäre es so, dass du dem ListItem bestimmte mdui-CSS Klassen zuweist (mdui-swipe-left-<width>-<color>-<icon>-<stateid>-<stateval>) und beim Swipe wird dann der <stateval> in den <stateid> geschrieben. Bsp:

                                      mdui-swipe-left-25-red-delete-0_userdata.0.messages.swipe-row100
                                      

                                      Oder nicht notwendig?

                                      Uhula - Leise und Weise
                                      Ex: ioBroker on Gigabyte NUC Proxmox

                                      T 1 Reply Last reply
                                      2
                                      • UhulaU Uhula

                                        Interesse an einer Erweiterung des MDCSS zum eleganten Löschen von Einträgen auf Touch-Geräten? Ich versuche gerade ein Swipe/Wisch-Objekt einzubauen, damit könnte man dann Einträge einfach nach links swipen/wischen und sie damit löschen.
                                        swipe_delete.gif

                                        @Tirador Technisch wäre es so, dass du dem ListItem bestimmte mdui-CSS Klassen zuweist (mdui-swipe-left-<width>-<color>-<icon>-<stateid>-<stateval>) und beim Swipe wird dann der <stateval> in den <stateid> geschrieben. Bsp:

                                        mdui-swipe-left-25-red-delete-0_userdata.0.messages.swipe-row100
                                        

                                        Oder nicht notwendig?

                                        T Offline
                                        T Offline
                                        Tirador
                                        wrote on last edited by Tirador
                                        #81

                                        @Uhula das wäre natürlich der Hammer. Ich fände es Klasse. Daumen hoch!

                                        1 Reply Last reply
                                        0
                                        • T Offline
                                          T Offline
                                          Tirador
                                          wrote on last edited by
                                          #82

                                          Was mich momentan umtreibt sind zwei Dinge:

                                          • Verzögerte Auslösung von Nachrichten: Am Beispiel meines Kühlschranks, soll die Nachricht erst ausgelöst werden, wenn der Kühlschrank länger als 60 Sekunden offen ist. Momentan bekomme ich jedes mal beim öffnen eine Nachricht / auch per Telegram. Das ist so nicht sinnvoll. Die Logik könnte äquivalent auch für Fenster/Türen angewendet werden. Natürlich gibt es im Pitini-Fensterskript auch solche Logiken, aber warum sollte man das nicht generalisierbar machen (und aus anderen Skripten heraushalten?).

                                          • Wiederholtes Auslösen von Nachrichten: d.h. wenn der Kühlschrank nach 10 Minuten immer noch offen ist, wird die Nachricht erneut gesendet. Damit würde ich auch die Pushs für TELEGRAM /EMail erneut senden. Fraglich ist, ob das einen Nutzen bringt in erhöhter Aufmerksamkeit. Wenn irgendwann mal Alexa/Say-Sprachausgaben hinzukommen könnte dieses Feature sinnvoll werden ;)

                                          Was meint Ihr?

                                          uwe12489U D 2 Replies Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          320

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe