NEWS
ecoflow-connector-Script zur dynamischen Leistungsanpassung
ecoflow-connector-Script zur dynamischen Leistungsanpassung
-
@maik-becker sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@maik-becker said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hallo, ich habe einen Delta Pro und er passt die Ladeleitung AC zwar an per Skript aber er ändert sie nicht in der App.
script.js.1713771693553-ecoflow-connector_v124: Write Event: 0_userdata.0.ecoflow.app_xxxx_xxxxx_thing_property_set.writeables.slowChgPower val: 1660 | No matching entry found.
Kann mir jemand helfen.
Heute habe ich ecoflow-mqtt installiert dieses Script kann über ecoflow-mqtt.0.xxxxx.inv.cfgSlowChgWatts die Ladeleistung ändern.
Daher habe ich jetzt erst einmal im JS von 0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.slowChgPower auf ecoflow-mqtt.0.xxxxx.inv.cfgSlowChgWatts geändert, jetzt wird die Ladeleistung automatisch geändert.
Das zweite Problem, was ich habe, ist das er Nachts mach mal das laden Aktiviert, trotz das kein Solar da ist.
Wenn du das Skript installierst, sind nur Beispielpfade eingegeben. Die musst du natürlich noch an deine Umgebung anpassen. Wenn du deine Delta richtig konfiguriert hast, findest du unter 0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables. die werte die zu deiner delta passen.
Aber mit dem Adapter geht das natürlich auch.
Es ist nur wichtig zu wissen, dass die Delta auch dann AC Ladung durchführt, wenn die Ladung auf null herunter geregelt wird. Darum gibt es die Funktion mit dem Zwischenschalter, der die Delta komplett vom Strom trennt wenn kein Überschuss vorhanden ist (ExcessChargeSwitchID)Für das grundsätzliche Prinzip kannst du dir auch noch mal mein Video auf YouTube angucken. Den Link dazu findest du im Eingangsbeitrag.
Hallo,
0_userdata.0.ecoflow.app_1765798xxx_DCEBF8ZFAxxxxx_thing_property_set.writeables.slowChgPower sollte ja auch zum regeln der Ladegeschwindigkeit sein. Auch wenn ich diesen manuell ändere, wird es im der App nicht geändert, da scheint es irgend ein Problem zugeben.
Da wenn ich den gleichen Wert ecoflow-mqtt.0.xxxxx.inv.cfgSlowChgWatts ändere, ist dieser sofort in der App, sichtbar und angepasst.
PS: ich arbeite mit dem Zwischenschalter, ich hatte vorher die Delta Max da, lief alles ohne Probleme.
danke für die hilfe.
-
Hallo,
0_userdata.0.ecoflow.app_1765798xxx_DCEBF8ZFAxxxxx_thing_property_set.writeables.slowChgPower sollte ja auch zum regeln der Ladegeschwindigkeit sein. Auch wenn ich diesen manuell ändere, wird es im der App nicht geändert, da scheint es irgend ein Problem zugeben.
Da wenn ich den gleichen Wert ecoflow-mqtt.0.xxxxx.inv.cfgSlowChgWatts ändere, ist dieser sofort in der App, sichtbar und angepasst.
PS: ich arbeite mit dem Zwischenschalter, ich hatte vorher die Delta Max da, lief alles ohne Probleme.
danke für die hilfe.
@maik-becker hast du im Skript den richtigen Typ für die Delta angegeben?
-
@ponti92 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Bedarf : 1.1800000000000068
Bitte beobachte das mal etwas länger, solange der Bedarf so niedrig ist, wird keine Leistung bereitgestellt. Das ist auch so gewollt. Es dauert ja immer eine gewisse Zeit, die du selbst konfigurieren kannst, bis auf Leistungsspitzen reagiert wird.
MinValueMin: 2, // Der Zeitraum in Minuten, aus dem der niedrigste Gesamtverbrauchswert geholt werden soll. 0 für EchtzeitwertWenn dann die PowerStream weiter im Zusatzpower Modus bleiben, brauche ich davon noch mal das mlog.
@waly_de
ok ich muss das noch mal genauer beobachten, wenn ich die Gelegenheit bekomme. In diesem Log waren auch ab und zu Wolken, sodass es nicht richtig geklappt hat.Eine andere Sache, ich habe vorgestern nun doch mal das letzte Powerstream update 1.0.1.1.195/196 installiert und sehe seitdem keine Temperatur mehr:
0_userdata.0.powerstream.app_device_property_HWXX.data.InverterHeartbeat.llcTempDieser Wert wird nicht mehr richtig aktualisiert. Hat das sonst noch jemand?
-
@maik-becker hast du im Skript den richtigen Typ für die Delta angegeben?
-
@waly_de
ok ich muss das noch mal genauer beobachten, wenn ich die Gelegenheit bekomme. In diesem Log waren auch ab und zu Wolken, sodass es nicht richtig geklappt hat.Eine andere Sache, ich habe vorgestern nun doch mal das letzte Powerstream update 1.0.1.1.195/196 installiert und sehe seitdem keine Temperatur mehr:
0_userdata.0.powerstream.app_device_property_HWXX.data.InverterHeartbeat.llcTempDieser Wert wird nicht mehr richtig aktualisiert. Hat das sonst noch jemand?
@Waly_de
Jetzt hatte ich einen guten Tag und der Trockner lief. Jedoch blieb er immer in der Zusatzpower hängen und hat nur die 30-40W eingespeist anstatt die 300W2024-05-12 15:57:41.862 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Hausstrom: 353.01 2024-05-12 15:57:41.862 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: lowestValue Realpower: 743 2024-05-12 15:57:41.863 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Lastcutoff: 0 2024-05-12 15:57:41.863 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: gapSumme: 0 2024-05-12 15:57:41.864 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Bedarf : 343 2024-05-12 15:57:41.864 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PStotalPV (+10 W/PS): 0 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Gobal totalPV: 1559 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PVBedarf : 0 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: BatBedarf: 343 2024-05-12 15:57:41.866 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PVfaktor:0 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Batfaktor:1 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: ueberschuss:0 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: ************************************* 2024-05-12 15:57:42.938 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: RealPower Set Warte auf aktuelle Daten von: [PowerStream] lezter: 15:57:29 / ACset: 15:57:41 2024-05-12 15:57:55.685 - info: admin.0 (1194) <== Disconnect system.user.admin from ::ffff:192.168.8.201 admin 2024-05-12 15:57:56.692 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: SetBasePower ! 2024-05-12 15:57:56.730 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PowerStream [PowerStream] Maximalleistung geht in die Batterie. Stelle zusätzlich Einspeisung auf 55 W 2024-05-12 15:57:56.779 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PowerStream [PowerStream2] Maximalleistung geht in die Batterie. Stelle zusätzlich Einspeisung auf 30 W 2024-05-12 15:57:56.859 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: otherPS (PSonly): 85 2024-05-12 15:57:56.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: otherPS (all): 409.7Man kann es auch gut in meinem Grafana Dashboard sehen:

