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

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Ereignisliste erzeugen

NEWS

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

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

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

Ereignisliste erzeugen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
89 Beiträge 21 Kommentatoren 20.2k Aufrufe 2 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.
  • P Offline
    P Offline
    PrinzEisenherz1
    schrieb am zuletzt editiert von
    #33

    @ruhr70:

    @kirbsi:

    Vielen Dank. Hat super geklappt. Kannst du mir noch n Tip geben wie du das mit den Farben gemacht hast? `

    Im Text des Ereignis html-Formatierungen einbauen:

    event('ioBroker - **Update für ' + obj.state.val + '** Adapter verfügbar.');
    

    event() ist bei mir eine kurze globale Funktion, mit der ich aus jedem Skript ein Ereignis schreiben kann.

    In den Ereignissen, in den ich was farbig oder fett darstellen lassen möchte, formatiere ich das mit . `

    Hi ruhr70!

    Könntest Du mir vielleicht das genauer erklären wie Du das mit der globalen Funktion umgesetzt hast?

    Ich habe da n paar Scripte wo ich gerne n Ereignis an die Ereignissliste übergeben möchte.

    Des weiteren hab ich nämlich das Problem wenn ich z.B ein Javascript-Objekt auslesen möchte

    ....
    ...
    var vBewegungGarten = $('state[id="javascript.0.Garten.Bewegung"]').each(function(id) {
        var val = getObject(id).common.name;
        log("Garten=" + val);
    });
    ..
    ...
    ..
    vBewegungGarten.on(function(obj) {
      if (obj.newState.val === 0) {
        var aktion="Bewegung erkannt";
        var ts=timestamp(obj.newState.ts);
        ereignis(ts + " Garten: " + aktion);
      }
        log("OBJ=" + JSON.stringify(obj,null,2));
    })
    
    

    Dann steigt irgendwie das Script bzw der Javascript-Adapter aus.

    Könntest Du mir da vielleicht weiterhelfen?

    Vielen Dank im voraus

    Gruß Johnny

    Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

    1 Antwort Letzte Antwort
    0
    • ruhr70R Offline
      ruhr70R Offline
      ruhr70
      schrieb am zuletzt editiert von
      #34

      @PrinzEisenherz1:

      Könntest Du mir vielleicht das genauer erklären wie Du das mit der globalen Funktion umgesetzt hast?

      Ich habe da n paar Scripte wo ich gerne n Ereignis an die Ereignissliste übergeben möchte. `

      ;-)

      ne, ist zu peinlich das zu schreiben ;-)

      Das globale Skript: :roll:

      function event(text) {
          setState("javascript.0.Ereignisliste.event",text);
      }
      
      

      Und dann das Skript für die Ereignisse als normales Skript. Überwachung des Datenpunkts im Ereignislistenskript. Erstellung der Ereignisliste.

      Über einen zweiten Parameter könnte man jetzt noch einbauen, dass unterschiedliche Datenpunkte gefüllt werden, um unterschiedliche Ereignislisten global anzusteuern.

      Das wars dann schon.

      @PrinzEisenherz1:

      Des weiteren hab ich nämlich das Problem wenn ich z.B ein Javascript-Objekt auslesen möchte

      ....
      ...
      var vBewegungGarten = $('state[id="javascript.0.Garten.Bewegung"]').each(function(id) {
          var val = getObject(id).common.name;
          log("Garten=" + val);
      });
      ..
      ...
      ..
      vBewegungGarten.on(function(obj) {
        if (obj.newState.val === 0) {
          var aktion="Bewegung erkannt";
          var ts=timestamp(obj.newState.ts);
          ereignis(ts + " Garten: " + aktion);
        }
          log("OBJ=" + JSON.stringify(obj,null,2));
      })
      
      

      Dann steigt irgendwie das Script bzw der Javascript-Adapter aus.

      Könntest Du mir da vielleicht weiterhelfen? `

      Ich weiss nicht, ob ich Dir da helfen kann. Mit dem Selector habe ich recht wenig Erfahrung und die Infos sind jetzt etwas dürftig.

      Kannst Du im Log mehr sehen?

      Ansonsten was geht auskommentieren und nach und nach freigeben, um zu sehen, wann der Adapter aussteigt.

      sorry

      Adapter: Fritzbox, Unify Circuit
      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

      1 Antwort Letzte Antwort
      0
      • P Offline
        P Offline
        PrinzEisenherz1
        schrieb am zuletzt editiert von
        #35

        Danke für die Info!

        Und wie hast Du Dein Ereignisscript abgeändert das es die Ereignisse so sauber untereinander reiht?

        Mein Script sieht so aus

        `/* Programm Ereignissliste für VIS */
        
        	var logging = true;
        
        createState("javascript.0.Servicemeldungen.vEreignisse","
        
        *   first
        
        ");
        
        var sensorsST = $('channel[state.id=*.STATE](functions=Schaltsteckdosen)').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("DeviceST=" + val);
        });
        
        var sensorsVS = $('channel[state.id=*.STATE](functions=Verschluss)').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("DeviceVS=" + val);
        });
        
        var sensorsBW = $('channel[state.id=*.MOTION](functions=Bewegungsmelder)').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("DeviceBW=" + val);
        });
        
        var vAlarmanlage_aussen = $('state[id="hm-rega.0.8834"]').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("Alarmanlage Aussenbereich= " + val);
        });
        
        var vAlarmanlage_gesamt = $('state[id="hm-rega.0.8835"]').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("Alarmanlage Gesamt= " + val);
        });
        
        var vAnwesenheitBaerchen = $('state[id="hm-rega.0.17897"]').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("Baerchen anwesend= " + val);
        });
        
        var vAnwesenheitHase = $('state[id="hm-rega.0.17898"]').each(function(id) {
            var val = getObject(id).common.name;
        	if (logging) log("Hase anwesend= " + val);
        });
        
        function ereignis(text) {
        	if (logging) log("ereignis "+text);
            var ereignisStr = getState("javascript.0.Servicemeldungen.vEreignisse").val;
            var ereignisArr;
            ereignisArr = ereignisStr.replace(/`
        
        `*   /, "").replace(/<\/li><\/ul>/, "").split("*   ");
                ereignisArr = ereignisArr.reverse();
                ereignisArr.push(text);
                ereignisArr.reverse().splice(99); // Liste auf 20 Einträge beschränken
                var str = ereignisArr.join("`
        *   `");
                setState("javascript.0.Servicemeldungen.vEreignisse", "
        
            *   "+str+"
        
            ");
            }
        
            function timestamp(ts) {
                var now=new Date(ts);
                var day = now.getDate();
                var month = now.getMonth() + 1;
                var year = now.getFullYear();
                var weekday = now.getDay();
                var hours = now.getHours();
                var minutes = now.getMinutes();
                var seconds = now.getSeconds();
                var day0  = ((day < 10) ? "0" : "");
                var month0  = ((month < 10) ? "0" : "");
                var hours0  = ((hours < 10) ? "0" : "");
                var minutes0  = ((minutes < 10) ? "0" : "");
                var seconds0  = ((seconds < 10) ? "0" : "");
                var output = day0 + day + "." + month0 + month + ". " + hours0 + hours + ":" + minutes0 + minutes+ " ";
                return output;
            }
        
            sensorsST.on(function(obj) {
              var aktion=" => AUS";
              if (obj.newState.val == 1) {
                aktion=" => AN";
              }
              var ts=timestamp(obj.newState.ts);
              ereignis(ts + "  " + obj.deviceName + " " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });
        
            sensorsVS.on(function(obj) {
              var aktion=" => VERSCHLOSSEN";
              if (obj.newState.val == 2) {
                aktion=" => AUF";
              }
                if (obj.newState.val == 1) {
                aktion=" => KIPP";
              }
              var ts=timestamp(obj.newState.ts);
              ereignis(ts + "  " + obj.deviceName + " " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });
        
            sensorsBW.on(function(obj) {
              if (obj.newState.val == 1) {
              var ts=timestamp(obj.newState.ts);
              ereignis(ts + "  " + room(obj) + " " + " => Bewegung");
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
              }
            });
        
            vAlarmanlage_aussen.on(function(obj) {
              var aktion="Aussenbereich gesichert";
              if (obj.newState.val == 1) {
                aktion="Aussenbereich deaktiviert";
              }
              var ts=timestamp(obj.newState.ts);
                ereignis(ts + "  Alarmstatus: " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });
        
            vAlarmanlage_gesamt.on(function(obj) {
              var aktion="Komplettbereich gesichert";
              if (obj.newState.val == 1) {
                aktion="Komplettbereich deaktiviert";
              }
              var ts=timestamp(obj.newState.ts);
                ereignis(ts + "  Alarmstatus: " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });
        
            vAnwesenheitBaerchen.on(function(obj) {
              var aktion="Bärchen ist ausser Haus";
              if (obj.newState.val == 1) {
                aktion="Bärchen ist anwesend";
              }
              var ts=timestamp(obj.newState.ts);
                ereignis(ts + "  Anwesenheit: " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });
        
            vAnwesenheitHase.on(function(obj) {
              var aktion="Hase ist ausser Haus";
              if (obj.newState.val == 1) {
                aktion="Hase ist anwesend";
              }
              var ts=timestamp(obj.newState.ts);
                ereignis(ts + "  Anwesenheit: " + aktion);
            	if (logging) log("OBJ=" + JSON.stringify(obj,null,2));
            });` 
        
            und das Globale Script so
            ````
            function event(text) {
                setState("javascript.0.Servicemeldungen.vEreignisse",text);
            }
        
            ````
        
            Wenn ich jetzt Dein Beispiel nehme
            ````
            on({id: 'admin.0.info.updatesNumber', change: 'any'},
            function(obj) {
            event2('ioBroker - **Update für ' + obj.state.val + '** Adapter verfügbar.');
            });
        
            ````
            Dann werden zum einen alle Ereignisse gelöscht und nur dieses angezeigt und dann fehlt auch noch die Uhrzeit!
        
            Wie hast du das gelöst?
        
            gruß
        
            Johnny
        
        

        Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

        1 Antwort Letzte Antwort
        0
        • ruhr70R Offline
          ruhr70R Offline
          ruhr70
          schrieb am zuletzt editiert von
          #36

          @PrinzEisenherz1:

          Danke für die Info!

          Und wie hast Du Dein Ereignisscript abgeändert das es die Ereignisse so sauber untereinander reiht? `

          Das "globale Skript" und dann ein normales Skript, um die Ereignisliste zu erstellen:

          ! ```
          // Erstellt eine Ereignisliste mit 50 Einträgen //============================================== ! var eventsLength = 50; // maximale Anzahl von Ereignissen ! var idEventList = "Ereignisliste.eventlistArr"; // Hier wird die Lsite als Array angelegt var idEventListStr = "Ereignisliste.eventlist"; // Die Liste als String mit für VIS ! var idEvent = "javascript.0.Ereignisliste.event"/*Aktueller Event*/; // überwachter Datenpunkt ! // Events werden mit der globalen Funktion // event() als Text in die ID: idEvent geschrieben // neue Texte dort werden von diesem Skript verarbeitet ! // ----------------------------------------------------------------------------- ! // Datenpunkt für die Eventliste anlegen createState(idEventList ,formatDate(new Date(), 'DD.MM. hh:mm') + ' Datenpunkt angelegt'); createState(idEventListStr ,""); ! function readListEvent(id) { // lese ein JSON aus einem Datenpunkt var list; try { list = JSON.parse(getState(id).val); } catch (ex) { list = []; } if(!list) list = []; return list; } function writeListEvent(list,id) { // schreibt ein JSON in einen Datenpunkt setState(id, JSON.stringify(list)); } ! function getEventsList(events) { var text = ''; for (var i = 0; i < events.length; i++) { text += (text ? ' \n' : '') + events[i]; } return text; } ! // Ereignis schreiben function writeEvent(text) { var events = readListEvent(idEventList); // list die Liste aus einem Datenpunkt events.unshift(formatDate(new Date(), 'DD.MM. hh:mm ') + text); // fügt den Text als Event am Anfag der Liste ien if (events.length > eventsLength) events.pop(); // kürzt die Liste hinten, wenn die maximale Länge erreicht ist writeListEvent(events, idEventList); // schreibt die Liste in den Datenpunkt zurück setState(idEventListStr,getEventsList(events)); // erzeugt aus dem Array den String mit für neue Zeilen } ! // ----------------------------------------------------------------------------- ! on({id:idEvent,change:'any'}, function (obj) { // wenn ein neuer Event geschrieben wird //if (!obj.newState.ack && obj.newState.val) { log("neuer Event zum verarbeiten: " + obj.state.val); writeEvent(obj.state.val); //} }); ! // --------------- Script start ---------------- #### Script Start #### ! function main() { log("Ereignisliste: Skript gestartet"); } ! setTimeout(main, 500);
          ! Wenn in einem beliebigen anderen Skript nun event("Beispieltext") aufgerufen wird, dann erscheint in der Ereignisliste ein Eintrag mit aktuellem formatiertem Datum.
          ! Bei Dir ist die Ereignisliste und die Ereignisse ein großes Skript.
          ! Ich habe das in ein Skript für die Liste getrennt und kann dann aus jedem beliebigen anderem Skript entscheiden, ob ein "Ereignis":
          ! - in die Ereignisliste
          ! - als Pushover
          ! - als Telegram
          ! - als Email
          ! - als sayit
          ! - im log
          ! - usw.
          ! ausgegeben werden soll.
          ! Für sayit gibt es dann z.B. auch ein globales sayit().[/i]

          Adapter: Fritzbox, Unify Circuit
          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

          1 Antwort Letzte Antwort
          0
          • P Offline
            P Offline
            PrinzEisenherz1
            schrieb am zuletzt editiert von
            #37

            Wow, das ist echt super von Dir!

            Das hilft mir schonmal rießig weiter!

            Tausend Dank!

            Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

            1 Antwort Letzte Antwort
            0
            • J Offline
              J Offline
              jensus11
              schrieb am zuletzt editiert von
              #38

              @ruhr70

              Könntest du dein globes Skript noch einstellen? Und ein Bsp. für ein anderes in dem Event mit Test enthalten ist?

              gruss

              1 Antwort Letzte Antwort
              0
              • ruhr70R Offline
                ruhr70R Offline
                ruhr70
                schrieb am zuletzt editiert von
                #39

                @jensus11:

                @ruhr70

                Könntest du dein globes Skript noch einstellen? Und ein Bsp. für ein anderes in dem Event mit Test enthalten ist?

                gruss `

                das große globale Skript findest Du im Post #34 ;-)

                Gesendet von iPhone mit Tapatalk

                Adapter: Fritzbox, Unify Circuit
                Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                1 Antwort Letzte Antwort
                0
                • J Offline
                  J Offline
                  jensus11
                  schrieb am zuletzt editiert von
                  #40

                  Frohe Weihnachten, das Globale hatte ich jetzt auch schon gefunden gehabt.

                  Hättest du noch ein Bsp.Script in dem ein Event geschrieben?

                  Ich weiss nicht wie ich das in andere Scripte schreiben soll.

                  1 Antwort Letzte Antwort
                  0
                  • ruhr70R Offline
                    ruhr70R Offline
                    ruhr70
                    schrieb am zuletzt editiert von
                    #41

                    @jensus11:

                    Frohe Weihnachten, das Globale hatte ich jetzt auch schon gefunden gehabt.

                    Hättest du noch ein Bsp.Script in dem ein Event geschrieben?

                    Ich weiss nicht wie ich das in andere Scripte schreiben soll. `

                    Was möchtest Du denn in eine Ereignisliste schreiben?

                    Du überwachst z.B. ein Objekt, bei dem Du bei Veränderung ein Ereignis schreiben möchtest.

                    Das können ganz kleine Skripte sein.

                    on({id:'hm-rpc.0.IEQ0099029.1.STATE/*Türkontakt Wohnungstür*/',change:'ne'}, function (obj) {
                        if (obj.state.val) {
                            event("Wohnungstür geöffnet");
                        }
                    });
                    

                    Ich habe für diverse Ereignisse Skripte in einem Ordner "Ereignisse" im Javaskript-Adapter.

                    Oben das Beispiel ist gekürzt, aber ausreichend.

                    Ein längeres Beispiel, wenn ein Anruf über die Fritzbox reinkommt:

                    • beim Anruf wird "Anruf von (Name des Anrufers) auf Sonos ausgegeben"

                    • die Info geht per Telegram und per Pushover raus

                    • am Ende des Anrufes wird der Anruf mit Zusatzinfos in die Ereignisliste geschrieben

                    ! ````
                    // -- Anrufe --
                    ! var pushoverOn = true;
                    var telegramOn = true;
                    var sayitAzOn = true; // Ansage im Arbeitszimmer
                    var sayitWzOn = false; // Ansage Im Wohnzimmer
                    var eventOn = true;
                    ! // Das Skript nutzt folgende globale Funktionen:
                    //
                    // fill()
                    // rufnummer2name()
                    // event()
                    // sayit()
                    ! var laengeNameTelefonbuch = 22; // Länge in der ein Name aus dem Telefonbuch in die Ereignisliste geschrieben wird
                    ! // -----------------------------------------------------------------------------
                    ! var timer = null;
                    ! function readJSON(json) {
                    log('Start JSON Daten einlesen');
                    if (json) {
                    var result;
                    try{
                    result = JSON.parse(json);
                    var data = JSON.stringify(result, null, 2);
                    // log(data); // gibt alle JSON Variablen mit Wert als einzelne Zeile aus
                    log('Kein Fehler :-D');
                    } catch (e) {
                    log('Parse Fehler:' + e);
                    }
                    if (result) {
                    log('Daten aus JSON eingelesen');
                    return result;
                    }
                    } else {
                    log('Fehler:' + error);
                    return null;
                    }
                    log('keine JSON Daten zur Verarbeitung');
                    return null;
                    }
                    ! // -----------------------------------------------------------------------------
                    // Telefon klingelt, Ansage des Anrufers aktueller Anrufer
                    // -----------------------------------------------------------------------------
                    on({id:'fritzbox.0.calls.ringActualNumber',change:'ne'}, function (obj) {
                    if (obj.state.val !== "") {
                    var name = "Anruf von: " + rufnummer2name(obj.state.val);
                    // log(name);
                    if(pushoverOn) sendTo("pushover",name + " - " + obj.state.val);
                    if(telegramOn) sendTo('telegram.1' ,name + '\n' + obj.state.val);
                    // TTS
                    if(sayitAzOn) sayit(name);
                    if(sayitWzOn) sayit(name,30,2); // Name des Anrufer auf Sonos im Wohnzimmer
                    }
                    });
                    ! // -----------------------------------------------------------------------------
                    // Anruf Informationen zum Gesprächsende CDR
                    // -----------------------------------------------------------------------------
                    on({id: "fritzbox.0.cdr.json", valNe: 2}, function(obj) { // Fritzbox Eintrag am Ende eines Telefonats
                    if (!timer) {
                    timer = setTimeout(function () {
                    timer = null;
                    }, 1000);
                    var deltatime = getState("fritzbox.0.system.deltaTime").val;
                    if (parseInt(deltatime) < -5 || parseInt(deltatime) > 5) {
                    event('DeltaZeit Fritz/System: ' + deltatime);
                    }
                    ! var cdr = getState("fritzbox.0.cdr.json");
                    var cdrJSON = readJSON(cdr.val);
                    //var externalNumber
                    var name = rufnummer2name(cdrJSON.externalNumber);
                    ! // name auf gleiche Länge kürzen
                    name = name.substring(0, laengeNameTelefonbuch);
                    name = name + fill(laengeNameTelefonbuch - name.length);
                    // Ereignisliste
                    if(eventOn) event('' + cdrJSON.externalTelLink + " " + name + " " + cdrJSON.callSymbolColor + " " + cdrJSON.durationForm + '');
                    }
                    });

                    
                    Da sind noch weitere globale Funktionen drin. Daher wird das Skript nicht ohne Anpassungen laufen.

                    Adapter: Fritzbox, Unify Circuit
                    Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                    1 Antwort Letzte Antwort
                    0
                    • J Offline
                      J Offline
                      jensus11
                      schrieb am zuletzt editiert von
                      #42

                      cool, das kurze reicht mir erstmal. Damit werde ich es erstmal versuchen.

                      rein sollten da Sachen wie:

                      • Sonne geht auf, Sonne geht unter

                      • Bewegung erkannt

                      • Tür geöffnet

                      • Sonnensensor Sonne scheint

                      mehr fällt mir auf die Schnelle nicht ein.

                      1 Antwort Letzte Antwort
                      0
                      • J Offline
                        J Offline
                        jensus11
                        schrieb am zuletzt editiert von
                        #43

                        so sieht mein Testscript aus. Leider wird nix in die Eventliste geschrieben.

                        Ist doch korrekt so oder?

                        on({id:'hm-rpc.0.KEQXXXXX9.1.STATE/*FK Balkontür*/',change:'ne'}, function (obj) {
                            if (obj.state.val) {
                                event("Balkontür geöffnet");
                            }
                        });
                        

                        So das globale.

                        function event(text) {
                            setState("javascript.0.Ereignisliste.event",text);
                        }
                        

                        und so das große.

                        Muss da auch was eingerichtet werden?

                        ! // Erstellt eine Ereignisliste mit 50 Einträgen
                        ! //==============================================
                        ! var eventsLength = 50; // maximale Anzahl von Ereignissen
                        ! var idEventList = "Ereignisliste.eventlistArr"; // Hier wird die Lsite als Array angelegt
                        ! var idEventListStr = "Ereignisliste.eventlist"; // Die Liste als String mit
                        für VIS
                        ! var idEvent = "javascript.0.Ereignisliste.event"/Aktueller Event/; // überwachter Datenpunkt
                        ! // Events werden mit der globalen Funktion
                        ! // event() als Text in die ID: idEvent geschrieben
                        ! // neue Texte dort werden von diesem Skript verarbeitet
                        ! // –---------------------------------------------------------------------------
                        ! // Datenpunkt für die Eventliste anlegen
                        ! createState(idEventList ,formatDate(new Date(), 'DD.MM. hh:mm') + ' Datenpunkt angelegt');
                        ! createState(idEventListStr ,"");
                        ! function readListEvent(id) { // lese ein JSON aus einem Datenpunkt
                        ! var list;
                        ! try {
                        ! list = JSON.parse(getState(id).val);
                        ! } catch (ex) {
                        ! list = [];
                        ! }
                        ! if(!list) list = [];
                        ! return list;
                        ! }
                        ! function writeListEvent(list,id) { // schreibt ein JSON in einen Datenpunkt
                        ! setState(id, JSON.stringify(list));
                        ! }
                        ! function getEventsList(events) {
                        ! var text = '';
                        ! for (var i = 0; i < events.length; i++) {
                        ! text += (text ? '
                        \n' : '') + events__;
                        ! }
                        ! return text;
                        ! }
                        ! // Ereignis schreiben
                        ! function writeEvent(text) {
                        ! var events = readListEvent(idEventList); // list die Liste aus einem Datenpunkt
                        ! events.unshift(formatDate(new Date(), 'DD.MM. hh:mm ') + text); // fügt den Text als Event am Anfag der Liste ien
                        ! if (events.length > eventsLength) events.pop(); // kürzt die Liste hinten, wenn die maximale Länge erreicht ist
                        ! writeListEvent(events, idEventList); // schreibt die Liste in den Datenpunkt zurück
                        ! setState(idEventListStr,getEventsList(events)); // erzeugt aus dem Array den String mit
                        für neue Zeilen
                        ! }
                        ! // –---------------------------------------------------------------------------
                        ! on({id:idEvent,change:'any'}, function (obj) { // wenn ein neuer Event geschrieben wird
                        ! //if (!obj.newState.ack && obj.newState.val) {
                        ! log("neuer Event zum verarbeiten: " + obj.state.val);
                        ! writeEvent(obj.state.val);
                        ! //}
                        ! });
                        ! // --------------- Script start ---------------- #### Script Start ####
                        ! function main() {
                        ! log("Ereignisliste: Skript gestartet");
                        ! }
                        ! setTimeout(main, 500);__

                        1 Antwort Letzte Antwort
                        0
                        • J Offline
                          J Offline
                          jensus11
                          schrieb am zuletzt editiert von
                          #44

                          @jensus11:

                          so sieht mein Testscript aus. Leider wird nix in die Ereignisliste geschrieben.

                          Ist doch korrekt so oder?

                          on({id:'hm-rpc.0.KEQXXXXX9.1.STATE/*FK Balkontür*/',change:'ne'}, function (obj) {
                              if (obj.state.val) {
                                  event("Balkontür geöffnet");
                              }
                          });
                          

                          So das globale.

                          function event(text) {
                              setState("javascript.0.Ereignisliste.event",text);
                          }
                          

                          und so das große.

                          Muss da auch was eingerichtet werden?

                          ! // Erstellt eine Ereignisliste mit 50 Einträgen
                          ! //==============================================
                          ! var eventsLength = 50; // maximale Anzahl von Ereignissen
                          ! var idEventList = "Ereignisliste.eventlistArr"; // Hier wird die Lsite als Array angelegt
                          ! var idEventListStr = "Ereignisliste.eventlist"; // Die Liste als String mit
                          für VIS
                          ! var idEvent = "javascript.0.Ereignisliste.event"/Aktueller Event/; // überwachter Datenpunkt
                          ! // Events werden mit der globalen Funktion
                          ! // event() als Text in die ID: idEvent geschrieben
                          ! // neue Texte dort werden von diesem Skript verarbeitet
                          ! // –---------------------------------------------------------------------------
                          ! // Datenpunkt für die Eventliste anlegen
                          ! createState(idEventList ,formatDate(new Date(), 'DD.MM. hh:mm') + ' Datenpunkt angelegt');
                          ! createState(idEventListStr ,"");
                          ! function readListEvent(id) { // lese ein JSON aus einem Datenpunkt
                          ! var list;
                          ! try {
                          ! list = JSON.parse(getState(id).val);
                          ! } catch (ex) {
                          ! list = [];
                          ! }
                          ! if(!list) list = [];
                          ! return list;
                          ! }
                          ! function writeListEvent(list,id) { // schreibt ein JSON in einen Datenpunkt
                          ! setState(id, JSON.stringify(list));
                          ! }
                          ! function getEventsList(events) {
                          ! var text = '';
                          ! for (var i = 0; i < events.length; i++) {
                          ! text += (text ? '
                          \n' : '') + events__;
                          ! }
                          ! return text;
                          ! }
                          ! // Ereignis schreiben
                          ! function writeEvent(text) {
                          ! var events = readListEvent(idEventList); // list die Liste aus einem Datenpunkt
                          ! events.unshift(formatDate(new Date(), 'DD.MM. hh:mm ') + text); // fügt den Text als Event am Anfag der Liste ien
                          ! if (events.length > eventsLength) events.pop(); // kürzt die Liste hinten, wenn die maximale Länge erreicht ist
                          ! writeListEvent(events, idEventList); // schreibt die Liste in den Datenpunkt zurück
                          ! setState(idEventListStr,getEventsList(events)); // erzeugt aus dem Array den String mit
                          für neue Zeilen
                          ! }
                          ! // –---------------------------------------------------------------------------
                          ! on({id:idEvent,change:'any'}, function (obj) { // wenn ein neuer Event geschrieben wird
                          ! //if (!obj.newState.ack && obj.newState.val) {
                          ! log("neuer Event zum verarbeiten: " + obj.state.val);
                          ! writeEvent(obj.state.val);
                          ! //}
                          ! });
                          ! // --------------- Script start ---------------- #### Script Start ####
                          ! function main() {
                          ! log("Ereignisliste: Skript gestartet");
                          ! }
                          ! setTimeout(main, 500);__ `

                          1 Antwort Letzte Antwort
                          0
                          • ruhr70R Offline
                            ruhr70R Offline
                            ruhr70
                            schrieb am zuletzt editiert von
                            #45

                            Sieht auf dem ersten Blick erst einmal gut aus…

                            @jensus11:

                            so sieht mein Testscript aus. Leider wird nix in die Ereignisliste geschrieben.

                            Ist doch korrekt so oder?

                            on({id:'hm-rpc.0.KEQXXXXX9.1.STATE/*FK Balkontür*/',change:'ne'}, function (obj) {
                                if (obj.state.val) {
                                    event("Balkontür geöffnet");
                                }
                            });
                            ```` `  
                            

                            Wenn Du nach dem event() ein log("Hier fand ein Ereignis statt"); einträgst, wird dann was ins Log geschrieben?

                            @jensus11:

                            So das globale.

                            function event(text) {
                                setState("javascript.0.Ereignisliste.event",text);
                            }
                            ```` `  
                            

                            Ist OK, wenn Du das große Skript auch in der Javascript Instanz 0 laufen hast.

                            Auch hier könntest Du nach dem setState() ein log("event() globa wurde aufgerufen."); zur Fehlereingrenzung einfügen.

                            @jensus11:

                            und so das große.

                            Muss da auch was eingerichtet werden? `

                            Nein. Du könntest den Pfad und die Namen der Datenpunkte anpassen. Das dann aber auch bei der globalen event() Funktion.

                            Sind alle Datenpunkte angelegt?

                            Passen die Javascript-Instanzen?

                            Das globale Skript ist auch wirklich global?

                            Die Skripte sind aktiv? ;-)

                            Adapter: Fritzbox, Unify Circuit
                            Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                            1 Antwort Letzte Antwort
                            0
                            • J Offline
                              J Offline
                              jensus11
                              schrieb am zuletzt editiert von
                              #46

                              ich habe die logs jetzt mit angehängt, doch die bringen auch nix. Im log sind keine Einträge zu finden.

                              Es sieht so aus als ob die Scripte gar nicht starten.

                              Das globale muss doch nur in die Globale-Gruppe gespeichert werden oder?

                              Wie meinst du das mit Javascript Instanzen?

                              Bei dem Großen habe ich noch ein log angehangen. Das wir auch im Log aufgeführt wenn ich es starte.

                              Nur bei den anderen wird nichts ins log geschrieben beim starten oder wenn ich die Balkontür öffne.

                              1 Antwort Letzte Antwort
                              0
                              • ruhr70R Offline
                                ruhr70R Offline
                                ruhr70
                                schrieb am zuletzt editiert von
                                #47

                                Dann löst Dein Testskript nicht aus, wenn Du die Balkontür öffnest.

                                on({id:'hm-rpc.0.KEQXXXXX9.1.STATE/*FK Balkontür*/',change:'ne'}, function (obj) {
                                    if (obj.state.val) {
                                        event("Balkontür geöffnet");
                                    }
                                });
                                

                                Hast Du im Admin unter Zustände mal nach den Datenpunkt gefiltert und geschaut, ob sich was ändert, wenn Du die Balkontür öffnest und dann wieder schliesst?

                                Dort kannst Du auch manuel von false auf true den Zustand ändern.

                                Adapter: Fritzbox, Unify Circuit
                                Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                1 Antwort Letzte Antwort
                                0
                                • ruhr70R Offline
                                  ruhr70R Offline
                                  ruhr70
                                  schrieb am zuletzt editiert von
                                  #48

                                  Zur Eingrenzung könntest Du auch noch ein Einzeiler starten;

                                  event("Skript wurde gestartet");
                                  

                                  Dann sollte das als Ereignis in die Liste geschrieben werden.

                                  Adapter: Fritzbox, Unify Circuit
                                  Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                  1 Antwort Letzte Antwort
                                  0
                                  • J Offline
                                    J Offline
                                    jensus11
                                    schrieb am zuletzt editiert von
                                    #49

                                    so jetzt kommt mal eine Fehlermeldung.

                                    javascript.0 2016-12-27 12:08:11.635 warn State "javascript.0.Ereignisliste.event" not found

                                    diesen Punkt habe ich auch nicht.

                                    Unter Objekte ist nur der Ordner: javascript.0.Ereignisliste mit dem Inhalt javascript.0.Ereignisliste.eventlist und javascript.0.Ereignisliste.eventlistArr

                                    1 Antwort Letzte Antwort
                                    0
                                    • J Offline
                                      J Offline
                                      jensus11
                                      schrieb am zuletzt editiert von
                                      #50

                                      Habe den Datenpunkt jetzt mal angelegt. Werde jetzt mal kuz testen.

                                      1 Antwort Letzte Antwort
                                      0
                                      • J Offline
                                        J Offline
                                        jensus11
                                        schrieb am zuletzt editiert von
                                        #51

                                        Wenn ich den Einzeiler starte. Überträgt er den event.

                                        Wird dann in in event und eventlist und eventlistArr dargestellt.

                                        Ich habe in das große Script die Zeile: createState(idEvent ,""); hinzugefügt.

                                        Wenn ich STATE unter Zustände änder löst es auch nicht aus.

                                        1 Antwort Letzte Antwort
                                        0
                                        • J Offline
                                          J Offline
                                          jensus11
                                          schrieb am zuletzt editiert von
                                          #52

                                          Also mit dem Einzeiler klappt das super.

                                          Wir schön in der eventlist dokumentiert.

                                          ` > on({id:'hm-rpc.0.LEQXXXXX91.1.STATE/Licht Wohnzimmer/',change:'ne'}, function (obj) {

                                          if (obj.state.val) {

                                          event("Licht Wohnzimmer");

                                          }

                                          }); `

                                          Habe das Script auf den Lichtschalter geändert. Geht aber auch nicht.

                                          Ist das wirklich richtig so?

                                          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

                                          821

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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