Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Script] MessageHandler: Nachrichten protokollieren +VIS

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    [Script] MessageHandler: Nachrichten protokollieren +VIS

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      Saschag last edited by

      Hallo

      ich wollte gren unseren Rasenhelfer als Message:

          // Mover
          // 
          {
              msgID: 'MOVER_LOAD_POS_INFO', 
              triggerDP: 'worx.0.201930198403016966D4.mower.status',
              postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:Home(1)},
              removeMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '!=', val:Home(1)},
              msgText_1: {text: 'Oskar in Parkposition'},
              countEventsDP: ''
          }
      

      Habe als Home und als Home(1) probiert. Im Log bekomme ich folgenden fehler:

      javascript.0
      2020-04-22 15:04:50.860
      error
      (7124) at Script.runInContext (vm.js:133:20)
      javascript.0
      2020-04-22 15:04:50.860
      error
      (7124) at script.js.Message.MessageCreator04:245:84
      javascript.0
      2020-04-22 15:04:50.859
      error
      (7124) ReferenceError: Home is not defined
      javascript.0
      2020-04-22 15:04:50.858
      error
      (7124) ^
      javascript.0
      2020-04-22 15:04:50.858
      error
      (7124) postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:Home(1)},
      javascript.0
      2020-04-22 15:04:50.856
      error
      (7124) script.js.Message.MessageCreator04: script.js.Message.MessageCreator04:245
      

      Muss ich hier einen Umweg gehen und in einem Skript den Status Home in "true" und "false" umwandeln?
      Dank im Voraus

      uwe12489 T 2 Replies Last reply Reply Quote 0
      • uwe12489
        uwe12489 @Saschag last edited by

        Hallo zusammen, hier mal eine neue Anwendungsidee: Spritpreise aus dem Tankerkoenig-Adapter.

        Bildschirmfoto 2020-04-22 um 16.09.37.png

        im MessageHandler

               //Spritpreis-Info
                TANK_INFO: {logType: 'LAST',  severity: 'INFO',  msgHeader: "Spritpreis", msgText: "", quit: true, mdIcon: 'time_to_leave', mdIconColor: '', fontColor: '', backgroundColor: ''},
        

        und im MessageStateCreator

            // Spritpreis-Info TEST
            // über tankerkoenig-Adapter
            {
                msgID: 'TANK_INFO', 
                triggerDP: 'tankerkoenig.0.stations.cheapest.e5.feed',
                postMsgDP: {dp:'tankerkoenig.0.stations.cheapest.e5.feed', comp: '>', val:0},
                removeMsgDP: {dp:'tankerkoenig.0.stations.cheapest.e5.feed', comp: '==', val:0},
                msgText_1: {text: 'Bester Preis für SUPER: '},
                msgText_2: {dp: 'tankerkoenig.0.stations.cheapest.e5.feed'},
                msgText_3: {text: '€ bei '},
                msgText_4: {dp: 'tankerkoenig.0.stations.cheapest.e5.name'},
                countEventsDP: ''
            },    
        

        Geht natürlich auch für E10 oder Diesel 😉

        T 1 Reply Last reply Reply Quote 0
        • T
          Tirador @Saschag last edited by

          @Saschag Man müsste schauen, welche Werte originär in deinem Datenpunkt stehen können.

          Ich vermute dass es ähnlich ist wie beim DWD Adapter.
          Dort gibt es einen Datenpunkt level, der den Wert "Minor(2)" hat:

          2020-04-22 16_26_58-objects - ioBroker.png

          Wenn man den Datenpunkt bearbeitet (über das Stiftsymbol auf dem Datenpunkt) ist jedoch erkennbar, dass es eine Werteliste ist:

          2020-04-22 16_28_13-objects - ioBroker.png

          D.h. der Datenpunkt selbst bildet eine Zahl ab. Mit der Zahl ist ein Beschreibungstext verbunden (in diesem Fall der Text "Minor" für die Zahl 2).

          Für deinen Datenpunkt solltest Du dir das auch ansehen. Ist der Datenpunkt eine Zahl, so ist die Konfiguration wie folgt auszuführen:

           postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:1},
          

          Ist der Datenpunkt ein Text eher so:

           postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:'1'},
          

          Wenn in deinem Datenpunkt wirklich "Home(1)" drinsteht, dann so:

           postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:'Home(1)'},
          
          S 1 Reply Last reply Reply Quote 0
          • T
            Tirador @uwe12489 last edited by

            @uwe12489 Tankerkönig habe ich auch noch auf dem Zettel. Habe deine Konfiguration als Beispiel schonmal in das Skript übernommen. 🙂

            1 Reply Last reply Reply Quote 0
            • T
              Tirador last edited by

              Anbei noch eine Idee die mir vorschwebt:

              269ab5b9-81e8-4fe9-a1f4-60afa87cdc6a-grafik.png

              Das setzt natürlich die Abfrage eines Dienstes (Google Maps/Traffic / Bing etc.) voraus.
              Ist aber wohl ein eigenes Unterprojekt das hinzubekommen 😉

              uwe12489 1 Reply Last reply Reply Quote 0
              • uwe12489
                uwe12489 @Tirador last edited by

                @Tirador Bei der Überschrift Nachrichten schweben mir immer BREAKING NEWS vor. Kann man die letzte RSS Meldung (von Tagesschau o.ä.) als Datenpunkt speichern und hier einblenden?

                1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @Tirador last edited by

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

                  @der-eine ja momentan kann man nur Meldungen global, d.h. für alle quittierbaren Meldungen gleichzeitig, quittieren. Das reicht für meine Fälle aus.

                  Schöner wäre natürlich ein Einzel-quittiermodus. Da fehlt mir noch der programmatische und schöne Ansatz, wie man das in VIS interagiert hinbekommt. Das Listview Widget von scrounger kann das. Ich habe aber aktuell keine Priorität auf eine Verbesserung des aktuellen Zustands. Wenn jemand anderes da eine Verbesserung beiträgt, nehme ich diese gerne auf.

                  evtl kannst du dass gebrauchen
                  diese tabelle ist wie das batterie script erstellt - hier ist es die alexa einkaufsliste, die angezeigt wird und dann über einen link der datenpunkt auch gelöscht werden kann - dazu wird ein einzeiliges script in das html eingebaut:

                  smart35.gif

                  drückt man den button wird ein datenpunkt des alexa adapters gesteuert (delete eintrag)

                  evtl könnte das eine lösung dafür sein

                  T 1 Reply Last reply Reply Quote 0
                  • T
                    Tirador @liv-in-sky last edited by

                    @liv-in-sky Danke für deinen Tipp. Das löschen von einzelnen Nachrichten ist in der aktuellen Version integriert.

                    1 Reply Last reply Reply Quote 0
                    • S
                      Saschag @Tirador last edited by

                      @Tirador
                      Danke!👍

                      Wider etwas gelernt.

                      Lösung war:

                      postMsgDP: {dp:'worx.0.201930198403016966D4.mower.status', comp: '==', val:1},
                      

                      😊

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        Tirador @Saschag last edited by

                        @Saschag OK, prima. Wenn du zufrieden mit der Message bist, kannst du ja nochmal den finalen stand des Skripts mit Screenshot Posten. Ich nehme das in die Basis Konfiguration der Auslieferung auf.

                        Die Idee ist, dass wir viele Messages Out of the Box haben. Das gilt übrigens auch für andere Messages.

                        S 1 Reply Last reply Reply Quote 0
                        • S
                          Saschag @Tirador last edited by

                          @Tirador
                          Teste es morgen nochmals und poste es dan gerne.

                          1 Reply Last reply Reply Quote 0
                          • D
                            der-eine @Tirador last edited by

                            @Tirador war wohl etwas in meiner Konfig falsch. Habe sie neu importiert und meine Einträge angepasst jetzt geht auch clear pressed wieder...

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

                            @der-eine swipen löschen ist noch in Arbeit bei uhula...

                            sorry hab ich überlesen. Stand ja im anderen Thread.

                            Wie läufts denn mit Version 0.5? 😀

                            T 1 Reply Last reply Reply Quote 0
                            • T
                              Tirador @der-eine last edited by

                              @der-eine also das verzögerte auslösen von Nachrichten klappt ganz prima.
                              Was jetzt fehlt ist das wiederholte auslösen von Nachrichten.

                              1 Reply Last reply Reply Quote 0
                              • T
                                Tirador last edited by

                                By the way: ich habe jetzt Logitech Harmony eingebaut.

                                2020-04-23 18_54_25-vis.png

                                    // Logitech Harmony
                                    {
                                        msgID: 'HARMONY_INFO', 
                                        triggerDP: 'harmony.0.Harmonyhub.activities.currentActivity',
                                        postMsgDP: {dp:'harmony.0.Harmonyhub.activities.currentActivity', comp: '!=', val:'PowerOff'},
                                        removeMsgDP: {dp:'harmony.0.Harmonyhub.activities.currentActivity', comp: '==', val:'PowerOff'}, // Nachricht wird zur Sicherheit nicht entfernt, falls der Sensor toggelt!
                                        msgText_1: {text: 'Aktivität: '},
                                        msgText_2: {dp: 'harmony.0.Harmonyhub.activities.currentActivity'},
                                        countEventsDP: ''
                                    },
                                
                                        // Logitech Harmony Info
                                        HARMONY_INFO: {msgEvent: [''], logType: 'LAST',  severity: 'INFO',  msgHeader: "Wohnzimmer Multimedia", msgText: "", mdIcon: 'settings_remote', quit: false, visView: 'pageMultimedia', mdIconColor: '', fontColor: '', backgroundColor: ''},
                                
                                
                                1 Reply Last reply Reply Quote 1
                                • D
                                  der-eine last edited by der-eine

                                  @Tirador das View wechseln auch schon 😬 ?
                                  Habe das GästeWlan mit aufgenommen.

                                  MessageCreator

                                      // Gäste WLAN
                                      {
                                          msgID: 'GUEST_WIFI', 
                                          triggerDP: 'tr-064.0.states.wlanGuest',
                                          postMsgDP: {dp:'tr-064.0.states.wlanGuest', comp: '==', val:true},
                                          removeMsgDP: {dp:'tr-064.0.states.wlanGuest', comp: '==', val:false},
                                          msgText_1: {text: 'Gäste WLAN eingeschalten'},
                                          msgText_2: {dp: 'javascript.0.QR-Code.Gast'},
                                          countEventsDP: ''
                                      },
                                  

                                  MessageHandler

                                  // Gäste WLAN
                                          GUEST_WIFI: {msgEvent: [''], logType: 'LAST',  severity: 'INFO',  msgHeader: "WLAN", msgText: "", quit: false, mdIcon: 'wifi', mdIconColor: '', fontColor: '', backgroundColor: ''},
                                  

                                  Bildschirmfoto 2020-04-24 um 17.20.17.png

                                  Edit 24.04.2020
                                  QR-Code mit Zugangsdaten anzeigen.
                                  Es wird benötigt:

                                  • TR-064 Adapter

                                  • Skript

                                  // https://www.npmjs.com/package/qr-image
                                  
                                  var MySSID          = "FRITZ!Box XXX";           //  SSID Name GästeWlan
                                  
                                  var MyCrypt         = "WPA2";                //  [WEP|WPA|WPA2]
                                  
                                  var MyVisibility    = "n";                  //  Hidden SSID? 
                                  
                                  var cronStr         = "1 3 * * *"           // Script wird jeden Tag um 03:01 Ausgeführt
                                                                             //Skript jede Minute ausführen * * * * * 
                                  
                                  
                                  var idQRZiel = "javascript.0.QR-Code.Gast"; // Zieldatenpunkt für QR-Code
                                  
                                  var IdGPasswd = "tr-064.0.states.wlanGuestPassword"; /*wlanGuestPassword*/
                                  
                                  
                                  
                                  if(MyVisibility == "y") {
                                  
                                    var MyHidden="H:true";
                                  
                                  } 
                                  
                                  else {
                                  
                                    MyHidden="";
                                  
                                  } 
                                  
                                  
                                  
                                  createState(idQRZiel, "", {
                                  
                                  
                                  
                                     name: 'QR-Code für Gastpasswort',
                                  
                                     desc: 'QR-Code für Gastpasswort',
                                  
                                     type: 'string',
                                  
                                     role: 'value'
                                  
                                  });
                                  
                                  
                                  
                                  function randomString(length) {         // Methode zur Erstellung eines Random-Passworts kann angepasst werden
                                  
                                  
                                  
                                    return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1);
                                  
                                  
                                  
                                  }
                                  
                                  
                                  
                                  function createQRcode() {
                                  
                                  
                                  
                                    var qr = require('qr-image');
                                  
                                    var NewPasswd = randomString(16);       // 16 Stelliges Passwort
                                  
                                    var svg_string = qr.imageSync('WIFI:S:'+MySSID+';T:'+MyCrypt+';P:'+NewPasswd+';'+MyHidden+';', { type: 'svg' });
                                  
                                         
                                  
                                    setState(idQRZiel, svg_string);
                                    setState(IdGPasswd, NewPasswd);
                                    console.log('+++ Wlan Gast QR-Code neu erstellt +++');
                                  }
                                  
                                  
                                  
                                  
                                  // regelmässige Wiederholungen
                                  
                                  schedule(cronStr, createQRcode);
                                  

                                  • JavaScript Instanz qr-image

                                    Bildschirmfoto 2020-04-24 um 17.26.18.png
                                  H 1 Reply Last reply Reply Quote 1
                                  • uwe12489
                                    uwe12489 last edited by

                                    Hier eine "Nachricht" zur Anzeige ioBroker-Update

                                    Bildschirmfoto 2020-04-24 um 09.06.33.png

                                    im MessageHandler

                                           //Update ioBroker
                                            UPDATE_INFO: {logType: 'LAST',  severity: 'INFO',  msgHeader: "Update ioBroker", msgText: "", quit: true, mdIcon: 'cached', mdIconColor: '', fontColor: '', backgroundColor: ''},
                                    
                                    

                                    und im MessageStateCreator

                                       // Update ioBroker
                                        // über Admin-Adapter
                                        {
                                            msgID: 'UPDATE_INFO', 
                                            triggerDP: 'admin.0.info.updatesNumber',
                                            postMsgDP: {dp:'admin.0.info.updatesNumber', comp: '>=', val:0},
                                            removeMsgDP: {dp:'admin.0.info.updatesNumber', comp: '==', val:0},
                                            msgText_1: {text: 'Adapter: '},
                                            msgText_2: {dp: 'admin.0.info.updatesList'},
                                            msgText_3: {text: '. Bitte aktualisieren.'},
                                            countEventsDP: 'admin.0.info.updatesNumber'
                                        },    
                                    

                                    Da kommen bestimmt noch einige Ideen 😏

                                    T 1 Reply Last reply Reply Quote 0
                                    • R
                                      rebel85 @Tirador last edited by

                                      @Tirador
                                      hi,
                                      wie meinst du das? welchen ordner muss ich da anlegen oder in welchen muss ich es speichern?

                                      Das Javascript "MessageHandler" serverseitiges Script installieren

                                      und da ist es egal wo?
                                      Das Javascript "MessageStateCreator" installieren und starten (optional)

                                      D 1 Reply Last reply Reply Quote 0
                                      • D
                                        der-eine @rebel85 last edited by

                                        @rebel85
                                        Leg unter Skripte -> common einen Ordner mit dem Namen MessageHandler an
                                        Dort erstellst Du zwei neue Javascripts und kopierst den Inhalt dieser beiden Skripte hinein:
                                        MessageHandler
                                        MessageCreator

                                        Dann klickst Du oben auf die 3 Punkte und aktivierst den Expertenmodus
                                        Bildschirmfoto 2020-04-24 um 17.02.19.png

                                        In dem neu erscheinenden Ordner Global
                                        Erstellst Du wieder einen Ordner Namens MessageHandler und erstellst ein neues Javascript. Dort kommt der Inhalt von diesem Skript hinein:
                                        MessageGlobal

                                        So hab ich es bei mir gemacht.

                                        1 Reply Last reply Reply Quote 2
                                        • T
                                          Tirador @uwe12489 last edited by

                                          @uwe12489 @der-eine eure Nachrichten habe ich direkt mal übernommen. Das mit dem Update für IOBroker ist eine tolle Idee. Wäre gar nicht auf die Idee gekommen im Admin Adapter zu schauen.

                                          1 Reply Last reply Reply Quote 0
                                          • D
                                            der-eine last edited by

                                            @der-eine sagte in [Script] MessageHandler: Nachrichten protokollieren +VIS:

                                            @Tirador das View wechseln auch schon 😬 ?
                                            Habe das GästeWlan mit aufgenommen.

                                            MessageCreator

                                                // Gäste WLAN
                                                {
                                                    msgID: 'GUEST_WIFI', 
                                                    triggerDP: 'tr-064.0.states.wlanGuest',
                                                    postMsgDP: {dp:'tr-064.0.states.wlanGuest', comp: '==', val:true},
                                                    removeMsgDP: {dp:'tr-064.0.states.wlanGuest', comp: '==', val:false},
                                                    msgText_1: {text: 'Gäste WLAN eingeschalten'},
                                                    msgText_2: {dp: 'javascript.0.QR-Code.Gast'},
                                                    countEventsDP: ''
                                                },
                                            

                                            MessageHandler

                                            // Gäste WLAN
                                                    GUEST_WIFI: {msgEvent: [''], logType: 'LAST',  severity: 'INFO',  msgHeader: "WLAN", msgText: "", quit: false, mdIcon: 'wifi', mdIconColor: '', fontColor: '', backgroundColor: ''},
                                            

                                            Bildschirmfoto 2020-04-24 um 17.20.17.png

                                            Edit 24.04.2020
                                            QR-Code mit Zugangsdaten anzeigen.
                                            Es wird benötigt:

                                            • TR-064 Adapter

                                            • Skript

                                            // https://www.npmjs.com/package/qr-image
                                            
                                            var MySSID          = "FRITZ!Box XXX";           //  SSID Name GästeWlan
                                            
                                            var MyCrypt         = "WPA2";                //  [WEP|WPA|WPA2]
                                            
                                            var MyVisibility    = "n";                  //  Hidden SSID? 
                                            
                                            var cronStr         = "1 3 * * *"           // Script wird jeden Tag um 03:01 Ausgeführt
                                                                                       //Skript jede Minute ausführen * * * * * 
                                            
                                            
                                            var idQRZiel = "javascript.0.QR-Code.Gast"; // Zieldatenpunkt für QR-Code
                                            
                                            var IdGPasswd = "tr-064.0.states.wlanGuestPassword"; /*wlanGuestPassword*/
                                            
                                            
                                            
                                            if(MyVisibility == "y") {
                                            
                                              var MyHidden="H:true";
                                            
                                            } 
                                            
                                            else {
                                            
                                              MyHidden="";
                                            
                                            } 
                                            
                                            
                                            
                                            createState(idQRZiel, "", {
                                            
                                            
                                            
                                               name: 'QR-Code für Gastpasswort',
                                            
                                               desc: 'QR-Code für Gastpasswort',
                                            
                                               type: 'string',
                                            
                                               role: 'value'
                                            
                                            });
                                            
                                            
                                            
                                            function randomString(length) {         // Methode zur Erstellung eines Random-Passworts kann angepasst werden
                                            
                                            
                                            
                                              return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1);
                                            
                                            
                                            
                                            }
                                            
                                            
                                            
                                            function createQRcode() {
                                            
                                            
                                            
                                              var qr = require('qr-image');
                                            
                                              var NewPasswd = randomString(16);       // 16 Stelliges Passwort
                                            
                                              var svg_string = qr.imageSync('WIFI:S:'+MySSID+';T:'+MyCrypt+';P:'+NewPasswd+';'+MyHidden+';', { type: 'svg' });
                                            
                                                   
                                            
                                              setState(idQRZiel, svg_string);
                                              setState(IdGPasswd, NewPasswd);
                                              console.log('+++ Wlan Gast QR-Code neu erstellt +++');
                                            }
                                            
                                            
                                            
                                            
                                            // regelmässige Wiederholungen
                                            
                                            schedule(cronStr, createQRcode);
                                            

                                            • JavaScript Instanz qr-image

                                              Bildschirmfoto 2020-04-24 um 17.26.18.png

                                            Jetzt mit QR-Code zum einloggen ins GästeWlan

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            554
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            25
                                            336
                                            40394
                                            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