der Trockner (rot) geht hoch und der Gesamtverbrauch (lila) geht dadurch hoch. Jedoch regelt der Powerstream (gelb) nicht mehr so hoch wie davor.
-
@Waly_de eine Frage: ich habe meinen PS im Skript richtig registriert (und alle anderen EF Geräte wie Plugs etc.). Habe jetzt aber das Phänomen, dass wenn ich am Nachmittag TV schaue (Smart Plug hängt am TV) der PS dann trotzdem aus der Batterie einspeist, obwohl ich durch meine Solaranlage sogar deutlich negativ bin d.h. massig Strom über habe.
(der Gesamthausstrom aus dem Zähler ist ebenfalls richtig im Skript registriert und erscheint auch in dem Datenpunkt PV Total)Ich hätte jetzt erwartet dass das Skript das erkennt und den PS und Plug entsprechend runterregelt.
-
Hi Zusammen
Kann mir jemand sagen ob er dieses "Problem" auch hat:
Wenn die Akku voll sind, wird Max eingespeist, aber nur die Solarleistung vom Powerstream.
Ich hätte weitere 1200W die am Delta Pro anliegen, diese werden dann nicht verwendet.
Kurz gesagt, bei battPozOn hätte ich gerne 600 Watt, auch wenn zB 200 Watt von der Batterie kommen.
Muss im APP noch was angepasst werden?
LG
Rafalregulation: true, // "true": Dieser PowerStream soll vom Script reguliert werden RegulationOffPower: -1, // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus) hasBat: true, // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant. battPozOn: 99, battPozOff: 95, // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb battOnSwitchPrio: false, // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt prioOffOnDemand: 100, // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus geschaltet wird. 0 für kein Rückschalten. lowBatLimitPozOn: 3, lowBatLimitPozOff: 5, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf lowBatLimit: 150, // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist -
@Waly_de eine Frage: ich habe meinen PS im Skript richtig registriert (und alle anderen EF Geräte wie Plugs etc.). Habe jetzt aber das Phänomen, dass wenn ich am Nachmittag TV schaue (Smart Plug hängt am TV) der PS dann trotzdem aus der Batterie einspeist, obwohl ich durch meine Solaranlage sogar deutlich negativ bin d.h. massig Strom über habe.
(der Gesamthausstrom aus dem Zähler ist ebenfalls richtig im Skript registriert und erscheint auch in dem Datenpunkt PV Total)Ich hätte jetzt erwartet dass das Skript das erkennt und den PS und Plug entsprechend runterregelt.
-
Hi Zusammen
Kann mir jemand sagen ob er dieses "Problem" auch hat:
Wenn die Akku voll sind, wird Max eingespeist, aber nur die Solarleistung vom Powerstream.
Ich hätte weitere 1200W die am Delta Pro anliegen, diese werden dann nicht verwendet.
Kurz gesagt, bei battPozOn hätte ich gerne 600 Watt, auch wenn zB 200 Watt von der Batterie kommen.
Muss im APP noch was angepasst werden?
LG
Rafalregulation: true, // "true": Dieser PowerStream soll vom Script reguliert werden RegulationOffPower: -1, // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus) hasBat: true, // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant. battPozOn: 99, battPozOff: 95, // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb battOnSwitchPrio: false, // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt prioOffOnDemand: 100, // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus geschaltet wird. 0 für kein Rückschalten. lowBatLimitPozOn: 3, lowBatLimitPozOff: 5, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf lowBatLimit: 150, // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist@audiofreak sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
false
Die Skript Konfiguration sieht soweit gut aus. Vermutlich musst du in der App unter Haushalt Strombedarf die Einspeisekontrolle deaktivieren. Dann sollte bei 99 % Akku 600W so lange eingespeist werden bis 95 % Akkustand erreicht sind.
-
@audiofreak sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
false
Die Skript Konfiguration sieht soweit gut aus. Vermutlich musst du in der App unter Haushalt Strombedarf die Einspeisekontrolle deaktivieren. Dann sollte bei 99 % Akku 600W so lange eingespeist werden bis 95 % Akkustand erreicht sind.
Hi Markus, danke für dein Feedback. Haushalt Strombedarf ist deaktiviert, es wird ein Überschuss eingespeist.
Hab aber gesehen dass die Ladewerte beim Delta UND beim PS eingestellt werden können. Beim PS waren min 0 max 100 eingestellt, habe dies angepasst und schaue mal was passiert.
LG -
@Waly_de
Jetzt hatte ich einen guten Tag und der Trockner lief. Jedoch blieb er immer in der Zusatzpower hängen und hat nur die 30-40W eingespeist anstatt die 300W2024-05-12 15:57:41.862 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Hausstrom: 353.01 2024-05-12 15:57:41.862 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: lowestValue Realpower: 743 2024-05-12 15:57:41.863 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Lastcutoff: 0 2024-05-12 15:57:41.863 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: gapSumme: 0 2024-05-12 15:57:41.864 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Bedarf : 343 2024-05-12 15:57:41.864 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PStotalPV (+10 W/PS): 0 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Gobal totalPV: 1559 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PVBedarf : 0 2024-05-12 15:57:41.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: BatBedarf: 343 2024-05-12 15:57:41.866 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PVfaktor:0 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: Batfaktor:1 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: ueberschuss:0 2024-05-12 15:57:41.867 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: ************************************* 2024-05-12 15:57:42.938 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: RealPower Set Warte auf aktuelle Daten von: [PowerStream] lezter: 15:57:29 / ACset: 15:57:41 2024-05-12 15:57:55.685 - info: admin.0 (1194) <== Disconnect system.user.admin from ::ffff:192.168.8.201 admin 2024-05-12 15:57:56.692 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: SetBasePower ! 2024-05-12 15:57:56.730 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PowerStream [PowerStream] Maximalleistung geht in die Batterie. Stelle zusätzlich Einspeisung auf 55 W 2024-05-12 15:57:56.779 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: PowerStream [PowerStream2] Maximalleistung geht in die Batterie. Stelle zusätzlich Einspeisung auf 30 W 2024-05-12 15:57:56.859 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: otherPS (PSonly): 85 2024-05-12 15:57:56.865 - info: javascript.0 (21466) script.js.Ecoflow1_2_4: otherPS (all): 409.7Man kann es auch gut in meinem Grafana Dashboard sehen:

der Trockner (rot) geht hoch und der Gesamtverbrauch (lila) geht dadurch hoch. Jedoch regelt der Powerstream (gelb) nicht mehr so hoch wie davor.
-
@ponti92 danke. Ist ein bisschen nervig, dass ich das im Moment nicht selbst testen kann.
Ich hab versucht eine Lösung einzubauen. Bitte Versuch es mal mit dem folgenden Skript:Hallo ich habe heute Nacht wieder festgestellt, das er Lädt ohne das PV da ist und Einspeist zu selben zeit.
-
@waly_de Denke auch. Melde mich, wenn sie abgeschlossen ist. Dann gebe ich mal Feedback, was out of the box schon läuft.
@eds sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@waly_de Denke auch. Melde mich, wenn sie abgeschlossen ist. Dann gebe ich mal Feedback, was out of the box schon läuft.
Und läuft die Box schon? Gibt es Erkenntnisse zu den Daten die gesendet werden?
-
@Waly_de Super Skript, vielen Dank dafür!
Basierend darauf habe ich eine einfache Lösung entwickelt, die momentan ausschließlich den PowerStream-Output steuert.
Einfache Automatisierung für den Ecoflow PowerStream.
Ein Vorteil davon ist, dass es sich leichter verstehen und erweitern lässt, falls man eigene Funktionalitäten benötigt.
Vielen Dank für deine tolle Arbeit, mach weiter so! -
@Waly_de Super Skript, vielen Dank dafür!
Basierend darauf habe ich eine einfache Lösung entwickelt, die momentan ausschließlich den PowerStream-Output steuert.
Einfache Automatisierung für den Ecoflow PowerStream.
Ein Vorteil davon ist, dass es sich leichter verstehen und erweitern lässt, falls man eigene Funktionalitäten benötigt.
Vielen Dank für deine tolle Arbeit, mach weiter so!@cptmozz sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Basierend darauf habe ich eine einfache Lösung entwickelt,
Und verweist auf einen neuen Post, der auch nur dazu dient auf GitHub weiter zu verweisen?
-
@ponti92 danke. Ist ein bisschen nervig, dass ich das im Moment nicht selbst testen kann.
Ich hab versucht eine Lösung einzubauen. Bitte Versuch es mal mit dem folgenden Skript: -
Hi Zusammen
Kann mir jemand sagen ob er dieses "Problem" auch hat:
Wenn die Akku voll sind, wird Max eingespeist, aber nur die Solarleistung vom Powerstream.
Ich hätte weitere 1200W die am Delta Pro anliegen, diese werden dann nicht verwendet.
Kurz gesagt, bei battPozOn hätte ich gerne 600 Watt, auch wenn zB 200 Watt von der Batterie kommen.
Muss im APP noch was angepasst werden?
LG
Rafalregulation: true, // "true": Dieser PowerStream soll vom Script reguliert werden RegulationOffPower: -1, // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus) hasBat: true, // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant. battPozOn: 99, battPozOff: 95, // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb battOnSwitchPrio: false, // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt prioOffOnDemand: 100, // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus geschaltet wird. 0 für kein Rückschalten. lowBatLimitPozOn: 3, lowBatLimitPozOff: 5, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf lowBatLimit: 150, // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist@audiofreak said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Wenn die Akku voll sind, wird Max eingespeist, aber nur die Solarleistung vom Powerstream.
Ich hätte weitere 1200W die am Delta Pro anliegen, diese werden dann nicht verwendet.
Kurz gesagt, bei battPozOn hätte ich gerne 600 Watt, auch wenn zB 200 Watt von der Batterie kommen.@audiofreak said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hab aber gesehen dass die Ladewerte beim Delta UND beim PS eingestellt werden können. Beim PS waren min 0 max 100 eingestellt, habe dies angepasst und schaue mal was passiert.
Nachdem ich beim PS die Ladewerte angepasst habe funktioniert es wie gewünscht. Musste den BattPozOn auf 90% runtersetzen. Weil: Akku 99% --> BattPozOn --> es wird 120 Watt vom Akku bezogen --> Akku wird durch die direkt angeschlossene Panel aber mit 1.1kW weiter geladen --> Akku erreicht trotzdem 100% und "stellt ab". Erst wenn etwa 10min Netzstrom bezogen wird, schaltet der PS die Akku wieder dazu.
-
@waly_de
Vielen Dank für Deine Antwort. Ich hatte meinen Post nicht mehr gefunden und dachte, er wäre, warum auch immer, gelöscht worden. War keine Unhöflichkeit!Da wir bei Tibber sind, ist der Strom so ab 10:00 sehr günstig, darum soll erstmal alles in die Batterie gehen.
Ich habe das erstmal so gelöst. Per Skript wird um 08:00 Uhr regulate auf false gesetzt. In der App wird dann Prio auf Einspeisung gesetzt mit Grundlast 0W. Nur so wird, wenn Solar 600W überschritten werden der Rest auch eingespeist, sowie alles an Solar, wenn der Akku voll ist. Zu 18:00 wird dann per Skript Dein Skript wieder gestartet und läuft sehr gut.Wenn ich darf, ich habe noch eine andere Frage.
Wir habe seit heute einen 2. PS mit D2 Zusatzakku. Im Script eingetragen und läuft.
Irgendwie war ich der Meinung mal wo gelesen zu haben, dass die Gesamteinspeisung über die Ecoflow-App auf 600W bzw. 800W gedrosselt wird. Scheint nicht so zu sein, es wird alles eingespeist, was die Dinger hergeben^^.Kann man im Script die Gesamteinspeisung auf 800W begrenzen? Von der Elektrik her sind mehr als 800W kein Problem, würde aber gerne auf der legalen Seite bleiben.
LG und DANKESCHÖN
-
Hallo zusammen,
Ich habe versucht alles eizurichten und bekomme nun folgende meldung.
00:00:16.733 error javascript.0 (2085) script.js.EcoflowScript: TypeError: Cannot read properties of undefined (reading 'connect') 00:00:16.735 error javascript.0 (2085) at setupMQTTConnection (script.js.EcoflowScript:1167:25) 00:00:16.736 error javascript.0 (2085) at script.js.EcoflowScript:1471:10 00:00:31.273 warn javascript.0 (2085) at CheckforReconnect (script.js.EcoflowScript:1510:16) 00:00:31.274 warn javascript.0 (2085) at Object.<anonymous> (script.js.EcoflowScript:1018:9) 00:00:31.297 error javascript.0 (2085) at SetBasePower (script.js.EcoflowScript:2166:43) 00:00:31.298 error javascript.0 (2085) at script.js.EcoflowScript:1020:13 00:00:31.299 error javascript.0 (2085) at CheckforReconnect (script.js.EcoflowScript:1519:9) 00:00:31.300 error javascript.0 (2085) at Object.<anonymous> (script.js.EcoflowScript:1018:9)weiss vielleicht jemand was ich falsch gemacht habe ?
gruss
Ole -
So, meine Anbindung läuft jetzt seit einigen Tagen sauber. Daher spendiere ich dem Skript mal einen eigenen Thread.
Anbei findet ihr ein Skript, das eine Verbindung zwischen euren ecoflow-Geräten und ioBroker herstellen kann. Dabei nutzt es die gleiche Schnittstelle wie die ecoFlow App. Ihr benötigt lediglich eure Zugangsdaten zur App und die Seriennummern eurer Geräte, um dieses Skript nutzen zu können. Alle bekannten übermittelten Daten werden in ioBroker als Zustände angelegt. Viele davon sind noch unbekannt. Wenn ihr herausfindet, was sich hinter den unbekannten Daten verbirgt, kann ich die Zustandsnamen anpassen.
Achtung: Der ecoflow-Server sendet unfassbar viele Nachrichten. Wenn ihr mehrere Geräte habt, kann dies euer System stark belasten und sogar zu Abstürzen führen. Vielleicht bekommt Ihr auch diese Meldung und das Script wird beendet:
[error]: javascript.0 (5490) Script script.js.EcoFlow is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!Daher empfehle ich, nicht alle Geräte dauerhaft zu abonnieren (dies kann über einen Parameter in der Einstellungssektion festgelegt werden). Es werden nur die PowerStreams benötigt, um die Einspeiseleistung anpassen zu können.
Sonst kann dieser Grenzwert aber auch in den Einstellungen der Javascript-Instanz heraufgesetzt werden. 3000 dürfte für die meisten Szenarien reichen. (Siehe Screenshot weiter unten. Der Wert befindet sich unten links)Damit kommen wir zur eigentlichen interessanten Funktion des Skripts:
Wenn ihr ein Smartmeter habt, das euren aktuellen Stromverbrauch in Echtzeit anzeigen kann, könnt ihr es an ioBroker anbinden. Informationen dazu findet ihr im Netz.Hier hab ich das Ding gekauft (Wenn ihr über die Links kauft, bekomme ich ein paar Cent Provision ab ;-)):
Hichi Wifi, IR Lesekopf für Stromzähler
https://ebay.us/3X1pkH
Der Verkäufer hat auch ein tolles Video gemacht, wie man es einrichtet
Es funktionieren aber auch viele andere Zähler wie z.B.:
Der Shelly 3EMTibber-Kunden mit Pulse empfehle ich die lokale Einbindung des Pulse als Smartmeter mit meinem Script:
https://forum.iobroker.net/topic/70758/tibber-pulse-verbrauchsdaten-lokal-auslesenDas Skript passt dann die Einspeiseleistung des PowerStream dynamisch an, sodass möglichst der gesamte Verbrauch durch die Einspeisung gedeckt wird, aber nichts ins Netz verschenkt wird. Erst wenn die Batterie voll geladen ist, wird die gesamte Leistung ins Netz eingespeist (wenn ihr das möchtet).
Das Smartmeter muss den aktuellen Verbrauch möglichst in Echtzeit und in der Einheit Watt in einem Objekt von IOBroker zur Verfügung stellen. Im Script muss dann nur noch der Pfad zu diesem Objekt unter "SmartmeterID:" eingetragen werden. Am einfachsten geht das über die Adminoberfläche von IOBroker. Klickt auf Objekte und sucht das Objekt eures Smartmeters mit dem "Watt"-Wert im Objektbaum:

