Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Praktische Anwendungen (Showcase)
    4. [Javascript] Midas (Aquatemp) Poolheizung

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Javascript] Midas (Aquatemp) Poolheizung

    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      dering @oxident last edited by

      @oxident Also meine Anpassungen haben leider nichts gebracht.
      Morgens um 10 Uhr wird die LWP eingeschaltet (mode: 2) und abends um 20 Uhr ausgeschaltet (mode: -1).

      Mir kommt es so vor, das genau zur vollen Stunde das Token zurückgesetzt wird und somit nicht mehr gültig ist.

      Folgendes sehe ich um 20 Uhr in der Log:

      2022-06-02 20:00:00.071  - info: javascript.0 (462) script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: updateDevicePower: token ist leer
      2022-06-02 20:00:00.074  - info: javascript.0 (462) script.js.Poolsteuerung.Luftwaermepumpe_Automatische_Steuerung: telegram: Luftwaermepumpe wurde auf Off eingestellt.
      2022-06-02 20:00:00.097  - info: javascript.0 (462) script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: updateDeviceStatus: token ist leer
      

      Vielleicht sollten wir das Skript so schreiben, dass es auto. ein neues Token generiert, wenn es leer ist, und dann einfach in der Funktion weiter macht?

      O 1 Reply Last reply Reply Quote 0
      • O
        oxident @dering last edited by

        @dering Sehr mysteriös. Gegenvorschlag: Der Token wird ja alle 60min vom Skript automatisch gelöscht. Vielleicht probieren wir's mal so, dass genau danach der Token direkt neu generiert wird.

        Könntest Du mal den "60min"-Block recht weit unten im Skript wie folgt ändern?

        schedule('*/60 * * * *', function () {
            // Token verfällt nach 60min
            token = "";
            updateToken();
        });
        
        D 2 Replies Last reply Reply Quote 0
        • D
          dering @oxident last edited by

          @oxident Alles klar, versuchen wir es mal so. Ich habe die Änderung jetzt eingebaut. Morgen um 14 Uhr werden wir sehen, obs geholfen hat. Ich werde berichten.
          Ich hätte Interesse einen Adapter dafür zu schreiben, jedoch habe ich null Ahnung. Ich kenne auch keine Seite die das Grundprinzip erklärt.

          1 Reply Last reply Reply Quote 0
          • D
            dering @oxident last edited by

            @oxident Hat auch nicht geholfen. Ich habe die Vermutung, dass es daran liegt, dass genau in dem Moment, wenn das Token gelöscht und erneut wird, auch der Modus verändert wird und dann auf ein leeres Token stößt.

            javascript.0
            2022-06-08 14:00:00.237	info	script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: Login ok! Token ...
            javascript.0
            2022-06-08 14:00:00.237	info	script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: updateToken: {"statusCode":200,"body":{"error_code":"0","error_msg":"Success","error_msg_code":"","object_result":{"role_name":"User","user_type":"Customer","user_id":"...","user_name":".....de","nick_name":"...","roleName":"User","x-token":"...","real_name":null},"is_reuslt_suc":true},"headers":{"date":"Wed, 08 Jun 2022 12:00:00 GMT","content-type":"application/json;charset=UTF-8","transfer-encoding":"chunked","connection":"close","set-cookie":["JSESSIONID=...; Path=/cloudservice; HttpOnly"]},"request":{"uri":{"protocol":"https:","slashes":true,"auth":null,"host":"cloud.linked-go.com","port":443,"hostname":"cloud.linked-go.com","hash":null,"search":null,"query":null,"pathname":"/cloudservice/api/app/user/login.json","path":"/cloudservice/api/app/user/login.json","href":"https://cloud.linked-go.com/cloudservice/api/app/user/login.json"},"method":"POST","headers":{"accept":"application/json","content-type":"application/json","content-length":75}}}
            javascript.0
            2022-06-08 14:00:00.106	info	script.js.Poolsteuerung.Luftwaermepumpe_Automatische_Steuerung: telegram: Luftwaermepumpe wurde auf Off eingestellt.
            javascript.0
            2022-06-08 14:00:00.105	info	script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: updateDeviceStatus: token ist leer
            javascript.0
            2022-06-08 14:00:00.104	info	script.js.Poolsteuerung.Luftwaermepumpe_Werte_auslesen: updateDevicePower: token ist leer
            

            Was hältst du von dem Vorschlag das Zurücksetzen des Tokens bzw. die Erneuerung auf eine krumme Zahl einzustellen, z.B. alle 57 Minuten?

            O 1 Reply Last reply Reply Quote 0
            • O
              oxident @dering last edited by

              @dering said in [Javascript] Midas (Aquatemp) Poolheizung:

              Was hältst du von dem Vorschlag das Zurücksetzen des Tokens bzw. die Erneuerung auf eine krumme Zahl einzustellen, z.B. alle 57 Minuten?

              Sehr gute Idee 😉
              Magst Du das mal testen?

              D 1 Reply Last reply Reply Quote 0
              • D
                dering @oxident last edited by dering

                @oxident Leider hat es auch nicht geholfen.
                Was mir damals schon aufgefallen ist, wenn ich den Objekten von iobroker mir den Datenpunkt "mode" angesehen hatte, während der Modus geändert wurde, ist der Wert manchmal hin und her gesprungen. Also von -1 auf 2 und dann wieder auf -1.

                Eventuell hat es etwas mit der async function zutun? z.B. hier:

                on({id: dpRoot + ".mode", change: "ne", ack: false}, async function (obj) {
                    updateDevicePower(device, getState(dpRoot + ".mode").val);
                });
                

                Aus welchem Grund hast du das eingebaut?

                Warum aktualisierst du den Wert nochmal, wenn der noch nicht acknowledged wurde?

                schedule('*/' + interval + ' * * * * *', function () {    
                    if(!getState(dpRoot + ".mode").ack) {
                        updateDevicePower(device, getState(dpRoot + ".mode").val);
                    }
                

                In meinen Scripten habe ich acknowledged noch nie verwendet 🙂 . Können wir das vielleicht einfach weglassen?

                A 1 Reply Last reply Reply Quote 0
                • A
                  Andy200877 @dering last edited by Andy200877

                  Nachdem das Wifi Modul seit heute wieder lieferbar ist, habe ich es mir direkt bestellt.
                  Ich möchte je nach PV-Leistung die Wärmepumpe ein.- bzw. ausschalten.
                  Dafür brauche ich auch das Script..... g

                  Ich habe auch mal etwas am Script gebastelt... Die Objekte werden so automatisch erstellt, wenn diese noch nicht vorhanden sind.
                  Das ganze muss vor der Zeile : "updateToken();"

                  function createobjects() {
                      log ("erstelle Objekte");
                      createState(dpRoot + '.ambient', {read: true, write: false,  type: "number", unit:"°C", name: "Umgebungstemperatur"});
                      createState(dpRoot + '.connection', {read: true, write: false,  type: "boolean", role: "state", name: "Verbindung", def: "false"});
                      createState(dpRoot + '.consumption', {read: true, write: false,  type: "number", unit:"W", name: "Stromverbrauch", def: 0});
                      createState(dpRoot + '.error', {read: true, write: false,  type: "boolean", role: "state", name: "Fehler", def: "false"});
                      createState(dpRoot + '.errorCode', {read: true, write: false,  type: "string", name: "Fehlercode", def: ""});
                      createState(dpRoot + '.errorLevel', {read: true, write: false,  type: "number", name: "Fehlerlevel"});
                      createState(dpRoot + '.errorMessage', {read: true, write: false,  type: "string", name: "Fehlermeldung", def: ""});
                      createState(dpRoot + '.mode', {read: true, write: true,  type: "string", states: "-1:off;0:cool;1:heat;2:auto", name: "Modus", def: ""});
                      createState(dpRoot + '.silent', {read: true, write: true,  type: "boolean", role: "state", name: "Silent", def: "false"});
                      createState(dpRoot + '.state', {read: true, write: false,  type: "boolean", role: "state", name: "Status", def: "false"});
                      createState(dpRoot + '.tempIn', {read: true, write: false,  type: "number", unit:"°C", name: "Eingangstemperatur"});
                      createState(dpRoot + '.tempOut', {read: true, write: false,  type: "number", unit:"°C", name: "Ausgangstemperatur"});
                      createState(dpRoot + '.tempSet', {read: true, write: true,  type: "number", unit:"°C", name: "Solltemperatur"});
                  }
                  
                  createobjects();
                  
                  O 1 Reply Last reply Reply Quote 1
                  • O
                    oxident @Andy200877 last edited by

                    @andy200877 Super, danke für Deine Zuarbeit. Hab's eingebaut und das Skript oben aktualisiert.

                    Jetzt wundert mich noch das Problem von @dering ... ich kann das bei mir nicht wirklich nachstellen.

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      dering @oxident last edited by dering

                      @oxident ich bin noch immer am analysieren. Mittlerweile hab ich die Vermutung, wenn ich den mode der LWP immer zur vollen Stunde ändern möchte, dass es nicht funktioniert (vielleicht läuft der Token immer zur vollen Studen auto. ab? (serverseitig)). Wenn ich jedoch 09:01 oder 20:01 Uhr einstelle, scheint es stabil zu funktionieren.
                      Aktuell hab ich leider das Problem, ich musste die LWP vom Strom nehmen, seitdem verbindet sich das AquaTemp Modul nicht mehr mit dem WLAN bzw. ich kann es nicht mehr neu registrieren.
                      Noch weiß ich nicht, wo ich Support herbekomme... habt ihr da zufälligerweise Ideen?

                      O 1 Reply Last reply Reply Quote 0
                      • O
                        oxident @dering last edited by

                        @dering Das könnte auch sein. Eventuell könnte man auch mal testen, einfach bei jeder Aktion einen neuen Login zu machen.

                        Kurze Frage nebenbei: Was ist der Grund für Deine stündlichen Moduswechsel?

                        D 2 Replies Last reply Reply Quote 0
                        • D
                          dering @oxident last edited by

                          @oxident Das stündliche wechseln war nur zum testen. Mein aktueller Anwendungsfall ist ganz einfach. Unter der Woche wird die LWP erst ab 14 Uhr eingeschaltet (weil sowieso niemand da ist) und um 20 Uhr ausgeschaltet (damit sie morgens, wenn die Poolpumpe wieder läuft, nicht auch startet).
                          Am Wochenende wird die LWP schon morgens ab 10 Uhr eingeschaltet.

                          1 Reply Last reply Reply Quote 0
                          • D
                            dering @oxident last edited by

                            @oxident Seit ich eingestellt um 09:01 und 20:01 Uhr ein/aus schalten, funktioniert es wie erwartet.
                            Wie wärs wir arbeiten überhaupt nicht mit Token sondern es wird einfach bei jeder Aktion eingeloggt?

                            O 1 Reply Last reply Reply Quote 0
                            • O
                              oxident @dering last edited by

                              @dering Nee, halte ich für keine gute Idee. Bei der Recherche der Funktionen habe ich gelesen, dass man durchaus geblockt werden kann, wenn man sich zu häufig neu anmeldet.

                              Ich teste aber gerade mal, die Sache mit einem Timer-Interval (anstelle immer zur vollen Stunde) zu lösen. Dann ist es (Skriptstart + 60min) und damit mehr oder weniger zufällig...

                              Kleiner Tipp am Rande an alle: Vielleicht wussten es manche schon, aber durch die Verbrauchsmessung im Adapter habe ich herausgefunden, dass der "Silent"-Mode eine Art "Sparmodus" ist und nicht, wie in meiner Anleitung der WP beschrieben, einfach nur die Tastentöne deaktiviert.

                              Sind bei mir -1000W. Bei verminderter Wärmeleistung na klar.

                              D W 2 Replies Last reply Reply Quote 0
                              • D
                                dering @oxident last edited by

                                @oxident sagte in [Javascript] Midas (Aquatemp) Poolheizung:

                                Ich teste aber gerade mal, die Sache mit einem Timer-Interval (anstelle immer zur vollen Stunde) zu lösen. Dann ist es (Skriptstart + 60min) und damit mehr oder weniger zufällig...

                                Das ist ja im Prinzip das, was ich bereits getestet hatte. Ich habe immer bei xx:57 Uhr das Token zurückgesetzt. Jedoch hatte es zur vollen Stunde trotzdem nicht funktioniert. Mit xx:01 Uhr funktioniert es problemlos.

                                O 1 Reply Last reply Reply Quote 0
                                • O
                                  oxident @dering last edited by

                                  @dering Ja, korrekt.
                                  Ich habe es jetzt auch ein paar Tage lang getestet und das Skript jetzt entsprechend aktualisiert. Meiner Meinung nach ist die Lösung mit dem 60min-Timer deutlich besser.

                                  Freue mich auf Rückmeldungen 😉

                                  1 Reply Last reply Reply Quote 0
                                  • F
                                    Fuxx 0 last edited by

                                    Hallo zusammen,

                                    erst einmal vielen Dank für das Skript!
                                    Ich habe das WLAN-Modul nun nachgerüstet und wollte mit Eurem Skript die Einbindung in iobroker realisieren.

                                    Funktioniert das Skript bei Euch noch?
                                    Ich habe das Problem, dass unter der Funktion updateDeviceID das Ergbnis von body.object_result immer leer ist.

                                    Dadurch ist egal welchen DP ich ändere, ich bekomme immer Zustandsänderung fehlgeschlagen!
                                    Alle lesenden DP werden nicht befüllt.

                                    O 1 Reply Last reply Reply Quote 0
                                    • O
                                      oxident @Fuxx 0 last edited by

                                      @fuxx-0 Komisch. Also bei mir klappt alles super.

                                      Gibt es denn Fehlermeldungen im Log?
                                      Funktioniert die App?

                                      F 1 Reply Last reply Reply Quote 0
                                      • F
                                        Fuxx 0 @oxident last edited by Homoran

                                        @oxident
                                        Vielen Dank für die Antwort. Ja das App funktioniert.
                                        Ich habe einmal das PW geändert weil ich vermutet hatte, dass es zu Problemen mit Sonderzeichen kommt. Das war es leider nicht.

                                        Derzeit läuft noch kein Wasser durch die Wärmepumpe, da der Pool noch eingewintert ist. Aus dem Grund zeigt die App eine Fehlermeldung an.
                                        Die Meldung kam aber erst gerade auf, weil ich die Pumpe zu lange ohne den Wassefluss angelassen hatte.

                                        Im App sehe ich trotzdem ein und augehende temperartur. Den Modus kann ich in der App auch schalten. (Off - Heat - Off habe ich erfolgreich in der App getestet. )

                                        Beim initialen Start des Scriptes bekam ich folgende Fehlermeldung:

                                        21:18:49.472	error	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: TypeError: Cannot read properties of null (reading 'toString')
                                        21:18:49.472	error	javascript.0 (430) at updateDeviceSetTemp (script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern:436:36)
                                        21:18:49.473	error	javascript.0 (430) at Object.<anonymous> (script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern:523:5)
                                        

                                        Dieser Fehler scheint sich aber nur auf die Erstellung der DP zu beziehen. Hier die passenden ausgaben aus dem Log:

                                        javascript.0
                                        2023-05-08 21:18:51.106	error	Error in request callback: TypeError: Cannot read properties of undefined (reading 'device_code')
                                        
                                        javascript.0
                                        2023-05-08 21:18:50.445	error	Error in request callback: TypeError: Cannot read properties of undefined (reading 'device_code')
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.529	warn	at processImmediate (node:internal/timers:468:21)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.529	warn	at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2411:33)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.528	warn	You are assigning a string to the state "0_userdata.0.Poolheizung.state" which expects a boolean. Please fix your code to use a boolean or change the state type to string. This warning might become an error in future versions.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.522	warn	at processImmediate (node:internal/timers:468:21)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.522	warn	at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2411:33)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.521	warn	You are assigning a string to the state "0_userdata.0.Poolheizung.silent" which expects a boolean. Please fix your code to use a boolean or change the state type to string. This warning might become an error in future versions.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.497	warn	at processImmediate (node:internal/timers:468:21)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.497	warn	at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2411:33)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.496	warn	You are assigning a string to the state "0_userdata.0.Poolheizung.error" which expects a boolean. Please fix your code to use a boolean or change the state type to string. This warning might become an error in future versions.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.473	error	at processImmediate (node:internal/timers:466:21)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.473	error	at Immediate.<anonymous> (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5916:56)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.473	error	at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:593:29)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.473	error	at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1244:38)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.473	error	at Object.<anonymous> (script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern:523:5)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.472	error	at updateDeviceSetTemp (script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern:436:36)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.472	error	script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: TypeError: Cannot read properties of null (reading 'toString')
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.466	warn	at processImmediate (node:internal/timers:468:21)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.466	warn	at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2411:33)
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.465	warn	You are assigning a string to the state "0_userdata.0.Poolheizung.connection" which expects a boolean. Please fix your code to use a boolean or change the state type to string. This warning might become an error in future versions.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.454	warn	Read-only state "0_userdata.0.Poolheizung.tempOut" has been written without ack-flag with value "null"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.413	warn	Read-only state "0_userdata.0.Poolheizung.tempIn" has been written without ack-flag with value "null"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.412	warn	Read-only state "0_userdata.0.Poolheizung.errorLevel" has been written without ack-flag with value "null"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.411	warn	Read-only state "0_userdata.0.Poolheizung.ambient" has been written without ack-flag with value "null"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	This object will not be created in future versions. Please report this to the developer.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	Object 0_userdata.0.Poolheizung.state is invalid: Default value has to be type "boolean" but received type "string"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	This object will not be created in future versions. Please report this to the developer.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	Object 0_userdata.0.Poolheizung.silent is invalid: Default value has to be type "boolean" but received type "string"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	This object will not be created in future versions. Please report this to the developer.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.281	warn	Object 0_userdata.0.Poolheizung.mode is invalid: obj.common.states has an invalid type! Expected "object", received "string"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.280	warn	This object will not be created in future versions. Please report this to the developer.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.280	warn	Object 0_userdata.0.Poolheizung.error is invalid: Default value has to be type "boolean" but received type "string"
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.280	warn	This object will not be created in future versions. Please report this to the developer.
                                        
                                        javascript.0
                                        2023-05-08 21:18:49.280	warn	Object 0_userdata.0.Poolheizung.connection is invalid: Default value has to be type "boolean" but received type "string"
                                        

                                        Bei jedem Start danach kommt die Meldung nicht mehr.
                                        Wenn ich z.B. mode ändere und das Skript starte sieht die Ausgabe wie folgt aus:

                                        21:22:32.070	info	javascript.0 (430) Stop script script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern
                                        21:23:12.289	info	javascript.0 (430) Start javascript script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern
                                        21:23:12.293	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: erstelle Objekte
                                        21:23:12.294	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: Token Neuanforderung
                                        21:23:12.295	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: schedule(cron=*/30 * * * * *)
                                        21:23:12.295	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: setInterval(ms=3600000)
                                        21:23:12.297	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: subscribe: {"pattern":{"id":"0_userdata.0.Poolheizung.mode","change":"ne","ack":false,"q":0},"name":"script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern"}
                                        21:23:12.297	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: subscribe: {"pattern":{"id":"0_userdata.0.Poolheizung.silent","change":"ne","ack":false,"q":0},"name":"script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern"}
                                        21:23:12.297	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: subscribe: {"pattern":{"id":"0_userdata.0.Poolheizung.tempSet","change":"ne","ack":false,"q":0},"name":"script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern"}
                                        21:23:12.297	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: registered 3 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
                                        21:23:30.004	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: getState(id=0_userdata.0.Poolheizung.mode, timerId=undefined) => {"val":"1","ack":false,"ts":1683573784694,"q":0,"from":"system.adapter.admin.0","user":"system.user.admin","lc":1683573784694}
                                        21:23:30.005	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: getState(id=0_userdata.0.Poolheizung.mode, timerId=undefined) => {"val":"1","ack":false,"ts":1683573784694,"q":0,"from":"system.adapter.admin.0","user":"system.user.admin","lc":1683573784694}
                                        21:23:30.006	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: getState(id=0_userdata.0.Poolheizung.silent, timerId=undefined) => {"val":"false","ack":true,"ts":1683573529522,"q":0,"c":"script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1683573529457}
                                        21:23:30.130	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: Zustandsänderung fehlgeschlagen!
                                        

                                        Im Log gibt es passend die folgende Meldung dazu:

                                        javascript.0
                                        2023-05-08 21:23:31.773	error	Error in request callback: TypeError: Cannot read properties of undefined (reading 'device_code')
                                        
                                        javascript.0
                                        2023-05-08 21:23:13.092	error	Error in request callback: TypeError: Cannot read properties of undefined (reading 'device_code')
                                        

                                        Hast du eine Idee woran es liegen kann? Ich schaue parallel weiter, sehe aber bisher keinen Fehler im Skript 😕

                                        1 Reply Last reply Reply Quote 0
                                        • O
                                          oxident last edited by

                                          Hmm, Du könntest auch mal testweise diese beiden Zeilen in der UpdateDeviceID() wieder "wegkommentieren":

                                                     //log(JSON.stringify(response));
                                                     //log(JSON.stringify(body.object_result));
                                          

                                          Dann bekommst Du mehr Details über die Rückgabe des Servers ... und warum dort keine DeviceID kommt.

                                          F 1 Reply Last reply Reply Quote 0
                                          • F
                                            Fuxx 0 @oxident last edited by Homoran

                                            @oxident

                                            Das ist das was ich nicht verstehe. Anmeldung und Token erstellen klappt alles.
                                            Der Response gibt auch 200 zurück und damit sollte doch eigentlich alles schön sein. Aber object_result ist leer. 😞
                                            Daher hatte ich befürchtet, dass die API geändert wurde. Wenn das Skript bei Euch aber noch läuft kann das ja auch nicht der Fall sein.

                                            08:50:53.746	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: {"statusCode":200,"body":{"error_code":"0","error_msg":"Success","error_msg_code":"","object_result":[],"is_reuslt_suc":true},"headers":{"date":"Tue, 09 May 2023 06:50:53 GMT","content-type":"application/json;charset=UTF-8","transfer-encoding":"chunked","connection":"close"},"request":{"uri":{"protocol":"https:","slashes":true,"auth":null,"host":"cloud.linked-go.com","port":443,"hostname":"cloud.linked-go.com","hash":null,"search":null,"query":null,"pathname":"/cloudservice/api/app/device/deviceList.json","path":"/cloudservice/api/app/device/deviceList.json","href":"https://cloud.linked-go.com/cloudservice/api/app/device/deviceList.json"},"method":"POST","headers":{"x-token":"2F9BE34BC92372C50CE6E84DB074140B","accept":"application/json","content-length":0}}}
                                            
                                            08:50:53.747	info	javascript.0 (430) script.js.Regeln_Komfort.Pool_Wärmepumpe_steuern: []
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            717
                                            Online

                                            31.7k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            24
                                            354
                                            43779
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo