NEWS
ecoflow-connector-Script zur dynamischen Leistungsanpassung
-
@19bobby65 Habe das Problem heute auch...ich habe nichts geändert zu gestern. Keine Ahnung, was sich zu gestern geändert hat und es heute nicht mehr funktioniert...ich schaue es mir heute am Abend noch mal an. Bin aktuell ratlos. Ich kann sehen, dass das Script den "Überschusswert" wieder nicht in das Writable übernimmt. Das Writable bleibt starr bei 200 stehen. Seltsam...
-
@ralf77 bitte editiere Deinen Beitrag und füge das Script als "CODE" ein.
Damit das so aussieht und lesbarer ist
-
@ralf77
deine Funktion startInterval()
wird niemals aufgerufen, darum startet die Regelung nicht.
Das muss aber auch nicht als Funktion definiert sein. Lass das einfach weg.:intervalId = setInterval(function () { let froniusValue = getState(vPower).val; // Wert vom Fronius Smartmeter if (froniusValue < 0) { powerValue += Math.abs(froniusValue); // Wenn der Wert negativ ist, addiere den absoluten Wert zum aktuellen Wert } else { powerValue -= Math.abs(froniusValue); // Wenn der Wert positiv ist, subtrahiere den Wert vom aktuellen Wert } if (powerValue < 200) { powerValue = 200; // Wenn der berechnete Wert negativ ist, setze den minimalen Wert von 200 } else if (powerValue > 2000) { powerValue = 1999; // Wenn der berechnete Wert größer als 2000 ist, setze den maximalen Wert von 1999 } setState(ecoflowObject, powerValue); // Wert in das Ecoflow-Objekt schreiben }, 60000); // alle 60 Sekunden
beim subtrahieren hast Du noch das Math.abs vergessen.
Ich hab die Funktion nicht getestet. Das ist nur das was mir beim drüber schauen aufgefallen ist.Wenn du die Berechnung die ich Dir empfohlen habe einbauen würdest, könntest du dir die Annäherung sparen, und die Ladeleistung wäre sofort die größtmögliche.
Das ist ChatGPT-Code, oder?
-
@waly_de Wie füge ich es als CODE ein??? Sorry...
-
@waly_de so einfach wie Du es beschrieben hast ist es meiner Meinung nach nicht...
Der Fronius Smart-Meter liefert ja einen "Minus-Wert", wenn Überschuss vorhanden ist. Daher muss ich ja den Minuswert in eine absolute Zahl wandeln und zum aktuellen Wert addieren.
Als Beispiel:
Ich habe als Start 200 Watt AC-Ladung- Smart-Meter liefert -300 (Überschuss)
- ich muss "-1(300)" zu den 200 addieren
- Neue AC-Ladeleistung = 500 Watt
Ich habe eine Aktuelle Ladeleistung von 500 Watt
- Smart Meter liefert 200 (Netzbezug)
- ich muss diesen Wert von den von den 500 Watt subtrahieren
-Neue AC-Ladeleistung = 200 Watt
...oder habe ich einen Denkfehler?
PS: Ja, ist 100% ChatGPT Code
-
@ralf77 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@waly_de so einfach wie Du es beschrieben hast ist es meiner Meinung nach nicht...
Ich denke doch. Klar, wenn du mit negativen Werten für den Überschuss arbeitest, musst du den einmal * -1 nehmen, oder aber den Wert der Ladeleistung Subtrahieren statt addieren.
Das hier kannst du mal versuchen. Ist nicht getestet, nur aus dem Kopf geschrieben. aber das Prinzip sollte klar sein..
// Funktion zum Abrufen und Umrechnen des Werts vom Fronius Smartmeter alle 60 Sekunden const EINSCHALT_POWER = 300 const AUSSCHALT_POWER = 0 let powerValue = 0 intervalId = setInterval(function () { const froniusValue = Math.floor(getState(vPower).val); // Wert vom Fronius Smartmeter const aktuelle_powerValue = getState(ecoflowObject).val const Entscheidungswert = (froniusValue * -1) + aktuelle_powerValue if (Entscheidungswert >= EINSCHALT_POWER){ powerValue = Entscheidungswert } if (powerValue > 0 && Entscheidungswert > AUSSCHALT_POWER){ powerValue = Entscheidungswert } if (Entscheidungswert <= AUSSCHALT_POWER){ powerValue = 0 } let setValue = powerValue //Wenn du die Werte in festen Schritten setzten wills, z.b. 100 w schritte dann kommentiere das hier noch ein: //setValue = setValue - (setValue % 100) if (setValue < 200) setValue = 200 if (setValue > 2000) setValue = 1999 setState(ecoflowObject, setValue); // Wert in das Ecoflow-Objekt schreiben }, 60000); // alle 60 Sekunden
@ralf77 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@waly_de Wie füge ich es als CODE ein??? Sorry...
Über dem Eingabefeld in das du im Forum schreibst sind Symbole. </> ist für Code.
Das generiert 2 Tags zwischen denen Du deinen Code einfügen kannst. Rechts siehst du wie es dann aussieht.
-
Ich arbeite gerade an einem Adapter um Powerstream und Powerstation als Geräte mit all ihren Werten in IOB zu haben.
Dann kommt man auch ohne script an die Daten und man entkoppelt die Logik von den Geräten.Im Grundsatz läuft es bei mir schon, allerdings habe ich nur eine Delta Max.
Die Datenpunkte der anderen Powerstations, die ich so gefunden habe, scheinen mir unvollständig.
Deswegen hier mal meine Frage an Euch, ob ihr mir die payload von Delta, Delta2, Delta2Max, DeltaPro schicken könnt, die beim Abo auf '/app/device/property/' + powerstationId' über mqtt hereinkommen.
Das wär super.Wenn ich das dann drin habe, werde ich einen extra Thema für den Adapter aufmachen.
Gruß
Klaus -
@foxthefox
Kann ich gerne für die Delta Pro schicken.
Gibt es eine andere Möglichkeit für Laien wie mich, als Screenshots der Ordner samt Inhalt zu schicken? -
@umele sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@foxthefox
Kann ich gerne für die Delta Pro schicken.
Gibt es eine andere Möglichkeit für Laien wie mich, als Screenshots der Ordner samt Inhalt zu schicken?also screenshot nützt mir nix, da muß ich ja alles abtippen.
eventuell klappt es mit nodered am einfachsten, ich denk mal drüber nach und melde mich nochmal
-
Habe vielleicht die passende Lösung für den Export:
Auf Expertenmodus umgeschaltet. Dann kommen 2 Pfeil-Icons, mit deren Hilfe ich die gesamte Struktur (der Delta Pro) als JSON runterladen konnte.
Blöderweise kann ich die Datei nicht hier uploaden - weder als JSON, noch als txt oder .zipJemand eine Idee?
Im Notfall schicke ich es in Portionen als Posts...ERLEDIGT - in Portionen weiter unten geschickt.
-
@foxthefox
Die Datei war wohl zu gross... Drum jetzt nach und nach in Portionen.0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.mppt.json
0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.pd.json
0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.inv.json
-
0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.ems.json
0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.bmsSlave2.json
0_userdata.0.ecoflow.app_device_property_DCEBZxxxx.data.params.bmsMaster.json
Und hier noch die Parameter, die weiter oben in der Struktur liegen:
Das ist dann alles von der Delta Pro."0_userdata.0.ecoflow.app_device_property_DCEBxxxx.RAW": { "common": { "name": "RAW", "role": "state", "read": true, "write": true, "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693598, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.RAW" }, "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data": { "type": "folder", "common": { "name": "data" }, "native": { "autocreated": "by automatic ensure logic" }, "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693791, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data" }, "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.addr": { "common": { "name": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.addr", "role": "state", "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693736, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.addr" }, "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdFunc": { "common": { "name": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdFunc", "role": "state", "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693736, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdFunc" }, "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdId": { "common": { "name": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdId", "role": "state", "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693736, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.cmdId" }, "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.id": { "common": { "name": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.id", "role": "state", "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693736, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.id" "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.version": { "common": { "name": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.version", "role": "state", "type": "mixed" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1697546693736, "_id": "0_userdata.0.ecoflow.app_device_property_DCEBxxxx.data.version"
-
ich hab nen flow erstellt
[ { "id": "5c3a7efbb734c312", "type": "tab", "label": "Flow EF_Data", "disabled": false, "info": "", "env": [] }, { "id": "5b6c19b0a776f928", "type": "mqtt in", "z": "5c3a7efbb734c312", "name": "", "topic": "/app/device/property/DAEBZ5Zxxxxxx", "qos": "2", "datatype": "json", "broker": "4a025f91e9595714", "nl": false, "rap": true, "rh": 0, "inputs": 0, "x": 520, "y": 160, "wires": [ [ "cdac5c07a612f81c" ] ] }, { "id": "cdac5c07a612f81c", "type": "debug", "z": "5c3a7efbb734c312", "name": "debug 1", "active": true, "tosidebar": true, "console": false, "tostatus": false, "complete": "false", "statusVal": "", "statusType": "auto", "x": 820, "y": 160, "wires": [] }, { "id": "773fab09ddaa9e53", "type": "inject", "z": "5c3a7efbb734c312", "name": "connect", "props": [ { "p": "action", "v": "connect", "vt": "str" }, { "p": "topic", "vt": "str" } ], "repeat": "", "crontab": "", "once": false, "onceDelay": 0.1, "topic": "", "x": 220, "y": 240, "wires": [ [ "d5d7e8960ba14429" ] ] }, { "id": "671e0ceff575862c", "type": "inject", "z": "5c3a7efbb734c312", "name": "disconnect", "props": [ { "p": "action", "v": "disconnect", "vt": "str" }, { "p": "topic", "vt": "str" } ], "repeat": "", "crontab": "", "once": false, "onceDelay": 0.1, "topic": "", "x": 220, "y": 300, "wires": [ [ "d5d7e8960ba14429" ] ] }, { "id": "d5d7e8960ba14429", "type": "mqtt out", "z": "5c3a7efbb734c312", "name": "ef-mqtt", "topic": "", "qos": "", "retain": "", "respTopic": "", "contentType": "", "userProps": "", "correl": "", "expiry": "", "broker": "4a025f91e9595714", "x": 420, "y": 240, "wires": [] }, { "id": "4a025f91e9595714", "type": "mqtt-broker", "name": "ecoflow", "broker": "mqtts://mqtt.ecoflow.com:8883", "port": "8883", "clientid": "ANDROID_xxxxx", "autoConnect": false, "usetls": false, "protocolVersion": "4", "keepalive": "60", "cleansession": true, "autoUnsubscribe": true, "birthTopic": "", "birthQos": "0", "birthRetain": "false", "birthPayload": "", "birthMsg": {}, "closeTopic": "", "closeQos": "0", "closeRetain": "false", "closePayload": "", "closeMsg": {}, "willTopic": "", "willQos": "0", "willRetain": "false", "willPayload": "", "willMsg": {}, "userProps": "", "sessionExpiry": "" } ]
Das müsste in nodered importiert werden.
mqtt-in braucht dann die richtige Seriennummermqtt-broker
- in der ersten Lasche den ANDROID Wert ändern
- in der Lasche Sicherheit, user und pw eingeben
Falls die Werte nicht bekannt sind:
wie auch hier post schonmal das besagte script https://github.com/mmiller7/ecoflow-withoutflow/blob/main/cloud-mqtt/ecoflow_get_mqtt_login.sh
oder website https://energychain.github.io/site_ecoflow_mqtt_credentials/Mit den beiden injects, lässt sich die Verbindung starten und stoppen
Was dann interessant ist, ist unter debug die Meldung ausklappen und bei params ergibt sich ein Baum mit pd..., ems...
Davon bräuchte ich jeweils einen Typ als Kopie.Gruß
Klaus -
@umele
Danke schonmal. -
-
@foxthefox said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hiermit habe ich user und pw rausgefunden.
website https://energychain.github.io/site_ecoflow_mqtt_credentials/
Hoffe, die Android Client ID hier stimmt.
Mein Problem:
Ich kann den Flow nicht starten. Deploy klappt ohne Fehler.
So sieht es aus, wenn ich den ersten Inject starten will:
-
@Waly_de Ich schreib jetzt mal wieder in the thread.
Bin jetzt nicht so code versiert, habe aber ChatGPT mal um Rat gefragt
Und das hier ist rausgekommen:
const axios = require('axios');
axios.get('https://api.sunrise-sunset.org/json?lat=48.134722&lng=11.695556')
.then(response => {
let sunrise = new Date(response.data.results.sunrise);
let sunset = new Date(response.data.results.sunset);
let now = new Date();if (now >= sunrise && now <= sunset) { let priceLevel = getState('tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level'); if (priceLevel === 'CHEAP' || priceLevel === 'VERY_CHEAP') { setState('0_userdata.0.ecoflow.app_1655917002031407105_HW51ZOH4SF540658_thing_property_set.writeables.SetPrio', 1); // Set to Battery prio mode } else { setState('0_userdata.0.ecoflow.app_1655917002031407105_HW51ZOH4SF540658_thing_property_set.writeables.SetPrio', 0); // Set to Power Supply prio mode } } });
Kommt das so hin? Vielleicht frage ich ein bisschen kompliziert nach Sonnenaufgang und Sonnenuntergang, das könnte man noch optimieren.
HIntergrund ist, ich möchte wenn der Tibber Pricelevel bei CHEAP oder VERY_CHEAP ist, dass die nur die Batterie geladen wird, bei allen anderen Price Level soll in den Strom-Modus geschalten werden. Batterie Modus soll nur unter Tags erfolgen.
Kannst Du mir hier helfen bzw. ggf. das Script optimieren und mir sagen, wo ich das einfügen soll? Ich habe es jetzt in Zeile 1857 eingefügt.
Danke Dir.
-
@umele sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@foxthefox said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hiermit habe ich user und pw rausgefunden.
website https://energychain.github.io/site_ecoflow_mqtt_credentials/
Hoffe, die Android Client ID hier stimmt.
Mein Problem:
Ich kann den Flow nicht starten. Deploy klappt ohne Fehler.
So sieht es aus, wenn ich den ersten Inject starten will:
Im oberen Knoten ist der subscription text nicht passig.
Da sollte unter Topic der Text mit /app/device/property/ anfangen und dann kommt die Seriennummer DCEB...Dann auch nochmal neben ecoflow auf den Stift klicken
und hier die Einstellung clientID (das mit dem Android) einstellen
und dann in der Lasche Sicherheit die beiden
Benutzername ist "app-...."
Passwort in deinem Fall das mit "f3690...."
Dann sollte es klappen.
Gruß
Klaus -
@foxthefox
Hab die Anpassungen gemacht - leider mit diesem Ergebnis:
Kann den Inject starten - es kommt aber nichts im Debug-Window...Ich vermute, dass der MQTT-Client von website https://energychain.github.io/site_ecoflow_mqtt_credentials/ nicht stimmt.
Der mittlere Teil ändert sich mit jeder Anfrage...
Das Script für die Abfrage des MQTT-Client kann ich leider nicht benutzen, weil ich kein Linux habe. Hoffe, Du kannst was mit den JSON-Dateien anfangen, die ich geschickt habe.Gruss,
ChrisUpdate: den MQTT-Client habe ich jetzt dank dem Script von @Waly_de gefunden.
Im Script Version 1.1.5 Zeile 1061. Den auskommentierten Block aktivieren - dann kommt die ID raus. Ändert aber nichts am Ergebnis... -
@waly_de sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hallo, funktioniert leider auch nicht, die AC leistung wird zwar angepasst und geschrieben aber nur für eine Sekunde fällt dann aber sofort immer wieder auf 200 Watt zurück.