Wenn Ihr auf das markierte Symbol klickt, ist der Pfad in euerer Zwischenablage gespeichert.
Jetzt müsst Ihr ihn nur noch hinter "SmartmeterID:" im Script einfügen. Achtet darauf, dass Ihr es zwischen die "" einfügt.
Wenn alles geklappt hat, der Pfad stimmt und das Script läuft, solltet Ihr unter Objekte: "0_userdata.0.ecoflow.RealPower" sehen, dass sich dieser Wert regelmäßig anpasst.Es können mehrere PowerStreams konfiguriert werden. Im Moment wird jedoch nur der erste in der Konfiguration gesteuert. Ich habe zum Beispiel zwei PowerStreams, einen mit und einen ohne Batterie. Dadurch steht tagsüber mehr Leistung zum Laden der Batterie zur Verfügung. Die Daten werden vom Skript verwendet, um die optimale Einspeiseleistung zu berechnen. In Zukunft könnten auch mehrere PowerStreams gesteuert werden.
Nochmals vielen Dank an alle hier im Forum, die mit Ihrer Arbeit die Anbindung erst möglich gemacht haben!
Ursprünglicher Beitrag: https://forum.iobroker.net/topic/54929/adapter-für-ecoflow-einbindung/Wichtig: Zur Installation müssen 2 Module installiert werden. Einfach in den Einstellungen der Javascriptinstanz unter Zusätzliche Module die beiden Namen eintragen und speichern ("mqtt" und "protobufjs")

