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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.2k

[Script] MessageHandler: Nachrichten protokollieren +VIS

Geplant Angeheftet Gesperrt Verschoben JavaScript
336 Beiträge 25 Kommentatoren 63.9k Aufrufe 40 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • D Offline
    D Offline
    der-eine
    schrieb am zuletzt editiert von
    #268

    Danke @Saschag & @BoehserWolf Messages habe ich mit aufgenommen. :+1:

    1 Antwort Letzte Antwort
    0
    • UhulaU Offline
      UhulaU Offline
      Uhula
      schrieb am zuletzt editiert von
      #269

      @Tirador Ein Hinweis, wie man die Vergleiche der DP zum Triggern/Removen alternativ und flexibler eingeben könnte:

      triggerDP: 'nut.0.status.replacebattery',
      postMsgDP: {cond:'nut.0.status.replacebattery==true'},
      removeDP: {cond:'nut.0.status.replacebattery!=true'},
      

      Dann könnte man auch mit Template-Strings (``) arbeiten (wenn triggerDP zur Laufzeit bekannt ist):

      triggerDP: 'nut.0.status.replacebattery',
      postMsgDP: {cond:`${triggerDP}==true`},
      removeDP: {cond:`${triggerDP}!==true`},
      

      Dann würde auch so etwas gehen:

      triggerDP: 'nut.0.status.replacebattery',
      postMsgDP: {cond:'nut.0.status.replacebattery==0 || nut.0.status.replacebattery==2'},
      removeDP: {cond:'nut.0.status.replacebattery==1 || nut.0.status.replacebattery==3'},
      
      triggerDP: 'nut.0.status.replacebattery',
      postMsgDP: {cond:`${triggerDP}==0 || ${triggerDP}==2`},
      removeDP: {cond:`${triggerDP}==1 || ${triggerDP}==3`},
      

      Du kannst solche String-Anweisungen dann in Javascript einfach via eval() ausführen lassen. Nur, falls eine solche Flexibilität mal gefordert wird. Es sind dann alle Vergleiche möglich, sogar Umrechnungen usw. - eben alles, was gültiges Javascript ist.

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

      T 1 Antwort Letzte Antwort
      0
      • UhulaU Uhula

        @Tirador Ein Hinweis, wie man die Vergleiche der DP zum Triggern/Removen alternativ und flexibler eingeben könnte:

        triggerDP: 'nut.0.status.replacebattery',
        postMsgDP: {cond:'nut.0.status.replacebattery==true'},
        removeDP: {cond:'nut.0.status.replacebattery!=true'},
        

        Dann könnte man auch mit Template-Strings (``) arbeiten (wenn triggerDP zur Laufzeit bekannt ist):

        triggerDP: 'nut.0.status.replacebattery',
        postMsgDP: {cond:`${triggerDP}==true`},
        removeDP: {cond:`${triggerDP}!==true`},
        

        Dann würde auch so etwas gehen:

        triggerDP: 'nut.0.status.replacebattery',
        postMsgDP: {cond:'nut.0.status.replacebattery==0 || nut.0.status.replacebattery==2'},
        removeDP: {cond:'nut.0.status.replacebattery==1 || nut.0.status.replacebattery==3'},
        
        triggerDP: 'nut.0.status.replacebattery',
        postMsgDP: {cond:`${triggerDP}==0 || ${triggerDP}==2`},
        removeDP: {cond:`${triggerDP}==1 || ${triggerDP}==3`},
        

        Du kannst solche String-Anweisungen dann in Javascript einfach via eval() ausführen lassen. Nur, falls eine solche Flexibilität mal gefordert wird. Es sind dann alle Vergleiche möglich, sogar Umrechnungen usw. - eben alles, was gültiges Javascript ist.

        T Offline
        T Offline
        Tirador
        schrieb am zuletzt editiert von
        #270

        @Uhula Super Idee! Kommt mal auf die Todoliste.
        Allerdings würde ich aus Gründen der Abwärtskompatibilität statt "cond" einen neuen Tag "eval:" erfinden, wo man dann das eval vorgeben kann.

        1 Antwort Letzte Antwort
        0
        • I intruder7

          Moin @all, man kann ja in der Meldung eine View aufrufen. Besteht auch die Möglichkeit einen Dialog aufzurufen? Und wenn nicht, @Tirador kann man das implementieren?

          Ansonsten super Arbeit...:+1:

          T Offline
          T Offline
          Tirador
          schrieb am zuletzt editiert von
          #271

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

          Moin @all, man kann ja in der Meldung eine View aufrufen. Besteht auch die Möglichkeit einen Dialog aufzurufen? Und wenn nicht, @Tirador kann man das implementieren?

          Ansonsten super Arbeit...:+1:

          Was meinst Du denn mit Dialog (ein Overlay / Popup)?
          Was ist denn der Anwendungsfall dafür?

          I 1 Antwort Letzte Antwort
          0
          • T Tirador

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

            Moin @all, man kann ja in der Meldung eine View aufrufen. Besteht auch die Möglichkeit einen Dialog aufzurufen? Und wenn nicht, @Tirador kann man das implementieren?

            Ansonsten super Arbeit...:+1:

            Was meinst Du denn mit Dialog (ein Overlay / Popup)?
            Was ist denn der Anwendungsfall dafür?

            I Offline
            I Offline
            intruder7
            schrieb am zuletzt editiert von
            #272

            @Tirador
            ja genau... sowas wie ein popup. Nennt sich ja Dialog View. Anwendungsfälle hab ich viele. ich lasse mir zB beim Briefkasten die Zeit der letzten Leerung des letzten Einwurfs und ein Snapshot von der Kamera im dialog anzeigen. oder aktuell nur die Anzahl der Lichter und nach draufdrücken mit einem dynamischen table in einem Dialogview die Möglichkeit die Lampen einzeln auszuschalten oder zeigt mein Klingelbutton nur die häufigkeit an wie oft es geklingelt hat, nach dem draufdrücken die Zeiten wann es geklingelt hat, Möglichkeit des Stummschakten oder Aus für eine bestimmte Zeit oder einstellen der Mittagsruhe. Hab auch noch viele mehr.

            Ein Dialog finde ich manchmal einfach besser als extra große Views zu machen.

            Das kann auch ruhig eine Standardgröße haben die man vorher im Skript einstellt.

            Ist ja auch bloß ne Idee

            1 Antwort Letzte Antwort
            0
            • D Offline
              D Offline
              der-eine
              schrieb am zuletzt editiert von
              #273

              Die Idee finde ich auch gut, wenn die Kamera eine Bewegung erkannt hat und man klickt auf die Nachricht und man bekommt ein Popup mit einem Bilder von der „Bewegung“. 🤔

              1 Antwort Letzte Antwort
              0
              • T Offline
                T Offline
                Tirador
                schrieb am zuletzt editiert von Tirador
                #274

                Auch wenn es technisch reizvoll erscheint das einzubauen:
                Statt dem Dialog View kann man auch auf den normalen View umleiten. Mehr klicken brauche ich ja dann prinzipiell prinzipiell nicht.
                Und die Funktionalität kann man ja wirklich analogi im normalen View abbilden (d.h. Anzeige Screenshot, anzeige lichter / Lichtersteuerung etc.).

                Wenn jemand aber die technische Lösung für den Dialog View aufzeigt, kann ich es gerne noch integrieren.

                1 Antwort Letzte Antwort
                0
                • T Offline
                  T Offline
                  Tirador
                  schrieb am zuletzt editiert von
                  #275

                  @der-eine
                  Du wolltest ja noch die Bilder für Gefrierschrank/Kühlschrank geöffnet:

                  2020-06-14 09_13_53-vis.png

                  MessageStateCreator

                      // Gefrierschrank geöffnet
                      // über eigenen Sensor
                      {
                          msgID: 'FREEZER_DOOR_ISOPEN_INFO', 
                          triggerDP: 'deconz.0.Sensors.56.open',
                          postMsgDP: {dp:'deconz.0.Sensors.56.open', comp: '==', val:true, delayTime: 60, repeatTime: 600},
                          removeMsgDP: {dp:'deconz.0.Sensors.56.open', comp: '==', val:false}, 
                          msgText_1: {text: ''},
                      },
                  

                  MessageHandler

                         // Offener Gefrierschrank
                          FREEZER_DOOR_ISOPEN_INFO: {msgEvent: [''], logType: 'LAST',  severity: 'ALARM',  msgHeader: "Gefrierschrank geöffnet", msgText: "Bitte Gefrierschrank schließen", quit: false, mdIcon: 'ac_unit', mdIconColor: '', fontColor: '', backgroundColor: ''},
                  
                  
                  1 Antwort Letzte Antwort
                  0
                  • T Offline
                    T Offline
                    Tirador
                    schrieb am zuletzt editiert von
                    #276

                    @der-ein Alarmanlage für das Wiki.

                    Die Alarmanlage basiert auf dem Skript von andreaskos:
                    https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3

                    Es gibt zwei Nachrichten:

                    Eine für die Ausgabe, dass die Alaramanlage an/aus ist:

                    2020-06-14 09_18_15-vis.png

                    2020-06-14 09_20_31-vis.png

                    Eine Nachricht für den ausgelösten Alarm:

                    2020-06-14 09_20_59-vis.png

                    MessageStateCreator

                        // Status Alarmanlage
                        // über Skript von andreaskos
                        // https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3
                        {
                            msgID: 'HOUSE_ALARM_STATUS', 
                            triggerDP: ['javascript.0.Alarmanlage.Output.StatusText'],
                            postMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: false},  
                            removeMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: true}, 
                            msgText_1: {text: 'Aktiv: '},
                            msgText_2: {dp: 'javascript.0.Alarmanlage.Output.StatusText'},
                            msgText_3: {text: '<br>'},
                            msgText_4: {text: 'Status: '},        
                            msgText_5: {dp: 'javascript.0.Alarmanlage.Output.AlarmText'}
                        },
                    
                    
                        // Status Alarmanlage
                        // über Skript von andreaskos
                        // https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3
                        {
                            msgID: 'HOUSE_ALARM_ACTIVE', 
                            triggerDP: ['javascript.0.Alarmanlage.Output.Alarm'],
                            postMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: true},  
                            removeMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: false}, 
                            msgText_1: {text: 'Melder: '},
                            msgText_2: {dp: 'javascript.0.Alarmanlage.Output.AlarmingDetector'},
                            msgText_3: {text: '<br>'},
                            msgText_4: {text: 'Status: '},        
                            msgText_5: {dp: 'javascript.0.Alarmanlage.Output.AlarmText'},
                            msgText_6: {text: '<br>'},
                            msgText_7: {text: 'Aktiv: '},
                            msgText_8: {dp: 'javascript.0.Alarmanlage.Output.StatusText'}
                        },
                    

                    MessageHandler

                            // Alarmanlage
                            HOUSE_ALARM_ACTIVE: {msgEvent: [''], logType: 'LAST',  severity: 'ALARM',  msgHeader: "Alarm im Haus", msgText: "", quit: true, visView: 'pageSicherheit', mdIcon: 'notification_important', mdIconColor: '', fontColor: '', backgroundColor: ''},
                    
                    

                    MessageHandler

                          // Status Alarmanlage
                            HOUSE_ALARM_STATUS: {msgEvent: [''], logType: 'LAST',  severity: 'INFO',  msgHeader: "Alarmanlage", msgText: "", quit: false, visView: 'pageSicherheit', mdIcon: 'security', mdIconColor: '', fontColor: '', backgroundColor: ''},
                    
                    
                    1 Antwort Letzte Antwort
                    0
                    • S Saschag

                      @der-eine
                      so habe heute auf die Version 0.7 umgestellt und nun sieht es beim iPhone leider wie bei Dir aus ;-(

                      D Offline
                      D Offline
                      der-eine
                      schrieb am zuletzt editiert von
                      #277

                      @Saschag ändere mal an folgender Stelle auf 2.5em (MessageHandler) dann rutschen die Icons nach rechts und sie werden wieder vollständig auf dem iPhone angezeigt.

                      Bildschirmfoto 2020-06-16 um 18.32.42.png

                      S 1 Antwort Letzte Antwort
                      0
                      • D der-eine

                        @Saschag ändere mal an folgender Stelle auf 2.5em (MessageHandler) dann rutschen die Icons nach rechts und sie werden wieder vollständig auf dem iPhone angezeigt.

                        Bildschirmfoto 2020-06-16 um 18.32.42.png

                        S Offline
                        S Offline
                        Saschag
                        schrieb am zuletzt editiert von
                        #278

                        @der-eine

                        Super !! Danke sieht viel besser aus :grin:

                        1 Antwort Letzte Antwort
                        0
                        • C Offline
                          C Offline
                          Conquest
                          schrieb am zuletzt editiert von
                          #279

                          @Tirador

                          Hallo Tirador,
                          erstmal vielen Dank für das tolle Script.
                          Ich habe nur ein kleines Problem mit der Anzeige. Ich kann die Schriftfarbe nicht auf weiß stellen.
                          Kannst du mir helfen?

                          screenshot-192.168.178.46_8082-2020.07.15-19_38_50.png

                          1 Antwort Letzte Antwort
                          0
                          • H Offline
                            H Offline
                            HoffmannOs
                            schrieb am zuletzt editiert von HoffmannOs
                            #280

                            Moin Moin,
                            ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                            Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                            Meine Config : Message State : ```

                            
                            {
                                    msgID: 'Klingel_Sxxx',
                                    triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                    postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                    msgText_1: {text: ''},
                                    countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                },    
                            

                            Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                            Message Handler

                            Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                            
                            T 1 Antwort Letzte Antwort
                            0
                            • H HoffmannOs

                              Moin Moin,
                              ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                              Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                              Meine Config : Message State : ```

                              
                              {
                                      msgID: 'Klingel_Sxxx',
                                      triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                      postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                      msgText_1: {text: ''},
                                      countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                  },    
                              

                              Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                              Message Handler

                              Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                              
                              T Offline
                              T Offline
                              Tirador
                              schrieb am zuletzt editiert von
                              #281

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

                              Moin Moin,
                              ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                              Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                              Meine Config : Message State : ```

                              
                              {
                                      msgID: 'Klingel_Sxxx',
                                      triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                      postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                      msgText_1: {text: ''},
                                      countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                  },    
                              

                              Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                              Message Handler

                              Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                              

                              Bei dem Tag "postMsgDP" fehlt noch ein Wert mit dem die Nachricht ausgelöst wird. Du hast den Datenpunkt angegeben (dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'), den Vergleichsoperator (comp: '=='; d.h. also Vergleich mit "GLEICH"), aber es fehlt der Wert mit dem verglichen werden soll. Ich kenne HM / HM IP nicht. Wenn es ein Contact ist, kann der Datenpunkt z.B. den Wert 0/1 oder true/false annehmen. Sofern er den Wert "true" annimmt, müsste die Deklaration im MessageStateCreator so aussehen:

                                  {
                              
                                      msgID: 'Klingel_Sxxx', 
                                      triggerDP: ['hm-rpc.1.PEQ0653xx.1.PRESS_SHORT'],
                                      postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', val: true, change: "any"},
                                      msgText_1: {text: ''},
                                      countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                  }
                              
                              T 1 Antwort Letzte Antwort
                              0
                              • T Tirador

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

                                Moin Moin,
                                ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                                Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                                Meine Config : Message State : ```

                                
                                {
                                        msgID: 'Klingel_Sxxx',
                                        triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                        postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                        msgText_1: {text: ''},
                                        countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                    },    
                                

                                Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                                Message Handler

                                Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                                

                                Bei dem Tag "postMsgDP" fehlt noch ein Wert mit dem die Nachricht ausgelöst wird. Du hast den Datenpunkt angegeben (dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'), den Vergleichsoperator (comp: '=='; d.h. also Vergleich mit "GLEICH"), aber es fehlt der Wert mit dem verglichen werden soll. Ich kenne HM / HM IP nicht. Wenn es ein Contact ist, kann der Datenpunkt z.B. den Wert 0/1 oder true/false annehmen. Sofern er den Wert "true" annimmt, müsste die Deklaration im MessageStateCreator so aussehen:

                                    {
                                
                                        msgID: 'Klingel_Sxxx', 
                                        triggerDP: ['hm-rpc.1.PEQ0653xx.1.PRESS_SHORT'],
                                        postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', val: true, change: "any"},
                                        msgText_1: {text: ''},
                                        countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                    }
                                
                                T Offline
                                T Offline
                                Tirador
                                schrieb am zuletzt editiert von
                                #282

                                @All: Ich experimentiere gerade mit Lovelace herum.
                                In Lovelace gibt es nativ eine Nachrichtenfunktion in der Oberfläche.

                                6cf18d0c-ca2b-4b5f-8c2d-ae28601e3631-grafik.png

                                Aktuell kann ich die Nachrichten des MessageHandlers dort schon ausgeben.

                                05caca50-7f20-4a7e-b039-2a002d5634ad-grafik.png

                                Leider gibt es nur eine Formatierung mit Markdown.
                                Natürlich kann man auch über eine eigene Card nachdenken. Eventuell hat jemand eine Idee ;)

                                T 1 Antwort Letzte Antwort
                                0
                                • T Tirador

                                  @All: Ich experimentiere gerade mit Lovelace herum.
                                  In Lovelace gibt es nativ eine Nachrichtenfunktion in der Oberfläche.

                                  6cf18d0c-ca2b-4b5f-8c2d-ae28601e3631-grafik.png

                                  Aktuell kann ich die Nachrichten des MessageHandlers dort schon ausgeben.

                                  05caca50-7f20-4a7e-b039-2a002d5634ad-grafik.png

                                  Leider gibt es nur eine Formatierung mit Markdown.
                                  Natürlich kann man auch über eine eigene Card nachdenken. Eventuell hat jemand eine Idee ;)

                                  T Offline
                                  T Offline
                                  Tirador
                                  schrieb am zuletzt editiert von Tirador
                                  #283

                                  Ich hatte jetzt mal etwas Zeit zu tüfteln.

                                  So sieht es nun aus mit der Lovelace-Visualisierung (eigene Card!):

                                  7bf84609-310f-4b5e-8cdb-2185f7db6c3c-grafik.png

                                  T 1 Antwort Letzte Antwort
                                  0
                                  • T Tirador

                                    Ich hatte jetzt mal etwas Zeit zu tüfteln.

                                    So sieht es nun aus mit der Lovelace-Visualisierung (eigene Card!):

                                    7bf84609-310f-4b5e-8cdb-2185f7db6c3c-grafik.png

                                    T Offline
                                    T Offline
                                    Tirador
                                    schrieb am zuletzt editiert von
                                    #284

                                    Habe jetzt eine stabiliserte Version:

                                    f6b83963-0d6b-4d02-ab69-ea55b5cdba9f-grafik.png

                                    1 Antwort Letzte Antwort
                                    0
                                    • 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.

                                      M Offline
                                      M Offline
                                      Mike Hellracer
                                      schrieb am zuletzt editiert von
                                      #285

                                      @Tirador
                                      Hi, habe jetzt alle Scripts installiert die DP unter userdata Messagehandler sind auch da. Aber der "count" zeigt immer 0 Nachrichten. Muss ich da noch weitere Einstellungen machen, oder müsste ich in der Grundkonfiguration zumindest mal ein paar Nachrichten sehen?

                                      D 1 Antwort Letzte Antwort
                                      0
                                      • M Mike Hellracer

                                        @Tirador
                                        Hi, habe jetzt alle Scripts installiert die DP unter userdata Messagehandler sind auch da. Aber der "count" zeigt immer 0 Nachrichten. Muss ich da noch weitere Einstellungen machen, oder müsste ich in der Grundkonfiguration zumindest mal ein paar Nachrichten sehen?

                                        D Offline
                                        D Offline
                                        der-eine
                                        schrieb am zuletzt editiert von
                                        #286

                                        @Mike-Hellracer wenn Du nur die Skripte eingefügt hast und nicht die Datenpunkte angepasst läuft das Skript nicht. Das siehst Du auch im Log. Sobald ein Datenpunkt bei Dir nicht existiert, wird das Skript gestoppt. Du muss im MessageCreator die Datenpunkte auf Dein System anpassen und die nicht verwendeten auskommentieren damit das Skript läuft.

                                        M 1 Antwort Letzte Antwort
                                        0
                                        • D der-eine

                                          @Mike-Hellracer wenn Du nur die Skripte eingefügt hast und nicht die Datenpunkte angepasst läuft das Skript nicht. Das siehst Du auch im Log. Sobald ein Datenpunkt bei Dir nicht existiert, wird das Skript gestoppt. Du muss im MessageCreator die Datenpunkte auf Dein System anpassen und die nicht verwendeten auskommentieren damit das Skript läuft.

                                          M Offline
                                          M Offline
                                          Mike Hellracer
                                          schrieb am zuletzt editiert von
                                          #287

                                          @der-eine
                                          Yep, Danke das war es.

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          270

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe