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. [Gelöst] Helios KWL - Zugriff auf xml

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.3k

[Gelöst] Helios KWL - Zugriff auf xml

Geplant Angeheftet Gesperrt Verschoben JavaScript
70 Beiträge 13 Kommentatoren 10.5k Aufrufe 13 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.
  • E elmocito

    @klvn
    Richtig starkes Script.
    Ich hab auch eine Helios und habe aktuell nur Homebridge und Loxone bei mir im Einsatz.
    Da die Loxone Lösung, die es zur Helios gibt nicht zufriedenstellend war, überlege ich eine ioBroker Instanz hochzuziehen.
    Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

    KLVNK Offline
    KLVNK Offline
    KLVN
    schrieb am zuletzt editiert von
    #48

    @elmocito sagte in [Gelöst] Helios KWL - Zugriff auf xml:

    Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

    Moin, mit Homebridge hatte und habe ich überhaupt keinen Kontakt, sorry.

    Und danke für den Stern bei GitHub ;)

    K 1 Antwort Letzte Antwort
    0
    • KLVNK KLVN

      Moin,

      mittlerweile sind 2 Wochen vergangen und ich wollte mich mal erkundigen, wie es so mit eurer Lüftersteuerung läuft :)
      Ich habe in der Zeit meinen Wochenplan etwas angepasst, sodass der Lüfter nach x Minuten wieder ausgestellt wird und nicht immer exakt zu jeder angefangenen Stunde und dass er ausgestellt wird, wenn niemand Zuhause ist. Zusätzlich habe ich noch eine "Dusch-Erkennung" eingebaut, die den Lüfter startet, sobald in den letzten 5 Minuten geduscht wurde/wird - seitdem habe ich keine beschlagenen Spiegel mehr und Schimmel kann gar nicht erst ansetzen.

      Meinen zusätzlichen Spielkram habe ich jetzt auch bei GitHub in einem gesonderten Ordner veröffentlicht: https://github.com/KLVN/ioBroker_Helios-KWL/tree/master/additionalScripts


      • Für die Personenzählung frage ich meine Fritzbox nach den Geräten im Netzwerk ab und zähle dann die Smartphones (das mache ich aber außerhalb vom ioBroker)
      • Die Dusche kann ich erkennen, weil ein Durchlauferhitzer verbaut ist und dieser mächtig Strom verbraucht. War der Durchschnittsverbrauch in den letzten 5 Minuten über 6kW, dann duscht (höchstwahrscheinlich) jemand und der Lüfter geht an. Das kann aber auch durch andere Verbraucher, wie mehrere Herdplatten, Haarföne, Waschmaschine, usw. ausgelöst werden.
      M Offline
      M Offline
      moehre
      schrieb am zuletzt editiert von
      #49

      @klvn

      Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

      KLVNK 1 Antwort Letzte Antwort
      1
      • M moehre

        @klvn

        Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

        KLVNK Offline
        KLVNK Offline
        KLVN
        schrieb am zuletzt editiert von
        #50

        @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

        @klvn

        Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

        Ich muss mich aber auch bei dir bedanken, für deine Pionierarbeit, schließlich hast du den Stein ins Rollen gebracht :D

        M 1 Antwort Letzte Antwort
        1
        • KLVNK KLVN

          @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

          @klvn

          Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

          Ich muss mich aber auch bei dir bedanken, für deine Pionierarbeit, schließlich hast du den Stein ins Rollen gebracht :D

          M Offline
          M Offline
          moehre
          schrieb am zuletzt editiert von moehre
          #51

          Ich bastele gerade daran, weitere xmls auszulesen. Sieht so aus. Es sind 2 console.logs mit reingekommen, damit ich folgendem Problem irgendwie auf die Schliche komme...

          // Refresh values
          setInterval(function () {
            // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
            const xmlPages = [1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17];
            xmlPages.forEach(function (page, index) {
              request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                console.log(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"))
                refreshValues(result);
                console.log(result);
                });
            });
          }, refresh_interval * 1000);
          

          Das klappt bis zu 12 xmls auch super, alle weiteren werfen Fehler. Folglich bekomme ich diesen Fehler 4x:

          javascript.0	2021-04-13 01:01:57.423	error	(549) Request error: Error: connect ECONNRESET [hier steht die IP der Helios samt Port]
          javascript.0	2021-04-13 01:01:57.423	error	(549) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
          

          Laut log sieht der request gut aus, die URLs werden korrekt erstellt, die xmls existieren.
          Es ist egal, welche page rausgenommen wird, jede Änderung der pages wird die Fehleranzahl verändern.

          Verdacht: refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.
          Ich habe daher versucht, den request asynchron auszuführen - ohne Erfolg. Auch eine Verzögerung um x ms hat nichts gebracht.

          Woran könnte der Fehler liegen?

          P.S. Lösungsansatz, ohne das Problem wirklich zu verstehen: Man könnte request und refreshValues trennen. Sodass der request die übertragenen Werte als JSON wegschreibt. Der refreshValues würde dann nur noch bereits vorhandene Variablen hübsch machen. Damit wären Rückmeldung und Verarbeitung unabhängig voneinander. Und Fehler in der Aktualisierung der Daten ließen sich vorzeitig erkennen.

          P.P.S. Über Sinn und Unsinn, wirklich ALLE Pages auszulesen, kann man sicher streiten :)

          VG

          KLVNK 1 Antwort Letzte Antwort
          0
          • M moehre

            Ich bastele gerade daran, weitere xmls auszulesen. Sieht so aus. Es sind 2 console.logs mit reingekommen, damit ich folgendem Problem irgendwie auf die Schliche komme...

            // Refresh values
            setInterval(function () {
              // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
              const xmlPages = [1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17];
              xmlPages.forEach(function (page, index) {
                request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                  console.log(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"))
                  refreshValues(result);
                  console.log(result);
                  });
              });
            }, refresh_interval * 1000);
            

            Das klappt bis zu 12 xmls auch super, alle weiteren werfen Fehler. Folglich bekomme ich diesen Fehler 4x:

            javascript.0	2021-04-13 01:01:57.423	error	(549) Request error: Error: connect ECONNRESET [hier steht die IP der Helios samt Port]
            javascript.0	2021-04-13 01:01:57.423	error	(549) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
            

            Laut log sieht der request gut aus, die URLs werden korrekt erstellt, die xmls existieren.
            Es ist egal, welche page rausgenommen wird, jede Änderung der pages wird die Fehleranzahl verändern.

            Verdacht: refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.
            Ich habe daher versucht, den request asynchron auszuführen - ohne Erfolg. Auch eine Verzögerung um x ms hat nichts gebracht.

            Woran könnte der Fehler liegen?

            P.S. Lösungsansatz, ohne das Problem wirklich zu verstehen: Man könnte request und refreshValues trennen. Sodass der request die übertragenen Werte als JSON wegschreibt. Der refreshValues würde dann nur noch bereits vorhandene Variablen hübsch machen. Damit wären Rückmeldung und Verarbeitung unabhängig voneinander. Und Fehler in der Aktualisierung der Daten ließen sich vorzeitig erkennen.

            P.P.S. Über Sinn und Unsinn, wirklich ALLE Pages auszulesen, kann man sicher streiten :)

            VG

            KLVNK Offline
            KLVNK Offline
            KLVN
            schrieb am zuletzt editiert von
            #52

            @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

            refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.

            Das kann eigentlich nicht sein, weil request() diejenige Funktion ist, die nach eigener Beendigung refreshValues() aufruft und result überliefert.

            Ich habe bei mir auch gerade alle XML-Seiten von 1 bis 17 durchprobiert, anfangs immer nur in Gruppen von ca. 6 Seiten, damit mein Log nicht zugemüllt wird und da gab es keine Fehler. Dann habe ich mir nochmal deine Fehlermeldung angesehen und "ECONNRESET" bedeutet, dass die Helios-Anlage die Verbindung getrennt hat. Dann habe ich nochmal dein Array an XML-Seiten genommen (also alle 16 auf einmal) und dann auch Fehlermeldungen bekommen. Meine Vermutung ist jetzt, dass die Helios-Anlage nicht zu viele Anfragen in sehr kurzer Zeit beantworten will und deshalb teilweise abbricht. Bei mir waren es auch nicht immer dieselben Seiten, bei denen abgebrochen wurde, sondern jedes Mal komplett unterschiedlich.

            @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

            Auch eine Verzögerung um x ms hat nichts gebracht.

            Wo und wie hast du diese Verzögerung eingebaut? Wenn man xmlPages.forEach() langsamer laufen lässt, sollte es eigentlich gehen, habe es jetzt aber auch nicht getestet. Leider gibt es auch keine einzelne XML-Seite, auf der alle Werte auf einmal sind.

            1 Antwort Letzte Antwort
            0
            • M Offline
              M Offline
              moehre
              schrieb am zuletzt editiert von
              #53

              @klvn sagte in [Gelöst] Helios KWL - Zugriff auf xml:

              Wo und wie hast du diese Verzögerung eingebaut? Wenn man xmlPages.forEach() langsamer laufen lässt, sollte es eigentlich gehen, habe es jetzt aber auch nicht getestet. Leider gibt es auch keine einzelne XML-Seite, auf der alle Werte auf einmal sind.

              Da ich mit dem async keinen Erfolg hatte, habe ich es auf die schmutzige Tour versucht:

              // Sleep function to delay requests
              function sleep(milliseconds) {
                  const date = Date.now();
                  let currentDate = null;
                  do {
                      currentDate = Date.now();
                  }   while (currentDate - date < milliseconds);
              }
              

              sleep() dann an verschiedenen Stellen innerhalb des request eingefügt. Habs mit Zeiten zwischen 50ms und 1000ms probiert. Allerdings bricht auch hier ab Werten von 500ms die Verbindung zur Helios ab. Nicht mit dem ECONNRESET. Hab den Fehler gerade nicht parat...
              Ein sleep ist nicht besonders elegant, hätte aber den Zweck erfüllen müssen. Im Log sehe ich auch, dass die Anfragen mit der entsprechenden Verzögerung rausgehen - aber trotzdem die ersten 4 requests mit ECONNRESET abbrechen.

              1 Antwort Letzte Antwort
              0
              • H Offline
                H Offline
                hartwigm
                schrieb am zuletzt editiert von
                #54

                Vielen Dank für das Script.

                Ich konnte so alle relevanten Daten auslesen.

                Nun stellt sich aber die Frage nach der Regelung und wäre dankbar für eure Tipps und Erfahrungen.

                Zum System.

                Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                Ebenso würde ich dies mit dem Temperaturen gerne machen.

                Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                Geht das so? Bzw. wie macht ihr das?

                KLVNK 1 Antwort Letzte Antwort
                0
                • H hartwigm

                  Vielen Dank für das Script.

                  Ich konnte so alle relevanten Daten auslesen.

                  Nun stellt sich aber die Frage nach der Regelung und wäre dankbar für eure Tipps und Erfahrungen.

                  Zum System.

                  Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                  Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                  Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                  Ebenso würde ich dies mit dem Temperaturen gerne machen.

                  Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                  Geht das so? Bzw. wie macht ihr das?

                  KLVNK Offline
                  KLVNK Offline
                  KLVN
                  schrieb am zuletzt editiert von KLVN
                  #55

                  @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                  Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                  Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                  Weißt du bzw. hast du diese Werte schon im ioBroker?

                  Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                  Ebenso würde ich dies mit dem Temperaturen gerne machen.

                  Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                  Geht das so? Bzw. wie macht ihr das?

                  Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                  Beispiel-/Pseudo-Code:

                  var sensorsTemps = [];
                  
                  sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                  sensorsTemps[1] = getTemperature("Zimmer 1");
                  // ...
                  
                  sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                  var lowestTemp = Math.min.apply(Math, sensorsTemps);
                  
                  if (lowestTemp < x) {
                    setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                  }
                  
                  

                  und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                  H R 2 Antworten Letzte Antwort
                  0
                  • KLVNK KLVN

                    @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                    Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                    Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                    Weißt du bzw. hast du diese Werte schon im ioBroker?

                    Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                    Ebenso würde ich dies mit dem Temperaturen gerne machen.

                    Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                    Geht das so? Bzw. wie macht ihr das?

                    Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                    Beispiel-/Pseudo-Code:

                    var sensorsTemps = [];
                    
                    sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                    sensorsTemps[1] = getTemperature("Zimmer 1");
                    // ...
                    
                    sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                    var lowestTemp = Math.min.apply(Math, sensorsTemps);
                    
                    if (lowestTemp < x) {
                      setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                    }
                    
                    

                    und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                    H Offline
                    H Offline
                    hartwigm
                    schrieb am zuletzt editiert von
                    #56

                    @klvn Danke

                    Ich hatte hier auch schon ein am Freitag ein Telefonat mit dem Helios Support.

                    Es geht nicht, dass die Werte von externen Sensoren an die Helios übergeben werden kann.
                    Daher habe ich es, wie von dir beschrieben nun realisiert.

                    Meine Logik habe ich dabei aber nicht im iobroker, sondern in Edomi. Die Systeme kommunizieren über mqtt.

                    Dabei ist mir noch ein kleiner Fehler beim schreiben auf die Betriebsart oder Stufe aufgefallen.

                    Wenn ich die Zielwerte per mqtt gesendet hab, sind diese auch unter Objekte eingetragen worden, allerdings nur sehr sporadisch ausgeführt worden. Stabil hat dies sofort funktioniert nachdem ich die Variabenart von gemischt auf Zahl umgestellt habe.

                    Dies scheint aber nur relevant zu sein, wenn der Wert per mqtt gesetzt wird.

                    Vielen Dank für das sehr hilfreiche Script

                    Hartwig

                    1 Antwort Letzte Antwort
                    0
                    • R Offline
                      R Offline
                      Reliktdragon 0
                      schrieb am zuletzt editiert von Reliktdragon 0
                      #57

                      Hallo.

                      Danke für dieses tolle Script.
                      Ich hätte da aber noch eine frage.

                      Das Skript funktioniert bei mir, ich kan die Helios auch steuern.

                      Nur im Log kommen diese ganzen fehler wenn das Skript läuft:

                      E0C05D03-9B4C-49A3-9A6A-C48866AA069A.png

                      Ist das normal oder habe ich was vergessen zu ändern?

                      Edit: Hab das Script auf einer neuen Javascript Instanz laufen lassen, jetzt funktioniert es plötzlich.

                      Grüße

                      1 Antwort Letzte Antwort
                      0
                      • KLVNK KLVN

                        @elmocito sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                        Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

                        Moin, mit Homebridge hatte und habe ich überhaupt keinen Kontakt, sorry.

                        Und danke für den Stern bei GitHub ;)

                        K Offline
                        K Offline
                        knudos
                        schrieb am zuletzt editiert von
                        #58

                        @klvn Gibt es eine Möglichkeit die Helios KWL in Hoobs einzubinden?

                        1 Antwort Letzte Antwort
                        0
                        • KLVNK KLVN

                          @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                          Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                          Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                          Weißt du bzw. hast du diese Werte schon im ioBroker?

                          Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                          Ebenso würde ich dies mit dem Temperaturen gerne machen.

                          Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                          Geht das so? Bzw. wie macht ihr das?

                          Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                          Beispiel-/Pseudo-Code:

                          var sensorsTemps = [];
                          
                          sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                          sensorsTemps[1] = getTemperature("Zimmer 1");
                          // ...
                          
                          sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                          var lowestTemp = Math.min.apply(Math, sensorsTemps);
                          
                          if (lowestTemp < x) {
                            setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                          }
                          
                          

                          und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                          R Offline
                          R Offline
                          Ritschy2000
                          schrieb am zuletzt editiert von
                          #59

                          @klvn kannst du mir noch einen Tip geben, wie ich:

                          Bypass Raum/Temp. = v01035 (aus der gaer.htm) beschreiben und auslesen kann?

                          Darüber lässt sich relativ simple der Bypass "steuern".

                          Habe bei deinem Script schon verschiede Dinge hinzugefügt, aber irgendwie
                          funktioniert es bei der Funktion nicht, ich bekomme den Wert nicht mal ausgelesen.
                          Liegt es eventuell daran, dass der Wert in einem Untermenü steckt?
                          Aber du setzt ja über dein Script auch den Filterwechsel zurück, welcher sich auf der gleichen
                          Seite befindet.

                          Bin für jede Hilfe dankbar.

                          KLVNK 1 Antwort Letzte Antwort
                          0
                          • R Ritschy2000

                            @klvn kannst du mir noch einen Tip geben, wie ich:

                            Bypass Raum/Temp. = v01035 (aus der gaer.htm) beschreiben und auslesen kann?

                            Darüber lässt sich relativ simple der Bypass "steuern".

                            Habe bei deinem Script schon verschiede Dinge hinzugefügt, aber irgendwie
                            funktioniert es bei der Funktion nicht, ich bekomme den Wert nicht mal ausgelesen.
                            Liegt es eventuell daran, dass der Wert in einem Untermenü steckt?
                            Aber du setzt ja über dein Script auch den Filterwechsel zurück, welcher sich auf der gleichen
                            Seite befindet.

                            Bin für jede Hilfe dankbar.

                            KLVNK Offline
                            KLVNK Offline
                            KLVN
                            schrieb am zuletzt editiert von
                            #60

                            @ritschy2000 Moin, weil das Register v01035 aus der Datei werte12.xml ausgelesen wird (siehe Bild), musst du in dieser Zeile noch eine 12 ins Array hinzufügen, damit auch diese Seite abgefragt wird.

                            0761914e-982c-42db-99bd-9f87d8b177b1-image.png

                            Und oben bei const datapoint_names brauchst du dann noch ein "v01035": "Temperatur_Bypass". So konnte ich schon den Wert auslesen; eine neue Temperatur setzen habe ich nicht ausprobiert, sollte aber mit setValues("gaer", "v01035=xx); funktionieren.

                            1 Antwort Letzte Antwort
                            0
                            • TimmerxT Offline
                              TimmerxT Offline
                              Timmerx
                              schrieb am zuletzt editiert von Timmerx
                              #61

                              Hallo Leute,

                              das Skript ist wirklich super, damit kann ich meine Siemens S7 extrem entlasten.

                              Kleines Manko ist, dass ich es nicht schaffe den Filterwechsel zurück zustellen.
                              Ich hätte in meiner VIS gerne einen Button, um die Resttage zurück zusetzten.

                              Hier das Skript inkl. Resttageabfrage, Bypass öffnen/Schließen, Interne Feuchte.

                              /*
                              ioBroker-Helios-KWL
                              IMPORTANT: This script requires at least Node.js v12.x!
                              https://github.com/KLVN/ioBroker_Helios-KWL
                              */
                              
                              // SETTINGS ////////////////////////////////////////////////////////////////
                              
                              const helios_ip = "192.168.178.20";    // IP of Helios KWL
                              const helios_password = "12345678";     // Password of Helios KWL (default)
                              const datapoint_prefix = "HeliosKWL";   // Prefix for datapoints, e.g. HeliosKWL.Temperatur_Zuluft
                              const refresh_interval = 10;            // Refresh every x seconds
                              
                              const datapoint_names = {
                                "w00090": "Partybetrieb_SOLL",        // on/off;duration;speed
                                "v00101": "Betriebsart_IST",          // Operating mode (manual = 1, automatic = 0)
                                "w00101": "Betriebsart_SOLL",         // Custom variable for operating mode (manual = 1, automatic = 0)
                                "v00102": "Luefterstufe_IST",         // Fan speed
                                "w00102": "Luefterstufe_SOLL",        // Custom variable for fan speed
                                "v00104": "Temperatur_Aussenluft",    // Temperature outdoor air sensor
                                "v00105": "Temperatur_Zuluft",        // Temperature supply air sensor
                                "v00106": "Temperatur_Fortluft",      // Temperature exhaust air sensor
                                "v00107": "Temperatur_Abluft",         // Temperature extract air sensor
                                "v01033": "Restlaufzeit in Tagen",             // FILTERWECHSEL
                                "v01035": "Temperatur_Bypass_Raum-Ablufttemperatur",
                                "v01036": "Temperatur_Bypass_Min_Außenlufttemperatur",
                                "v00348": "Drehzahl Zuluft (rpm)",
                                "v00349": "Abluftzahl Zuluft (rpm)",
                                "v01103": "ZuluftVENTI_Gesamt_h",
                                "v01104": "AbluftVENTI_Gesamt_h",
                                "v02136": "Feuchte",
                                "v02119": "Bypass_AUF/ZU"            // 0= ZU    1= AUF
                                // "Register": "Name for the datapoint" (I'm using "vxxxxx" for actual registers and "wxxxxx" for custom datapoints)
                              }
                              
                              ////////////////////////////////////////////////////////////////////////////
                              
                              // Not necessary; already defined in ioBroker
                              // var request= require('request');
                              
                              // Returns a matching header for login and XML-files
                              function createHeader(ip, url, body) {
                                var header = {
                                  headers: {
                                    "Accept": "*/*",
                                    "Accept-Encoding": "gzip, deflate",
                                    "Accept-Language": "de,en-US;q=0.7,en;q=0.3",
                                    "Connection": "keep-alive",
                                    "Content-Length": "15",
                                    "Content-Type": "text/plain;charset=UTF-8",
                                    "DNT": "1",
                                    "Referer": "http://" + ip + "/",
                                    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.193 Safari/537.36",
                                    "Host": ip
                                  },
                                  url: "http://" + ip + "/" + url,
                                  body: body,
                                  method: "POST"
                                }
                                return header
                              }
                              
                              // Create states from parameter names
                              for (let param in datapoint_names) {
                                // Different defaults for different datapoints
                                if (param == "w00090") {
                                  createState(datapoint_prefix + "." + datapoint_names[param], "0;10;4");
                                } else if (param == "w00101") {
                                  createState(datapoint_prefix + "." + datapoint_names[param], 0);
                                } else {
                                  // No default given
                                  createState(datapoint_prefix + "." + datapoint_names[param]);
                                }
                              }
                              
                              // Login every 5 minutes
                              setInterval(function () {
                                request(createHeader(helios_ip, "info.htm", "v00402=" + helios_password));
                              }, 300000);
                              
                              // Refresh values
                              setInterval(function () {
                                // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
                                const xmlPages = [4, 8, 11, 12];
                                xmlPages.forEach(function (page, index) {
                                  request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                                    refreshValues(result);
                                  });
                                });
                              }, refresh_interval * 1000);
                              
                              // Read XML response, extract IDs and values, refresh states with new values
                              function refreshValues(xml) {
                                const regex = /<ID>(?<ID>v\d{5})<\/ID>\s*?<VA>(?<VALUE>.*?)<\/VA>/gm;
                                var elements = xml.matchAll(regex);
                              
                                for (let element of elements) {
                                  let { ID, VALUE } = element.groups;
                                  let NAME = datapoint_names[ID];
                              
                                  // Only refresh values that we have names for
                                  if (NAME != undefined) {
                                    setState(datapoint_prefix + "." + NAME, VALUE);
                                  }
                                }
                              }
                              
                              // Takes an URL-path and multiple registers with values to set values and change settings
                              function setValues(path, values) {
                                var args = arguments;
                                var arrayValues = [];
                                for (var i = 1; i < args.length; i++) {
                                  arrayValues.push(args[i]);
                                }
                                request(createHeader(helios_ip, path + ".htm", arrayValues.join("&")));
                              }
                              
                              // Set fan speed
                              function setFanSpeed(speed) {
                                // Check if wanted fan speed is a reasonable value
                                if ([0, 1, 2, 3, 4].indexOf(speed) >= 0) {
                                  setValues("info", "v00102=" + speed);
                                } else {
                                  setFanSpeed(0);
                                }
                              }
                              // If specified fan speed was changed, then set fan speed accordingly
                              on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00102"], change: "any" }, async function (obj) {
                                var value = obj.state.val;
                                setFanSpeed(value);
                              });
                              
                              // Set party mode using following scheme:
                              // onOff;duration;speed, e.g.
                              // "1;10;4" = turn on party mode for 10 minutes and set fan speed to 4
                              // "2;10;4" = invalid
                              // "0;10;4" = turn off party mode
                              function setPartyMode(onOff, duration, speed) {
                                // Only allow reasonable values
                                if (([0, 1].indexOf(onOff) >= 0) && (duration > 0) && (duration <= 180) && ([0, 1, 2, 3, 4].indexOf(speed) >= 0)) {
                                  setValues("party", "v00094=" + onOff, "v00091=" + duration, "v00092=" + speed);
                                }
                              }
                              // If specified party mode was changed, then mode accordingly
                              on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00090"], change: "any" }, async function (obj) {
                                var value = obj.state.val;
                                var values = value.split(";");
                                setPartyMode(parseInt(values[0], 10), parseInt(values[1], 10), parseInt(values[2], 10));
                              });
                              
                              // Set operating mode
                              function setOperatingMode(onOff) {
                                // Only allow reasonable values
                                if ([0, 1].indexOf(onOff) >= 0) {
                                  setValues("info", "v00101=" + onOff);
                                }
                              }
                              // If specified party mode was changed, then mode accordingly
                              on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00101"], change: "any" }, async function (obj) {
                                var value = obj.state.val;
                                setOperatingMode(value);
                              });
                              
                              
                              
                              
                              createState("setBypass_AUF", function () {
                              });
                              on({id: 's7.0.Markers.1014.Helios_Sommerbypass', val: true}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                setValues("gear", "v01036=20");
                              
                              });
                              
                              createState("setBypass_ZU", function () {
                              });
                              on({id: 's7.0.Markers.1014.Helios_Sommerbypass', val: false}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                setValues("gear", "v01036=30");
                              
                              });
                              
                              
                              
                              // ADDITIONAL SCRIPTS (see github.com/KLVN/ioBroker_Helios-KWL) ////////////
                              
                              // ...insert additional scripts here
                              
                              KLVNK 1 Antwort Letzte Antwort
                              0
                              • TimmerxT Timmerx

                                Hallo Leute,

                                das Skript ist wirklich super, damit kann ich meine Siemens S7 extrem entlasten.

                                Kleines Manko ist, dass ich es nicht schaffe den Filterwechsel zurück zustellen.
                                Ich hätte in meiner VIS gerne einen Button, um die Resttage zurück zusetzten.

                                Hier das Skript inkl. Resttageabfrage, Bypass öffnen/Schließen, Interne Feuchte.

                                /*
                                ioBroker-Helios-KWL
                                IMPORTANT: This script requires at least Node.js v12.x!
                                https://github.com/KLVN/ioBroker_Helios-KWL
                                */
                                
                                // SETTINGS ////////////////////////////////////////////////////////////////
                                
                                const helios_ip = "192.168.178.20";    // IP of Helios KWL
                                const helios_password = "12345678";     // Password of Helios KWL (default)
                                const datapoint_prefix = "HeliosKWL";   // Prefix for datapoints, e.g. HeliosKWL.Temperatur_Zuluft
                                const refresh_interval = 10;            // Refresh every x seconds
                                
                                const datapoint_names = {
                                  "w00090": "Partybetrieb_SOLL",        // on/off;duration;speed
                                  "v00101": "Betriebsart_IST",          // Operating mode (manual = 1, automatic = 0)
                                  "w00101": "Betriebsart_SOLL",         // Custom variable for operating mode (manual = 1, automatic = 0)
                                  "v00102": "Luefterstufe_IST",         // Fan speed
                                  "w00102": "Luefterstufe_SOLL",        // Custom variable for fan speed
                                  "v00104": "Temperatur_Aussenluft",    // Temperature outdoor air sensor
                                  "v00105": "Temperatur_Zuluft",        // Temperature supply air sensor
                                  "v00106": "Temperatur_Fortluft",      // Temperature exhaust air sensor
                                  "v00107": "Temperatur_Abluft",         // Temperature extract air sensor
                                  "v01033": "Restlaufzeit in Tagen",             // FILTERWECHSEL
                                  "v01035": "Temperatur_Bypass_Raum-Ablufttemperatur",
                                  "v01036": "Temperatur_Bypass_Min_Außenlufttemperatur",
                                  "v00348": "Drehzahl Zuluft (rpm)",
                                  "v00349": "Abluftzahl Zuluft (rpm)",
                                  "v01103": "ZuluftVENTI_Gesamt_h",
                                  "v01104": "AbluftVENTI_Gesamt_h",
                                  "v02136": "Feuchte",
                                  "v02119": "Bypass_AUF/ZU"            // 0= ZU    1= AUF
                                  // "Register": "Name for the datapoint" (I'm using "vxxxxx" for actual registers and "wxxxxx" for custom datapoints)
                                }
                                
                                ////////////////////////////////////////////////////////////////////////////
                                
                                // Not necessary; already defined in ioBroker
                                // var request= require('request');
                                
                                // Returns a matching header for login and XML-files
                                function createHeader(ip, url, body) {
                                  var header = {
                                    headers: {
                                      "Accept": "*/*",
                                      "Accept-Encoding": "gzip, deflate",
                                      "Accept-Language": "de,en-US;q=0.7,en;q=0.3",
                                      "Connection": "keep-alive",
                                      "Content-Length": "15",
                                      "Content-Type": "text/plain;charset=UTF-8",
                                      "DNT": "1",
                                      "Referer": "http://" + ip + "/",
                                      "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.193 Safari/537.36",
                                      "Host": ip
                                    },
                                    url: "http://" + ip + "/" + url,
                                    body: body,
                                    method: "POST"
                                  }
                                  return header
                                }
                                
                                // Create states from parameter names
                                for (let param in datapoint_names) {
                                  // Different defaults for different datapoints
                                  if (param == "w00090") {
                                    createState(datapoint_prefix + "." + datapoint_names[param], "0;10;4");
                                  } else if (param == "w00101") {
                                    createState(datapoint_prefix + "." + datapoint_names[param], 0);
                                  } else {
                                    // No default given
                                    createState(datapoint_prefix + "." + datapoint_names[param]);
                                  }
                                }
                                
                                // Login every 5 minutes
                                setInterval(function () {
                                  request(createHeader(helios_ip, "info.htm", "v00402=" + helios_password));
                                }, 300000);
                                
                                // Refresh values
                                setInterval(function () {
                                  // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
                                  const xmlPages = [4, 8, 11, 12];
                                  xmlPages.forEach(function (page, index) {
                                    request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                                      refreshValues(result);
                                    });
                                  });
                                }, refresh_interval * 1000);
                                
                                // Read XML response, extract IDs and values, refresh states with new values
                                function refreshValues(xml) {
                                  const regex = /<ID>(?<ID>v\d{5})<\/ID>\s*?<VA>(?<VALUE>.*?)<\/VA>/gm;
                                  var elements = xml.matchAll(regex);
                                
                                  for (let element of elements) {
                                    let { ID, VALUE } = element.groups;
                                    let NAME = datapoint_names[ID];
                                
                                    // Only refresh values that we have names for
                                    if (NAME != undefined) {
                                      setState(datapoint_prefix + "." + NAME, VALUE);
                                    }
                                  }
                                }
                                
                                // Takes an URL-path and multiple registers with values to set values and change settings
                                function setValues(path, values) {
                                  var args = arguments;
                                  var arrayValues = [];
                                  for (var i = 1; i < args.length; i++) {
                                    arrayValues.push(args[i]);
                                  }
                                  request(createHeader(helios_ip, path + ".htm", arrayValues.join("&")));
                                }
                                
                                // Set fan speed
                                function setFanSpeed(speed) {
                                  // Check if wanted fan speed is a reasonable value
                                  if ([0, 1, 2, 3, 4].indexOf(speed) >= 0) {
                                    setValues("info", "v00102=" + speed);
                                  } else {
                                    setFanSpeed(0);
                                  }
                                }
                                // If specified fan speed was changed, then set fan speed accordingly
                                on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00102"], change: "any" }, async function (obj) {
                                  var value = obj.state.val;
                                  setFanSpeed(value);
                                });
                                
                                // Set party mode using following scheme:
                                // onOff;duration;speed, e.g.
                                // "1;10;4" = turn on party mode for 10 minutes and set fan speed to 4
                                // "2;10;4" = invalid
                                // "0;10;4" = turn off party mode
                                function setPartyMode(onOff, duration, speed) {
                                  // Only allow reasonable values
                                  if (([0, 1].indexOf(onOff) >= 0) && (duration > 0) && (duration <= 180) && ([0, 1, 2, 3, 4].indexOf(speed) >= 0)) {
                                    setValues("party", "v00094=" + onOff, "v00091=" + duration, "v00092=" + speed);
                                  }
                                }
                                // If specified party mode was changed, then mode accordingly
                                on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00090"], change: "any" }, async function (obj) {
                                  var value = obj.state.val;
                                  var values = value.split(";");
                                  setPartyMode(parseInt(values[0], 10), parseInt(values[1], 10), parseInt(values[2], 10));
                                });
                                
                                // Set operating mode
                                function setOperatingMode(onOff) {
                                  // Only allow reasonable values
                                  if ([0, 1].indexOf(onOff) >= 0) {
                                    setValues("info", "v00101=" + onOff);
                                  }
                                }
                                // If specified party mode was changed, then mode accordingly
                                on({ id: "javascript.0." + datapoint_prefix + "." + datapoint_names["w00101"], change: "any" }, async function (obj) {
                                  var value = obj.state.val;
                                  setOperatingMode(value);
                                });
                                
                                
                                
                                
                                createState("setBypass_AUF", function () {
                                });
                                on({id: 's7.0.Markers.1014.Helios_Sommerbypass', val: true}, function (obj) {
                                  var value = obj.state.val;
                                  var oldValue = obj.oldState.val;
                                  setValues("gear", "v01036=20");
                                
                                });
                                
                                createState("setBypass_ZU", function () {
                                });
                                on({id: 's7.0.Markers.1014.Helios_Sommerbypass', val: false}, function (obj) {
                                  var value = obj.state.val;
                                  var oldValue = obj.oldState.val;
                                  setValues("gear", "v01036=30");
                                
                                });
                                
                                
                                
                                // ADDITIONAL SCRIPTS (see github.com/KLVN/ioBroker_Helios-KWL) ////////////
                                
                                // ...insert additional scripts here
                                
                                KLVNK Offline
                                KLVNK Offline
                                KLVN
                                schrieb am zuletzt editiert von
                                #62

                                @timmerx sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                Hallo Leute,

                                das Skript ist wirklich super, damit kann ich meine Siemens S7 extrem entlasten.

                                Freut mich, dass es funktioniert und du es auch gleich noch erweitert hast :)

                                Kleines Manko ist, dass ich es nicht schaffe den Filterwechsel zurück zustellen.
                                Ich hätte in meiner VIS gerne einen Button, um die Resttage zurück zusetzten.

                                Funktioniert das Code-Stück von GitHub nicht? Da brauchst du nicht mal einen Button, sondern es wird automatisch immer zurückgesetzt. Ich habe jetzt seit fast einem Jahr meine Helios nicht mehr angefasst (den Filter sollte ich aber wohl wirklich mal wechseln :sweat_smile: )

                                // Reset change interval of filter every month
                                schedule("0 5 1 * *", function () {
                                  setValues("gear", "v01034=1");
                                });
                                

                                Das Register zum Zurücksetzen findest du im Quellcode vom "Restlaufzeit neu starten"-Button. Vielleicht ist das bei dir anders (?)
                                63baecdf-ad80-4b3a-917d-4af0c168071b-image.png

                                VIS benutze ich nicht allzu sehr, deshalb fällt mir da jetzt nur diese dreckige Lösung ein:

                                • neuer Datenpunkt (Bool, false), z.B. resetHelios
                                • In VIS dann einen Button, der diesen Datenpunkt auf true setzen kann
                                • In deinem Skript dann auf eine Veränderungen von resetHelios warten, dann den Code zum resetten ausführen und danach den Datenpunkt wieder auf false setzen
                                T 1 Antwort Letzte Antwort
                                0
                                • KLVNK KLVN

                                  @timmerx sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                  Hallo Leute,

                                  das Skript ist wirklich super, damit kann ich meine Siemens S7 extrem entlasten.

                                  Freut mich, dass es funktioniert und du es auch gleich noch erweitert hast :)

                                  Kleines Manko ist, dass ich es nicht schaffe den Filterwechsel zurück zustellen.
                                  Ich hätte in meiner VIS gerne einen Button, um die Resttage zurück zusetzten.

                                  Funktioniert das Code-Stück von GitHub nicht? Da brauchst du nicht mal einen Button, sondern es wird automatisch immer zurückgesetzt. Ich habe jetzt seit fast einem Jahr meine Helios nicht mehr angefasst (den Filter sollte ich aber wohl wirklich mal wechseln :sweat_smile: )

                                  // Reset change interval of filter every month
                                  schedule("0 5 1 * *", function () {
                                    setValues("gear", "v01034=1");
                                  });
                                  

                                  Das Register zum Zurücksetzen findest du im Quellcode vom "Restlaufzeit neu starten"-Button. Vielleicht ist das bei dir anders (?)
                                  63baecdf-ad80-4b3a-917d-4af0c168071b-image.png

                                  VIS benutze ich nicht allzu sehr, deshalb fällt mir da jetzt nur diese dreckige Lösung ein:

                                  • neuer Datenpunkt (Bool, false), z.B. resetHelios
                                  • In VIS dann einen Button, der diesen Datenpunkt auf true setzen kann
                                  • In deinem Skript dann auf eine Veränderungen von resetHelios warten, dann den Code zum resetten ausführen und danach den Datenpunkt wieder auf false setzen
                                  T Offline
                                  T Offline
                                  tombox
                                  schrieb am zuletzt editiert von
                                  #63

                                  @klvn Würde es nicht sinn machen ein Adapter aus dem Script zu machen?

                                  1 Antwort Letzte Antwort
                                  0
                                  • TimmerxT Offline
                                    TimmerxT Offline
                                    Timmerx
                                    schrieb am zuletzt editiert von Timmerx
                                    #64

                                    Hi,

                                    das Github Codestück // Reset change interval of filter every month schedule("0 5 1 * *", function () { setValues("gear", "v01034=1"); });

                                    habe ich so nicht getestet, sonderen
                                    schedule("0 5 1 * *", ..... direkt versucht mit einem Butten zu ersetzen.

                                    Eine monatliche zurücksetzen halte ich nicht für sinnvoll, da ich die Filter wechseln will (schon weil die Anlage mit der Zeit immer lauter wird mit alten / vollen Filtern)

                                    Und weil ich auch nicht mehr auf die Helios Weboberfläche will, wäre ein solcher Button wirklich toll

                                    Ich werde mich heute vormittag nochmal hinsetzen und bissel rum probieren.

                                    Grüße

                                    1 Antwort Letzte Antwort
                                    0
                                    • TimmerxT Offline
                                      TimmerxT Offline
                                      Timmerx
                                      schrieb am zuletzt editiert von
                                      #65

                                      So ich habe in der Vis einen Button ( 1 / 0 ) erstellt, diesen habe ich mit der Variablen javascript.0.RESET_RESTTAGE_HELIOS verknüpft und das Skript wie folgt angepasst.

                                      // Resttage reset
                                      createState("RESET_RESTTAGE_HELIOS", function () {
                                      });
                                      on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                        var value = obj.state.val;
                                        var oldValue = obj.oldState.val;
                                        setValues("gear", "v01034=1");
                                        console.log('Reset ausgeführt');
                                      
                                      });
                                      var Resttage_Skript;
                                      // Resttage Filterwechsel
                                      on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                        var value = obj.state.val;
                                        var oldValue = obj.oldState.val;
                                        Resttage_Skript = setTimeout(function () {
                                          setState("javascript.0.RESET_RESTTAGE_HELIOS", 0);
                                        }, 15000);
                                      });
                                      (function () {if (Resttage_Skript) {clearTimeout(Resttage_Skript); Resttage_Skript = null;}})();
                                      
                                      //Resttage umrechnen
                                      createState("Restfiltertage_berechnet", function () {
                                      });
                                      on({id: 'javascript.0.HeliosKWL.Restlaufzeit in Tagen', change: "ne"}, function (obj) {
                                        var value = obj.state.val;
                                        var oldValue = obj.oldState.val;
                                        setState("javascript.0.Restfiltertage_berechnet", (Math.round(getState("javascript.0.HeliosKWL.Restlaufzeit in Tagen").val / 1443.1)));
                                        console.log((['Lüftungsanlage: Filterwechsel in ',getState("javascript.0.Restfiltertage_berechnet").val,' Tagen!'].join('')));
                                      });
                                      

                                      Im Skript wird jetzt der Button nach 15 Sekunden wieder auf 0 zurückgesetzt.

                                      Zusätzlich werden die Resttage in eine lesbare Zahl (ohne Komma) umgerechnet.

                                      Das zurücksetzten der Resttage hat leider nur einmal funktioniert.....

                                      KLVNK 1 Antwort Letzte Antwort
                                      0
                                      • TimmerxT Timmerx

                                        So ich habe in der Vis einen Button ( 1 / 0 ) erstellt, diesen habe ich mit der Variablen javascript.0.RESET_RESTTAGE_HELIOS verknüpft und das Skript wie folgt angepasst.

                                        // Resttage reset
                                        createState("RESET_RESTTAGE_HELIOS", function () {
                                        });
                                        on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                          var value = obj.state.val;
                                          var oldValue = obj.oldState.val;
                                          setValues("gear", "v01034=1");
                                          console.log('Reset ausgeführt');
                                        
                                        });
                                        var Resttage_Skript;
                                        // Resttage Filterwechsel
                                        on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                          var value = obj.state.val;
                                          var oldValue = obj.oldState.val;
                                          Resttage_Skript = setTimeout(function () {
                                            setState("javascript.0.RESET_RESTTAGE_HELIOS", 0);
                                          }, 15000);
                                        });
                                        (function () {if (Resttage_Skript) {clearTimeout(Resttage_Skript); Resttage_Skript = null;}})();
                                        
                                        //Resttage umrechnen
                                        createState("Restfiltertage_berechnet", function () {
                                        });
                                        on({id: 'javascript.0.HeliosKWL.Restlaufzeit in Tagen', change: "ne"}, function (obj) {
                                          var value = obj.state.val;
                                          var oldValue = obj.oldState.val;
                                          setState("javascript.0.Restfiltertage_berechnet", (Math.round(getState("javascript.0.HeliosKWL.Restlaufzeit in Tagen").val / 1443.1)));
                                          console.log((['Lüftungsanlage: Filterwechsel in ',getState("javascript.0.Restfiltertage_berechnet").val,' Tagen!'].join('')));
                                        });
                                        

                                        Im Skript wird jetzt der Button nach 15 Sekunden wieder auf 0 zurückgesetzt.

                                        Zusätzlich werden die Resttage in eine lesbare Zahl (ohne Komma) umgerechnet.

                                        Das zurücksetzten der Resttage hat leider nur einmal funktioniert.....

                                        KLVNK Offline
                                        KLVNK Offline
                                        KLVN
                                        schrieb am zuletzt editiert von
                                        #66

                                        @tombox sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                        @klvn Würde es nicht sinn machen ein Adapter aus dem Script zu machen?

                                        Könnte man machen, aber ich habe mich bewusst dagegen entschieden, weil ich kein Fan von aufgeblasenen Adaptern bin, wenn sich alles mit nur ca. 140 Codezeilen im Skript-Adapter erledigen lässt. Hinzu kommt noch, dass es sowieso nur wenige Helios-Benutzer gibt und diese können wiederum auch nur mit diesem Skript arbeiten und sind zufrieden (wie der Thread zeigt). Und auch gerade diese eigenen Anpassungen, wie jetzt z.B. der Button von Timmerx oder meine Zusatzfunktionen (Zeitpläne, die nur laufen, wenn auch jemand Zuhause ist oder dass mein Bad abgesaugt wird, wenn die Dusche läuft) sind in Adaptern einfach nicht möglich (ohne viel Aufwand), sodass man sowieso auf den Skript-Adapter setzen muss.

                                        Ein Adapter sieht schicker aus, aber ich habe das Skript schon so einfach wie möglich gehalten, sodass man eigentlich nur Copy & Paste, die IP-Adresse eintragen und das Skript starten muss.


                                        @timmerx sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                        Das zurücksetzten der Resttage hat leider nur einmal funktioniert.....

                                        Probiere es in 24h nochmal, dann ist auch wieder ein Tag vergangen, den du zurücksetzen kannst.
                                        Statt dem setTimeout würde ich ein setStateDelayed nehmen, so spart man sich etwas Code.

                                        // Resttage reset
                                        createState("RESET_RESTTAGE_HELIOS", function () {
                                        });
                                        on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                          var value = obj.state.val;
                                          var oldValue = obj.oldState.val;
                                        
                                          // Falls auf 0 gesetzt wurde, breche ab. Wenn 1, dann mache Reset
                                          if(!value) return;
                                        
                                          setValues("gear", "v01034=1");
                                          console.log('Reset ausgeführt');
                                        
                                          // Setze in 15 Sekunden zurück auf 0
                                          setStateDelayed("javascript.0.RESET_RESTTAGE_HELIOS", 0, 15000);
                                        });
                                        

                                        Ist ungetestet, weil ich das jetzt nur im Browser geschrieben habe. Bei dem if bin ich mir nicht sicher, ob man das überhaupt braucht, die Idee dahinter war aber:

                                        • Das on reagiert auf jede Veränderung
                                        • Du drückst den Button, der Wert wird zu 1 -> Änderung
                                        • Das on wird jetzt ausgeführt
                                        • 15 Sekunden später wird wieder auf 0 gesetzt -> Änderung
                                        • ...der Kreislauf geht los, weil es sich immer wieder selbst triggert (?)

                                        Mit dem if testet man jetzt, ob der Wert 0 ist, denn dann wurde ja gerade zurückgesetzt und wir wollen es nicht nochmal machen.

                                        Man könnte auch ein on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "gt"}, function (obj) {}) nehmen (change: "gt"), dann wird nur ausgelöst, wenn man von 0 auf 1 gegangen ist, also den Button gedrückt hat.

                                        T 2 Antworten Letzte Antwort
                                        0
                                        • KLVNK KLVN

                                          @tombox sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                          @klvn Würde es nicht sinn machen ein Adapter aus dem Script zu machen?

                                          Könnte man machen, aber ich habe mich bewusst dagegen entschieden, weil ich kein Fan von aufgeblasenen Adaptern bin, wenn sich alles mit nur ca. 140 Codezeilen im Skript-Adapter erledigen lässt. Hinzu kommt noch, dass es sowieso nur wenige Helios-Benutzer gibt und diese können wiederum auch nur mit diesem Skript arbeiten und sind zufrieden (wie der Thread zeigt). Und auch gerade diese eigenen Anpassungen, wie jetzt z.B. der Button von Timmerx oder meine Zusatzfunktionen (Zeitpläne, die nur laufen, wenn auch jemand Zuhause ist oder dass mein Bad abgesaugt wird, wenn die Dusche läuft) sind in Adaptern einfach nicht möglich (ohne viel Aufwand), sodass man sowieso auf den Skript-Adapter setzen muss.

                                          Ein Adapter sieht schicker aus, aber ich habe das Skript schon so einfach wie möglich gehalten, sodass man eigentlich nur Copy & Paste, die IP-Adresse eintragen und das Skript starten muss.


                                          @timmerx sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                          Das zurücksetzten der Resttage hat leider nur einmal funktioniert.....

                                          Probiere es in 24h nochmal, dann ist auch wieder ein Tag vergangen, den du zurücksetzen kannst.
                                          Statt dem setTimeout würde ich ein setStateDelayed nehmen, so spart man sich etwas Code.

                                          // Resttage reset
                                          createState("RESET_RESTTAGE_HELIOS", function () {
                                          });
                                          on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "ne"}, function (obj) {
                                            var value = obj.state.val;
                                            var oldValue = obj.oldState.val;
                                          
                                            // Falls auf 0 gesetzt wurde, breche ab. Wenn 1, dann mache Reset
                                            if(!value) return;
                                          
                                            setValues("gear", "v01034=1");
                                            console.log('Reset ausgeführt');
                                          
                                            // Setze in 15 Sekunden zurück auf 0
                                            setStateDelayed("javascript.0.RESET_RESTTAGE_HELIOS", 0, 15000);
                                          });
                                          

                                          Ist ungetestet, weil ich das jetzt nur im Browser geschrieben habe. Bei dem if bin ich mir nicht sicher, ob man das überhaupt braucht, die Idee dahinter war aber:

                                          • Das on reagiert auf jede Veränderung
                                          • Du drückst den Button, der Wert wird zu 1 -> Änderung
                                          • Das on wird jetzt ausgeführt
                                          • 15 Sekunden später wird wieder auf 0 gesetzt -> Änderung
                                          • ...der Kreislauf geht los, weil es sich immer wieder selbst triggert (?)

                                          Mit dem if testet man jetzt, ob der Wert 0 ist, denn dann wurde ja gerade zurückgesetzt und wir wollen es nicht nochmal machen.

                                          Man könnte auch ein on({id: 'javascript.0.RESET_RESTTAGE_HELIOS', change: "gt"}, function (obj) {}) nehmen (change: "gt"), dann wird nur ausgelöst, wenn man von 0 auf 1 gegangen ist, also den Button gedrückt hat.

                                          T Offline
                                          T Offline
                                          tombox
                                          schrieb am zuletzt editiert von
                                          #67

                                          @klvn Ich denke mal ein Adapter hat keine 140 zeilen. Es ist auch leichter nutzbar als das aktuelle Skript in einem thread zu finden. Ich kann ja mal schnell einen erstellen und du kannst entscheiden wo du weiter dran arbeiten willst.

                                          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

                                          623

                                          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