Erweiterungen:
Tibber Modul
Kann als eigenes, neues Script neben dem Hauptscript angelegt werden.//************************************************************* // Tibber Modul //************************************************************* // Schaltet die Regelung der Powerstation ab, wenn der Strom billig ist // und einen beliebigen Schalter zum Aktivieren der AC-Ladung ein, bis die Batterie // den durch der "BatMax" festgelegten Ladestand in % erreicht hat // // Diese Parameter aus dem Hauptscript sind wichtig: // RegulationOffPower: -2 // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus) // RegulationState: "Regulate" // Erzeugt der State zum Ein und Aus-Schalten der Regulation. // // Das Script versucht selbst die ID's für den TibberStatus und den Batteriestand zu ermitteln. // Wenn das nicht klappt bitte einfach die richtigen ID's hinter "batSocID" und "tibberID" angeben. // //************************************************************* //************************************************************* // Konfiguration laden, wenn nicht im Originalscript eingefügt //************************************************************* var ConfigData = { statesPrefix: '0_userdata.0.ecoflow', RegulationState: "Regulate" } if (typeof ConfigData.email === 'undefined') { try { let tempConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val if (typeof tempConfigData !== 'object' && tempConfigData !== null) { tempConfigData = JSON.parse(tempConfigData) } if (typeof tempConfigData === 'object' && tempConfigData !== null) { if (tempConfigData.email !== undefined) { ConfigData = tempConfigData; //log("wurde geladen als object") } } } catch (error) { log("Konfiguration wurde nicht geladen: " + error.message) } } /*************************************** ********** YOUR DATA HERE ************ ****************************************/ var tibberConfig = { BatMax: 99, //Bei diesem Ladestand stoppt die AC-Ladung und das Script wird wieder eingeschaltet BatMin: 95, //Der Ladestand der Batterie muss kleiner sein als BatMin , damit der Akku per AC-Ladung geladen wird SwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", //ID des Schalters, der die AC-Ladung einschaltet. "true" und "false" werden gesetzt LevelToSwitch: [ //Hier die Werte definieren, bei denen die AC-Ladung eingeschaltet werden soll //"NORMAL", //"CHEAP", //Einkommentieren falls gewüscht "VERY_CHEAP" ], } //***************************************/ // Nur angeben, wenn automatische Ermittlung fehlschlägt //***************************************/ let batSocID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID").val let tibberID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID").val //***************************************/ var idOK = false if (!batSocID || !tibberID) { log("Versuche die IDs für Tibber und Batterielevel zu finden") $("tibberlink.*.Homes.*.CurrentPrice.level").each(function (id, i) { tibberID = id createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID", tibberID, false) log("TibberID gefunden und gespeichert:" + id) }) $(ConfigData.statesPrefix + ".app_device_property_*.data.InverterHeartbeat.batSoc").each(function (id, i) { if (getState(id).val > 0) { batSocID = id createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID", batSocID, false) log("batSocID gefunden und gespeichert:" + id) } }) if (!batSocID || !tibberID) { log("Fehler bei der Ermittlung der IDs. Bitte händisch ins Script eintragen", 'error') } else { idOK = true } } else { idOK = true } if (idOK) { checkTibber() on({ id: tibberID, change: "ne" }, function (obj) { //log("Tibber Modul. tibberID Event:" + obj.state.val) checkTibber() }); on({ id: batSocID, change: "ne" }, function (obj) { //log("Tibber Modul. batSocID Event:" + obj.state.val + "%") checkTibber() }); } function checkTibber() { if (tibberID && batSocID) { const RegulateID = ConfigData.statesPrefix + "." + ConfigData.RegulationState let priceLevel = getState(tibberID).val; let batsoc = Number(getState(batSocID).val) let OldRegulate = toBoolean(getState(RegulateID).val) //log("Tibber Preislevel: " + priceLevel + " OldRegulate: " + OldRegulate + " batsoc: " + (batsoc)) if ((tibberConfig.LevelToSwitch.includes(priceLevel))) { if (OldRegulate) { if (batsoc <= tibberConfig.BatMin) { setState(RegulateID, false); // Regulierung aus setState(tibberConfig.SwitchID, true) //Schalter einschalten log("Script abgeschaltet AC-Ladung Ein, weil priceLevel:" + priceLevel + " batsoc:" + batsoc + "%") } } else { if (batsoc >= tibberConfig.BatMax) { setState(RegulateID, true); // Regulierung an setState(tibberConfig.SwitchID, false) //Schalter ausschalten log(" Batterie bei BatMax. Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%") } } } else { if (!OldRegulate) { setState(RegulateID, true); // Regulierung an setState(tibberConfig.SwitchID, false) //Schalter ausschalten log("Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%") } } } else { //log("checkTibber skip. batsocID und/oder tibberID fehlen.") } } //*************************************************************
Tibber-Pulse als Smartmeter nutzen und lokal auslesen:
https://forum.iobroker.net/topic/70758/tibber-pulse-verbrauchsdaten-lokal-auslesenUnterstütze das Projekt 'ecoflow-connector'
Wenn dir das Script zur dynamischen Leistungsanpassung für den IObroker gefällt und du es nützlich findest, ziehe bitte in Erwägung, eine kleine Spende via PayPal zu hinterlassen.
Jeder Beitrag hilft, das Projekt am Laufen zu halten und weitere Updates zu ermöglichen.
Danke für deine Unterstützung!
Jetzt SpendenDieses Script wird bei Änderungen und Updates immer aktualisiert:
Nutzung auf eigene Gefahr 
- Installation von ioBroker und Skript unter UNRAID in nur 12 Minuten
- Video mit Erklärung der Basiskonfiguration
- Video mit Erklärung zu AdditionalPower und Überschussladung
Download (neues JS-Script in IOBroker anlegen und den Inhalt der Datei einfügen):
- 1.2.5.f1 Fork von Florian Vogt (25.06.2024)
Feature hinzugefügt, um die Größe der Delta-Speicher beim Ausbalancieren der Entladeleistung zu berücksichtigen, damit die Batterien gleichmäßig geleert werden.
Parameter battCapacity bei den Einstellungen für PowerStream = Kapazität der angeschlossenen Batterie in kWh, default = 1
ecoflow-connector_v125_mod_FV.txt (25.06.2024)
ältere Versionen:
- ecoflow-connector_v124.txt (22.04.2024)
- ecoflow-connector_v123.txt (21.02.2024)
- ecoflow-connector_v121_05.01.2024.txt
- ecoflow-connector_v12_.04.12.2023.txt
- ecoflow-connector_v1162_04.11.2023.txt
- ecoflow-connector_v115_02.10.2023.txt
- ecoflow-connector_v1142_26.09.2023
- ecoflow-connector_v1132_31.08.2023
- ecoflow-connector_v112_17.08.2023)
@waly_de
Coole Sache dieses Script, Gratulation!
Läuft auch bei mir, aber leider konnte ich meinen Stromzähler mangels „Scripting-Experience“ noch nicht einbinden. Die Daten von einem gPlugM Zähler kann ich per http abholen als json String im Format {... ,"i":115,"e":0, ...}, wobei "i" den Import in Watt und "e" den Export in Watt beinhaltet.Hat jemand einen Tipp für mich? Für Inputs bin dankbar!
Ich beobachte aber noch weiter..