Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. ecoflow-connector-Script zur dynamischen Leistungsanpassung

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    ecoflow-connector-Script zur dynamischen Leistungsanpassung

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

      @waly_de Ich hab die duration schon auf 0. Aber das Problem ist ja, dass er meint, er könne mit 10 W laden, lädt aber in wirklichkeit mit 80 Watt. Dann wird nicht abgeschaltet… oder vielleicht… sorry das ganze Setup ist einfach schon etwas komplex, je nach Mondphase verliert auch mal das Shelly die Verbindung ne Weile, vielleicht war am Ende das das Problem, muss ich mal prüfen bevor ich die weiter nerve. Aber heut hab ich auch zu wenig Sonne.
      Edit: Wobei, glaub doch nicht, dass das Shelly da das Problem war. Die Leistung wurde ja auch geupdated, also war das Gerät wohl nicht offline. Naja ich beobachte es weiter.

      1 Reply Last reply Reply Quote 0
      • F
        foxthefox Developer @aherby last edited by

        @aherby sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

        @foxthefox Hey meinst du die Helligkeit der LED-Beleuchtung vom Smartplug?
        Ja die kann man über die App ändern.

        ist es möglich, das es hier drin ist?

        /thing/property/set:0a36102018352001280138034002488201580170ddbb9d8006800113880101ba0103696f73ca0110485735325a4448345346363636353838
        

        kann damit was angefangen werden?

        könnte sein, das es das war cmdID=130 war mir noch nicht bekannt, allerdings fehlt noch ein Wert für die Helligkeit in dem Telegramm
        Aber ich notier es mir mal.

        1 Reply Last reply Reply Quote 0
        • F
          foxthefox Developer @aherby last edited by

          @aherby sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

          @foxthefox ist die Helligkeit nicht schon hier drin ?

          0_userdata.0.ecoflow.app_device_property_HW52ZDH4SF66xxxx.data.plug_heartbeat_pack.brightness
          

          Max. Power hier:

          0_userdata.0.ecoflow.app_device_property_HW52ZDH4SF66xxxx.data.plug_heartbeat_pack.maxWatts
          

          Die ersten Mitschnitte ware durch die neue Firmware der Smartplugs und vom Powerstream, dass man die Berücksichtigung der Smartplugs für den Haushaltsstrom oder Energiebedarf ein oder ausschalten kann.

          KAnn ich gerade leider durch zu wenig Sonne nicht richtig testen.

          die Werte sind als Status schon mit dabei.
          Mir ging es ja um die Befehle. Das ist erstmal soweit klar.
          Danke

          A 1 Reply Last reply Reply Quote 0
          • A
            aherby @foxthefox last edited by aherby

            @foxthefox Schau mal ob hier die Helligkeit drin ist:

            Nachricht: {"header":[{"pdata":"08a307","src":32,"dest":53,"dSrc":1,"dDest":1,"checkType":3,"cmdFunc":2,
            "cmdId":130,"dataLen":3,"needAck":1,"seq":1683706391,"version":19,"payloadVer":1,"from":"ios","deviceSn":"HW52ZDH4SF66xxxx"}]}
            
            Nicht definierter cmd_func-Wert. [Wasserkocher] cmdId:130 cmdFunc:2
            0a36102018352001280138034002488201580170ccb788a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
            
            0a3d0a030880041020183520012801380340024882015003580170bfef88a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
            
            0a3d0a0308ff071020183520012801380340024882015003580170829089a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
            

            Max Power / Überlastschutz hier ?:

            script.js.Ecoflow_Dynamische_Leistung_V1_2: Nachricht: {"header":[{"pdata":"08880e","src":32,"dest":53,"dSrc":1,"dDest":1,"checkType":3,"cmdFunc":2,"cmdId":137,"dataLen":3,"needAck":1,"seq":1683834767,"version":19,"payloadVer":1,"from":"ios","deviceSn":"HW52ZDH4SF66xxxx"}]}
            
            0a3d0a0308d60d1020183520012801380340024889015003580170bb99a6a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
            [Wasserkocher] cmdId:137 cmdFunc:2
            
            0a3d0a0308c4131020183520012801380340024889015003580170f9b8a6a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
            
            0a2e0a0368c41310351820200128014002480150035801800103880103ca0110485735325a4448345346363636353838
            
            script.js.1_16_1_Ecoflow_Dynamische_Leistung: Decodierte Nachricht:{"data":{"plug_heartbeat_pack":{"maxWatts":2500}}}
            
            F W 2 Replies Last reply Reply Quote 0
            • F
              foxthefox Developer @aherby last edited by foxthefox

              @aherby sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

              @foxthefox Schau mal ob hier die Helligkeit drin ist:
              Ja cmdId=130 hatten wir als Helligkeit definiert.

              Das könnte Helligkeit cmdID=130 sein, hier mit Zahlenwert 512, könnte 50% entsprechen

              0a3d0a030880041020183520012801380340024882015003580170bfef88a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
              

              hier Zahlenwert 1023, also ggf. 100% Helligkeit

              0a3d0a0308ff071020183520012801380340024882015003580170829089a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
              

              damit sollte das auch als Kommando gehen brightness cmdId=130, dateLen=3, Helligkeit als Zahlenwert normiert auf 1024 (100%)

              Max Power / Überlastschutz hier ?:

              so isses, cmdId=137:
              hier ist 1750W als Übergabewert drin:

              0a3d0a0308d60d1020183520012801380340024889015003580170bb99a6a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
              [Wasserkocher] cmdId:137 cmdFunc:2
              

              und dieses Kommando mit cmdId=137 hat den Übergabewert von 2500W, das passt zusammen!

              0a3d0a0308c4131020183520012801380340024889015003580170f9b8a6a206800113880101ba0103696f73ca0110485735325a4448345346363636353838
              
              0a2e0a0368c41310351820200128014002480150035801800103880103ca0110485735325a4448345346363636353838
              
              script.js.1_16_1_Ecoflow_Dynamische_Leistung: Decodierte Nachricht:{"data":{"plug_heartbeat_pack":{"maxWatts":2500}}}
              

              damit sollte das auch als Kommando gehen maxWatts, cmdId=137, dateLen=3, Watt = Zahlenwert

              A 3 Replies Last reply Reply Quote 0
              • A
                aherby @foxthefox last edited by aherby

                @foxthefox Genau richtig es waren erstmal 0%, 50% und 100% Helligkeit. Habe glaube nicht alle als Code eingefügt.

                Und ja 2500 W sind der Max-Wert und 1750 W war so grob als ein Werte oberhalb der Mitte gedacht.

                Kannst du mir in irgendeinerweise beibringen so Sachen / Dinge zu lesen?

                F 1 Reply Last reply Reply Quote 0
                • A
                  aherby @foxthefox last edited by

                  @foxthefox Es gibt ja die "Timerfunktionen" Laden über AC, Laden über Solar und so.
                  Hier würde ich gern die Syntax verstehen und hier teilen.

                  1 Reply Last reply Reply Quote 0
                  • S
                    sirdir @Waly_de last edited by

                    @waly_de Also ich hab’s mal so probiert. Hab den Offset auf -70 um nicht dauernd an der Grenze zu sein. Das Problem ist halt einfach, dass das Script versucht bis auf 0 Watt runter zu regeln bei der Ladeleistung was einfach nicht geht. Ich persönlich würde das wohl so lösen, dass man nen Mindestwert setzen kann (also so die 88W bei meiner Ecoflow) und sobald der Wert tiefer gesetzt werden müsste um die Bedinungen einzuhalten wird stattdessen die Ladung pausiert.

                    1 Reply Last reply Reply Quote 0
                    • S
                      sirdir @Waly_de last edited by sirdir

                      @waly_de hm, weiteres Problem mit der Lösung. Gerade steht *writeables.chgPauseFlag auf 1. Auf dem Gerät scheint das aber nicht anzukommen. WIFI ist OK. params.inv.inputWatts meldet manchmal 0, manchmal 60W, laut shelly wird konstant mit um die 90W geladen. Das script hat die Ladegeschwindigkeit auf 0 gesetzt. Sehe grad, das data.params.chgPauseFlag gibt 255 zurück. Da klappt wohl irgendwo noch was nicht ganz mit der übertragung manchmal?
                      Hab jetzt gerade chgPauseFlag kurz auf 0 gesetzt, dann hat er noch schneller geladen?! (über 255W wahrscheinlich?) Dann nochmal auf 1 gesetzt und jetzt ist Ruhe, wie es sein sollte. Irgendwo rutschen da in der Kommunikation wohl immer noch 255 rein manchmal?
                      PS: Ja ich seh's gerade, *.params.slowChgWatts steht auf 255 *.writeables.slowChgWatts auf 0 steht.

                      1 Reply Last reply Reply Quote 0
                      • S
                        sirdir @Waly_de last edited by sirdir

                        @waly_de Hm, also ich hab das jetzt gerade nochmal genauer angeschaut - das Problem tritt anscheinend auf, wenn ich die D2M subscribe - dann springen pauseChgFlag und slowChgWatts zufällig auf 255 (als ich gerade getestet habe und jeweils wieder den richtigen Wert setzen lies, war's immer in einem durchgang deines Scripts der richtige Wert, danach wieder 255. . In den writables bleibt’s korrekt, aber an die Station geschickt wird anscheinend der falsche Wert.

                        Edit: Hat's evtl. was damit zu tun? Mir ist nicht ganz klar was das bedeutet:

                            { id: 0, name: 'slowChgWatts', ValueName: 'slowChgWatts', Typ: 'D2M', MT: 3, OT: 'acChgCfg', AddParam: '{"fastChgWatts":255, "slowChgWatts":0,"chgPauseFlag":255}' }, // Objekt angelegt, schreibbar
                            { id: 0, name: 'chgPauseFlag', ValueName: 'chgPauseFlag', Typ: 'D2M', MT: 3, OT: 'acChgCfg', AddParam: '{"fastChgWatts":255, "slowChgWatts":255,"chgPauseFlag":0}' }, // TODO: chgPauseFlag testen, ob dann die Ladung pausiert
                        
                        W 1 Reply Last reply Reply Quote 0
                        • W
                          Waly_de @sirdir last edited by

                          @sirdir leider hab ich im Augenblick keine Zeit um das genauer zu untersuchen. Kümmere ich mich bald drum. Ich bau Dir dann auch eine Parameter ein "ExcessChargeStopPower" der festlegt ab welcher Überschussleistung abgestellt werden soll, was im Moment fest auf 0W steht.

                          Noch ein paar Anmerkungen:

                          @sirdir sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                          Hab den Offset auf -70 um nicht dauernd an der Grenze zu sein.

                          Das führt aber auch dazu das ein negativer Wert an die Delta gesendet wird.
                          Das ist noch nicht abgefangen. Bau ich in die nächste Version.

                          Dass mit den 255 ist vermutlich richtig so. 255 heisst nach dem was wir bisher wissen: den vorhandenen Wert nicht ändern. Das wird nur mit dem Set gesendet, auch von der APP. Im eigentlichen Wert (Heartbeat) steht dann der echte wert.

                          E S 2 Replies Last reply Reply Quote 0
                          • E
                            ETGermany @Waly_de last edited by

                            @waly_de Interessantes Thema, habe das gerade gefunden, Tibber Pulse hängt am Zähler und Web-Server ist freigeschaltet. Dein Skript in meinen ioBroker eingetragen, allerdings gibt es bei mir ein Problem mit der Funktion BigInt():
                            Cannot find name 'BigInt'. Do you need to change your target library? Try changing the 'lib' compiler option to 'es2020' or later.(2583)
                            Keine Ahnung wo ich die Option für den Compiler anpassen muss - gibt es da eine Lösung oder Hilfestellung?

                            W 1 Reply Last reply Reply Quote 0
                            • S
                              sirdir @Waly_de last edited by sirdir

                              @waly_de der falsche Wert steht aber IMHO im Heartbeat. Aber irgendwie auch nur gestern, am Tag davor schien es zu klappen. Hab jetzt vorerst alles wieder auf shelly an/aus gestellt, da funktioniert alles soweit. Wenn ich die Grenzen vernünftig setze geht es auch nicht andauernd an und aus. Es ist wirklich schade, dass man die Geräte nicht lokal steuern kann. Manchmal hab ich das Gefühl die Server tun ihr übriges… Dass bei 0 überschuss aus geht (hab die Stelle im Script übrigens schon gefunden) ist ja soweit OK. Was ich eher möchte ist, dass etwas 'Luft' bleibt beim Leistung setzen. (resp. eben dass das Script nicht versucht unrealistisch tiefe Leistungen zu setzen). Ich schau da auch nochmal rein... Hab mir eigentlich mal gesagt ich fummle an deinem script nicht mehr rum, aber…

                              1 Reply Last reply Reply Quote 0
                              • W
                                Waly_de @ETGermany last edited by

                                @etgermany sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                allerdings gibt es bei mir ein Problem mit der Funktion BigInt():
                                Cannot find name 'BigInt'. Do you need to change your target library? Try changing the 'lib' compiler option to 'es2020' or later.(2583)
                                Keine Ahnung wo ich die Option für den Compiler anpassen muss - gibt es da eine Lösung oder Hilfestellung?

                                Ich nehme an, du bekommst diese Meldung nur im Editor und nicht beim Ausführen des Scripts, richtig?
                                Das hatte ich auch, es geht scheinbar um die javascript Versionen. Man kann das abstellen indem man "es2020" in den in den Instanz-Einstellungen des Javascriptadapters unter "Die Syntaxhilfe für diese npm-Module aktivieren:" einträgt.
                                Ich habe dort 3 Einträge: JSON,string und es2020.

                                Bildschirmfoto 2023-12-16 um 11.54.51.jpg

                                S A P 3 Replies Last reply Reply Quote 0
                                • S
                                  sirdir @Waly_de last edited by

                                  @waly_de Ich glaube man muss auch bei der Ladeleistung noch nen Offset vorsehen. gerade der inv.inputWatts zeigt vielleicht die DC Leistung an. Der Wert ist tiefer als was man als SlowChgWatts setzt, laut meinem Shelly ist die bezogene Leistung aber höher. (in meinem Fall ca. 20W differenz)

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    aherby @foxthefox last edited by

                                    @foxthefox, @Waly_de
                                    So da meine Delta 2 Max nun mal etwas geladen ist und auch heute ein weiteres Update durch Ecoflow bekommen hat,
                                    dachte ich log mal was über die Lap-Funktionen.

                                    Laden über Solar, einmalig, heute 17.12.23 ab 10:00 Uhr:

                                    script.js.Ecoflow_Dynamische_Leistung_V1_2: Unbekannter Delta2Max Set Befehl: {"params":{"min":20,"taskIndex":0,"taskPrior":0,"sec":6,"timeMode":3,"timeScale":[0,0,0,0,0,0,0,240,255,255,255,255,255,255,255,255,255,255],"day":17,"type":1,"timeParam":1036177,"year":2023,"week":1,"isEnable":1,"month":12,"hour":9,"isCfg":1},"from":"iOS","lang":"de-de","id":"232761002","moduleSn":"R351ZEB4HF4Exxxx","moduleType":1,"operateType":"taskCfg","version":"1.0"}
                                    

                                    ein verändern jeweils um eine komplette Stunde (10, 11, 12, 13, 14, 15, 16:00 Uhr) ewirkt:

                                    "timeScale":[0,0,0,0,0,0,0,240,255,255,255,255,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,252,255,255,255,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,0  ,255,255,255,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,0  ,192,255,255,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,0  ,0  ,240,255,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,0  ,0  ,  0,252,255,255,255,255,255,255],"day":17,"type":1,
                                    "timeScale":[0,0,0,0,0,0,0,  0,0  ,0  ,0  ,  0,255,255,255,255,255,255],"day":17,"type":1,
                                    

                                    täglich 10:00 Uhr bis 15:00 Uhr

                                    script.js.Ecoflow_Dynamische_Leistung_V1_2: Unbekannter Delta2Max Set Befehl: {"params":{"min":0,"taskIndex":0,"taskPrior":0,"sec":0,"timeMode":0,"timeScale":[0,0,0,0,0,0,0,240,255,255,255,3,0,0,0,0,0,0],"day":17,"type":1,"timeParam":1036177,"year":2023,"week":1,"isEnable":1,"month":12,"hour":0,"isCfg":1},"from":"iOS","lang":"de-de","id":"617597303","moduleSn":"R351ZEB4HF4Exxxx","moduleType":1,"operateType":"taskCfg","version":"1.0"}
                                    

                                    täglich von 15:00 Uhr bis 20:00 Uhr

                                    script.js.Ecoflow_Dynamische_Leistung_V1_2: JSON-Nachricht empfangen:/app/1669741428735926273/R351ZEB4HF4Exxxx/thing/property/set:{"params":{"min":0,"taskIndex":0,"taskPrior":0,"sec":0,"timeMode":0,"timeScale":[0,0,0,0,0,0,0,0,0,0,0,252,255,255,255,0,0,0],"day":17,"type":1,"timeParam":1036177,"year":2023,"week":1,"isEnable":1,"month":12,"hour":0,"isCfg":1},"from":"iOS","lang":"de-de","id":"873716234","moduleSn":"R351ZEB4HF4Exxxx","moduleType":1,"operateType":"taskCfg","version":"1.0"}
                                    

                                    Könnt ihr hiermit was anfangen?

                                    F 1 Reply Last reply Reply Quote 0
                                    • F
                                      foxthefox Developer @aherby last edited by foxthefox

                                      @aherby
                                      grundsätzlich kann man damit was anfangen, timeScale ist noch etwas interpretationsbedürftig, aber sonst sprechen die Namen schon fast zu einem.

                                      Allerdings würde ich solche Aufgaben nicht über script oder Adapter setzen wollen.
                                      Bzw. diese überhaupt setzen, wenn man Automatisierung über iob macht.
                                      Aus meiner Sicht gehört die Logik zentral an eine Stelle und kein konkurierendes Eigenleben zusätzlich (dezentral im Gerät).
                                      Theoretisch alles machbar, aber einfacher wird es dadurch nicht.

                                      EDIT:
                                      wobei ich glaube, daß die eigentliche Aufgabe im Powerstream zu setzen ist und dann folgt die Powerstation diesem. Kann aber auch sein, daß die Einstellung auch von der Powerstation initiert werden kann.

                                      A 1 Reply Last reply Reply Quote 0
                                      • A
                                        aherby @foxthefox last edited by aherby

                                        @foxthefox Moin es ist eine von vier Automatisierung von der Delta 2 Max.
                                        Laden über Solarengergie, Laden über Wechselstrom, Entladen über AC-Port und Entladen über 12V-Dc Port.

                                        Einstellungen täglich, einmalig, wöchentlich.

                                        Natürlich ist es über die App oder so einfacher aber vielleicht für Überschussladen mit entsprechender Ladeleistung
                                        ein Mehrwert. Oder als Rückmeldung ob eins der "Punkte" aktiv ist und daher die Delta 2 Max dies und das nicht macht.

                                        1 Reply Last reply Reply Quote 0
                                        • F
                                          foxthefox Developer @aherby last edited by foxthefox

                                          @aherby sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                          @foxthefox Genau richtig es waren erstmal 0%, 50% und 100% Helligkeit. Habe glaube nicht alle als Code eingefügt.

                                          Und ja 2500 W sind der Max-Wert und 1750 W war so grob als ein Werte oberhalb der Mitte gedacht.

                                          Kannst du mir in irgendeinerweise beibringen so Sachen / Dinge zu lesen?

                                          Kein Problem.
                                          zum anschauen der HEX-Pakete, gibt man diese auf der Webseite ein
                                          https://protobuf-decoder.netlify.app
                                          Danach wird ohne protobuf-Definition zu kennen etwas ausgegeben.
                                          Beispiel: Bildschirmfoto 2023-12-17 um 17.05.12.png
                                          FieldNumber
                                          1 -> die Daten der gemachten Einstellung
                                          8 -> welches Gerät 20=Powerstream, 2=Plug
                                          9 -> cmdId, hier die 137 für die Überlastgrenze
                                          10 -> Datenlänge von FieldNumber 1

                                          Damit kommt man solchen einfachen Kommandos schon gut auf die Spur.
                                          Komplexere wie die Aufgaben, haben dann in 1 noch ihre eigene Struktur (bzw. wenn es um Daten vom Gerät kommend handelt)

                                          Wenn das eine 0% Helligkeit war, dann ist dies wieder auch ein interessanter Fall. Bei binären wurde auch schon eine "0" gar nicht als data übergeben, sondern nur der Rest. Hier scheint es ähnlich zu sein, daß 0% auch nicht übergeben wird.

                                          A 1 Reply Last reply Reply Quote 0
                                          • A
                                            aherby @foxthefox last edited by aherby

                                            @foxthefox
                                            0% Helligkeit könnte dies hier sein:

                                            script.js.Ecoflow_Dynamische_Leistung_V1_2: Binäre Nachricht empfangen:/app/166974142873592xxxx/HW52ZDH4SF66xxxx/thing/property/set:0a36102018352001280138034002488201580170f4f9d1c407800113880101ba0103696f73ca0110485735325a4448345346363636353835
                                            
                                            F 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            538
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            126
                                            1630
                                            501615
                                            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