Skip to content
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. ecoflow-connector-Script zur dynamischen Leistungsanpassung

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.2k

ecoflow-connector-Script zur dynamischen Leistungsanpassung

Geplant Angeheftet Gesperrt Verschoben JavaScript
1.6k Beiträge 127 Kommentatoren 741.9k Aufrufe 127 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • W Waly_de

    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 3EM

    Tibber-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-auslesen

    Das 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:
    Bildschirmfoto 2023-09-04 um 09.55.08.jpg
    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")

    Bildschirmfoto 2023-07-17 um 10.56.49.jpg

    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-auslesen

    Unterstü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 Spenden

    Dieses Script wird bei Änderungen und Updates immer aktualisiert:
    Nutzung auf eigene Gefahr !

    [Bildschirmfoto 2024-03-29 um 09.37.51.jpg

    • 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):

    • ecoflow-connector_v125.txt (13.05.2024)
    • 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)
    A Offline
    A Offline
    aherby
    schrieb am zuletzt editiert von
    #681

    @waly_de Auch wenn es vielleicht mittlerweile überflüssig geworden sein könnte.
    Gestern habe ich mal kurz mit dem "chgPauseFlag" gespielt, ich mal meine Delta 2 Max
    über AC 230 V geladen habe.
    Tatsächlich wurde die AC-Ladung unterbrochen. Jedoch war ich beim zurücksetzen auf den Wert "0" überrascht, dass nicht sofort das Laden wieder begonnen hat.
    Muss ich aber noch ausführlicher testen.

    Ich rede von diesem Objekt / Wert

    0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag
    
    W 1 Antwort Letzte Antwort
    0
    • A aherby

      @waly_de Auch wenn es vielleicht mittlerweile überflüssig geworden sein könnte.
      Gestern habe ich mal kurz mit dem "chgPauseFlag" gespielt, ich mal meine Delta 2 Max
      über AC 230 V geladen habe.
      Tatsächlich wurde die AC-Ladung unterbrochen. Jedoch war ich beim zurücksetzen auf den Wert "0" überrascht, dass nicht sofort das Laden wieder begonnen hat.
      Muss ich aber noch ausführlicher testen.

      Ich rede von diesem Objekt / Wert

      0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag
      
      W Offline
      W Offline
      Waly_de
      schrieb am zuletzt editiert von
      #682

      @aherby Danke. Das wäre auf jeden Fall interessant zu wissen. Wenn ich das richtig verstehe, könnte man sich damit den Zwischenstecker zum Abschalten des Ladens sparen, oder?

      A 1 Antwort Letzte Antwort
      0
      • W Waly_de

        @aherby Danke. Das wäre auf jeden Fall interessant zu wissen. Wenn ich das richtig verstehe, könnte man sich damit den Zwischenstecker zum Abschalten des Ladens sparen, oder?

        A Offline
        A Offline
        aherby
        schrieb am zuletzt editiert von
        #683

        @waly_de Ja, unterbrechen hat sofort geklappt. Nur bin ich mir nicht sicher ob das Einschalten durch die Ecoflow eigene Möglichkeit Laden über AC 230 V Funktion dann erstmal nicht immer funktioniert hat oder ich zu ungeduldig war.
        Hatte gestern auch nicht viel Zeit um es ausführlich mit Log-Einträgen zu testen.
        Komme ich vielleicht nächste Woche dazu.

        A 1 Antwort Letzte Antwort
        0
        • F Abwesend
          F Abwesend
          foxthefox
          Developer
          schrieb am zuletzt editiert von
          #684

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

          @foxthefox
          Zusatzinfo:
          Bei meiner Abfrage war der Zusatzakku an Port 2 der Delta Pro angeschlossen.
          Nehme an, dass ein Zusatzakku an Port 1 "bmsSlave1" heißen würde. Bin aber gerade unterwegs und kann das nicht prüfen.

          Gebe Bescheid, wenn ich das nachprüfen konnte.

          Gruss,
          Chris

          Hätte ich jetzt auch so vermutet.

          Gruß
          Klaus

          Adapterüberblick: Profil Github;

          Wenn der Adapter gefällt und nützlich ist, bitte ins Repo gehen und Star setzen. Danke

          Ein Aufruf: video

          D 1 Antwort Letzte Antwort
          0
          • F foxthefox

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

            @foxthefox
            Zusatzinfo:
            Bei meiner Abfrage war der Zusatzakku an Port 2 der Delta Pro angeschlossen.
            Nehme an, dass ein Zusatzakku an Port 1 "bmsSlave1" heißen würde. Bin aber gerade unterwegs und kann das nicht prüfen.

            Gebe Bescheid, wenn ich das nachprüfen konnte.

            Gruss,
            Chris

            Hätte ich jetzt auch so vermutet.

            Gruß
            Klaus

            D Offline
            D Offline
            Dreffi
            schrieb am zuletzt editiert von
            #685

            Hat hier noch jemand massive Probleme mit der Cloud?
            Das Script bekommt meine Geräte nicht mehr geregelt, weil die Werte gar nicht oder nur sehr zeitverzögert übernommen werden.

            In der App (iOS) erhalte ich seit gestern diese Fehlermeldung:
            IMG_5197.jpeg

            Werte ändern ist praktisch nur noch per Bluetooth möglich indem ich den Repeater der Ecoflow Geräte ausschalte.

            1 Antwort Letzte Antwort
            0
            • F Abwesend
              F Abwesend
              foxthefox
              Developer
              schrieb am zuletzt editiert von
              #686

              @dreffi
              alles normal bei mir, keine Verbindungsprobleme

              Adapterüberblick: Profil Github;

              Wenn der Adapter gefällt und nützlich ist, bitte ins Repo gehen und Star setzen. Danke

              Ein Aufruf: video

              D 1 Antwort Letzte Antwort
              0
              • F foxthefox

                @dreffi
                alles normal bei mir, keine Verbindungsprobleme

                D Offline
                D Offline
                Dreffi
                schrieb am zuletzt editiert von
                #687

                @foxthefox
                Danke für die Rückmeldung. Momentan läufts hier auch wieder. Das Problem trat gestern und heute während des Tages auf.

                Im Verlauf ist es bei mir gut erkennbar, weil der Bezug dann teilweise für längere Zeit negativ wird, da die Powerstreams nicht nachgeregelt werden.

                @Waly_de
                Sollte das Problem wieder auftreten, würde ich als quick fix die Regelfrequenz des scripts gerne drosseln, da die Änderungen eh nicht so schnell übernommen werden und dann alles durcheinander kommt.
                An welcher Stelle bzw. in welcher Funktion kann ich das anpassen? Ich würde gerne statt alle 30s nur z.B. alle 5 oder 15 Minuten den Einspeisewert aktualisieren lassen. Die möglichen Nebenwirkungen sind mir bewusst…

                1 Antwort Letzte Antwort
                0
                • P Offline
                  P Offline
                  Ponti92
                  schrieb am zuletzt editiert von
                  #688

                  Heute gab es ein neues Powerstream Update und das Skript läuft noch ohne Probleme!
                  Anscheinend soll das Problem der D2M bei wechselnder Bewölkung behoben sein.
                  Ich beobachte mal morgen, aber hoffentlich läuft es dann wieder 🙂

                  1 Antwort Letzte Antwort
                  0
                  • S Offline
                    S Offline
                    sirdir
                    schrieb am zuletzt editiert von
                    #689

                    Das Update hab ich leider nicht bekommen, obwohl man mich die ganze Woche darauf vertröstet hat (hab ein Downgrade bekommen, das das ganze System ausser Betrieb gesetzt hat)...
                    Anyways, ich glaub ich hab nen Bug gefunden:
                    Sobald man MinValueMin per externer config auf 0 setzt, kommt:

                    2023-10-27 20:16:57.194  - info: javascript.0 (1836) script.js.Powerstrean_4_10: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                    

                    Wird der Wert konventionell auf 0 gesetzt, klappt alles. Ich hab noch nicht nachgeschaut, woran das liegen kann.

                    W 1 Antwort Letzte Antwort
                    0
                    • A aherby

                      @waly_de Ja, unterbrechen hat sofort geklappt. Nur bin ich mir nicht sicher ob das Einschalten durch die Ecoflow eigene Möglichkeit Laden über AC 230 V Funktion dann erstmal nicht immer funktioniert hat oder ich zu ungeduldig war.
                      Hatte gestern auch nicht viel Zeit um es ausführlich mit Log-Einträgen zu testen.
                      Komme ich vielleicht nächste Woche dazu.

                      A Offline
                      A Offline
                      aherby
                      schrieb am zuletzt editiert von aherby
                      #690

                      @Waly_de Ich habe gestern Abend mal mit der Delta 2 Max weiter gespielt oder getestet.
                      Also "chgPauseFlag" funktioniert immer, dass das Laden mit setzen vom Wert "1" gestoppt wird.

                      0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag 
                      

                      Setzt man den Wert wieder zurück auf "0" startet aber die Ladung nicht mehr, erstmal.
                      Ich kann zwar mit

                      slowChgWatts
                      

                      die Ladewerte verändern, aber die Ladung startet nicht!
                      Komischerweise wenn ich den AC-Ladewert in der App ändere, startet die Ladung sofort wieder.
                      Ein Workaround habe ich erstmal mit der in der App verfügbaren Funktion
                      der Delta 2 Max gefunden.

                      Lab-Funktion ->Automatisierung -> "Laden über Wechselstrom" eingeschaltet ist.
                      

                      Nur war ich mir gestern Abend nicht sicher, ob es immer zu 100% funktioniert.
                      Bisher würde ich sagen zu 80-90%.

                      Kann das vielleicht noch wer mal bitte testen oder bestätigen?
                      Dankeschön

                      F S W 3 Antworten Letzte Antwort
                      0
                      • A aherby

                        @Waly_de Ich habe gestern Abend mal mit der Delta 2 Max weiter gespielt oder getestet.
                        Also "chgPauseFlag" funktioniert immer, dass das Laden mit setzen vom Wert "1" gestoppt wird.

                        0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag 
                        

                        Setzt man den Wert wieder zurück auf "0" startet aber die Ladung nicht mehr, erstmal.
                        Ich kann zwar mit

                        slowChgWatts
                        

                        die Ladewerte verändern, aber die Ladung startet nicht!
                        Komischerweise wenn ich den AC-Ladewert in der App ändere, startet die Ladung sofort wieder.
                        Ein Workaround habe ich erstmal mit der in der App verfügbaren Funktion
                        der Delta 2 Max gefunden.

                        Lab-Funktion ->Automatisierung -> "Laden über Wechselstrom" eingeschaltet ist.
                        

                        Nur war ich mir gestern Abend nicht sicher, ob es immer zu 100% funktioniert.
                        Bisher würde ich sagen zu 80-90%.

                        Kann das vielleicht noch wer mal bitte testen oder bestätigen?
                        Dankeschön

                        F Abwesend
                        F Abwesend
                        foxthefox
                        Developer
                        schrieb am zuletzt editiert von
                        #691

                        @aherby
                        an so einem Wert bin ich für die DELTA MAX interessiert.
                        Mit der uralten FW funktioniert die Homeassistant Implementierung und dort gibt es einen Schalter AC Charge.
                        Dieser lässt sich wunderbar für überschüssiges AC laden der Powerstation nutzen.
                        Ich hatte dauerhaft am AC Ausgang den Kühlschrank dran und über MPPT Eingang wurde aufgeladen.
                        Mit dem Zuschalten von AC Versorgung konnte man über diesen besagten Schalter Laden oder auch in Bypass gehen.

                        Also in der direkten Kommunikation (alteFW) hängt AC Charge irgendwie an einem "ac_pause" und wie das in ein Kommando überführt wird ist mir noch unklar.
                        Aber immerhin stimmt z.B. id=66 für AC-Enable und Xboost überein.
                        Leider wird bei der direkten Kommunikation kein mqqt set ausgelöst, welches man sehen könnte.

                        Ich würde vermuten, daß es bei DELTA MAX am cfgAcEnabled gekoppelt ist.

                        Weiß jemand mehr?

                        Gruß
                        Klaus

                        Adapterüberblick: Profil Github;

                        Wenn der Adapter gefällt und nützlich ist, bitte ins Repo gehen und Star setzen. Danke

                        Ein Aufruf: video

                        1 Antwort Letzte Antwort
                        0
                        • A aherby

                          @Waly_de Ich habe gestern Abend mal mit der Delta 2 Max weiter gespielt oder getestet.
                          Also "chgPauseFlag" funktioniert immer, dass das Laden mit setzen vom Wert "1" gestoppt wird.

                          0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag 
                          

                          Setzt man den Wert wieder zurück auf "0" startet aber die Ladung nicht mehr, erstmal.
                          Ich kann zwar mit

                          slowChgWatts
                          

                          die Ladewerte verändern, aber die Ladung startet nicht!
                          Komischerweise wenn ich den AC-Ladewert in der App ändere, startet die Ladung sofort wieder.
                          Ein Workaround habe ich erstmal mit der in der App verfügbaren Funktion
                          der Delta 2 Max gefunden.

                          Lab-Funktion ->Automatisierung -> "Laden über Wechselstrom" eingeschaltet ist.
                          

                          Nur war ich mir gestern Abend nicht sicher, ob es immer zu 100% funktioniert.
                          Bisher würde ich sagen zu 80-90%.

                          Kann das vielleicht noch wer mal bitte testen oder bestätigen?
                          Dankeschön

                          S Offline
                          S Offline
                          sirdir
                          schrieb am zuletzt editiert von
                          #692

                          @aherby Selbes Problem wenn man die slowChgWatts ändert, die Ladung stoppt sofort…

                          1 Antwort Letzte Antwort
                          0
                          • W Waly_de

                            @karo2204
                            Das sieht doch ganz gut aus... Wenn das ermitteln der Zeiten funktioniert...

                            allerdings gibt es das schon im Script. Dort findest du die Funktion

                            istTag(0)

                            Die True ist, wenn es gerade Tag ist mit dem Parameter kannst du den Sonnenuntergang noch verschieben. (in Minuten) istTag(60) Wäre erst eine Stunde nach Sonnenuntergang False.

                            Nur würde ich nicht einfach den Powermode schalten, denn dann überschreibt das Script das wieder.

                            Setze in der Konfiguration:

                            RegulationOffPower: -2 //Das Schaltet den Priomode, wenn du die Regulation ausschaltest
                            RegulationState: "Regulate" // Erzeugt der State zum Ein und Aus-Schalten der Regulation

                            dann Dein Script:

                            
                                if (istTag(0)) {
                                    let priceLevel = getState('tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level');
                             
                                    if (priceLevel === 'CHEAP' || priceLevel === 'VERY_CHEAP') {
                                        setState('0_userdata.0.ecoflow.Regulate', false);  // Set to Battery prio mode
                                     } else {
                                         setState('0_userdata.0.ecoflow.Regulate', true);  // Set to Power Supply prio mode
                                     }
                                 }
                             });
                            

                            das sollte funktionieren

                            Allerdings musst du das noch in einen Timer packen, so dass es in regelmäßigen Abständen ausgeführt und geprüft wird.

                            // alle 60 Sekunden den Tarif prüfen
                            var CheckTibber = setInterval(function () {
                             if (istTag(0)) {
                                    let priceLevel = getState('tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level');
                             
                                    if (priceLevel === 'CHEAP' || priceLevel === 'VERY_CHEAP') {
                                        setState('0_userdata.0.ecoflow.Regulate', false);  // Set to Battery prio mode
                                     } else {
                                         setState('0_userdata.0.ecoflow.Regulate', true);  // Set to Power Supply prio mode
                                     }
                                 }
                             });
                               
                            }, 60 * 1000);
                            
                            K Offline
                            K Offline
                            karo2204
                            schrieb am zuletzt editiert von karo2204
                            #693

                            @Waly_de Danke Dir. Ich werde das mal probieren.

                            UPDATE: Soweit hat es funktioniert. Allerdings sobald man dann z.B. die Waschmaschine anwirft ( über 600W) speist er wieder vom Akku ein. Wenn man es weiss ist es ja kein Thema. Dann muss ich meine Wasch-Zeiten halt auf den frühen Morgen ändern.


                            Ich hatte zwischenzeitlich mal ChatGPT gefragt, und Deinen Code durch diesen ersetzt:

                            // Define Constants
                            const CHEAP_LEVELS = ['CHEAP', 'VERY_CHEAP'];
                            
                            // Function to check if it's daytime
                            function isDaytime() {
                                const now = new Date();
                                const sunrise = new Date(SunTimes(0));
                                const sunset = new Date(SunTimes(1));
                                return now >= sunrise && now <= sunset;
                            }
                            
                            // Function to check price level and time of day
                            function checkPriceAndTimeOfDay(priceLevel) {
                                if (isDaytime() && CHEAP_LEVELS.includes(priceLevel)) {
                                    for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                        if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                            const asn = ConfigData.seriennummern[i].seriennummer;
                                            setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "1", false);
                                        }
                                    }
                                } else {
                                    for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                        if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                            const asn = ConfigData.seriennummern[i].seriennummer;
                                            setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "0", false);
                                        }
                                    }
                                }
                            }
                            
                            // Regulation State
                            if (ConfigData.RegulationState != "") {
                                let eventid = ConfigData.statesPrefix + '.' + ConfigData.RegulationState;
                                ConfigData.Regulation = Boolean(getStateCr(eventid, ConfigData.Regulation, true).val);
                                on({ id: eventid, change: "any", ack: false }, function (obj) {
                                    let name = obj.id.split('.').pop();
                                    // log(name + ":" + obj.state.val);
                                    for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                        if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                            const asn = ConfigData.seriennummern[i].seriennummer;
                                            var foundItem = ConfigData.seriennummern.find(item => item.seriennummer === asn);
                                            if (foundItem.RegulationOffPower >= 0 && !obj.state.val) {
                                                setAC(asn, foundItem.RegulationOffPower * 10);
                                                GlobalObj[asn].OldNewValue = 0;
                                            } else if (foundItem.RegulationOffPower == -2 && !obj.state.val) {
                                                log("Regulation Off, PrioMode On für:" + asn);
                                                setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "1", false);
                                            } else if (foundItem.RegulationOffPower == -2 && obj.state.val) {
                                                log("Regulation On, PrioMode Off für:" + asn);
                                                setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "0", false);
                                            }
                                        }
                                    }
                                    ConfigData.Regulation = Boolean(obj.state.val);
                                });
                            
                                // Listener for CurrentPrice.level changes
                                on({ id: 'tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level', change: "any", ack: false }, function (obj) {
                                    checkPriceAndTimeOfDay(obj.state.val);
                                });
                            
                                // Initialize with the current price level
                                const initialPriceLevel = getState('tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level').val;
                                checkPriceAndTimeOfDay(initialPriceLevel);
                            }
                            

                            Ich dachte mir, dass er Deine Logik nehmen soll, wenn die Preise nicht die definierten Level haben.

                            ioBroker
                            Tibber
                            Ecoflow Powerstream & Delta Max 2000

                            W 1 Antwort Letzte Antwort
                            0
                            • K karo2204

                              @Waly_de Danke Dir. Ich werde das mal probieren.

                              UPDATE: Soweit hat es funktioniert. Allerdings sobald man dann z.B. die Waschmaschine anwirft ( über 600W) speist er wieder vom Akku ein. Wenn man es weiss ist es ja kein Thema. Dann muss ich meine Wasch-Zeiten halt auf den frühen Morgen ändern.


                              Ich hatte zwischenzeitlich mal ChatGPT gefragt, und Deinen Code durch diesen ersetzt:

                              // Define Constants
                              const CHEAP_LEVELS = ['CHEAP', 'VERY_CHEAP'];
                              
                              // Function to check if it's daytime
                              function isDaytime() {
                                  const now = new Date();
                                  const sunrise = new Date(SunTimes(0));
                                  const sunset = new Date(SunTimes(1));
                                  return now >= sunrise && now <= sunset;
                              }
                              
                              // Function to check price level and time of day
                              function checkPriceAndTimeOfDay(priceLevel) {
                                  if (isDaytime() && CHEAP_LEVELS.includes(priceLevel)) {
                                      for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                          if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                              const asn = ConfigData.seriennummern[i].seriennummer;
                                              setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "1", false);
                                          }
                                      }
                                  } else {
                                      for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                          if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                              const asn = ConfigData.seriennummern[i].seriennummer;
                                              setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "0", false);
                                          }
                                      }
                                  }
                              }
                              
                              // Regulation State
                              if (ConfigData.RegulationState != "") {
                                  let eventid = ConfigData.statesPrefix + '.' + ConfigData.RegulationState;
                                  ConfigData.Regulation = Boolean(getStateCr(eventid, ConfigData.Regulation, true).val);
                                  on({ id: eventid, change: "any", ack: false }, function (obj) {
                                      let name = obj.id.split('.').pop();
                                      // log(name + ":" + obj.state.val);
                                      for (var i = 0; i < ConfigData.seriennummern.length; i++) {
                                          if (ConfigData.seriennummern[i].typ == "PS" && ConfigData.seriennummern[i].seriennummer != "XXXXXXXXXXXXX") {
                                              const asn = ConfigData.seriennummern[i].seriennummer;
                                              var foundItem = ConfigData.seriennummern.find(item => item.seriennummer === asn);
                                              if (foundItem.RegulationOffPower >= 0 && !obj.state.val) {
                                                  setAC(asn, foundItem.RegulationOffPower * 10);
                                                  GlobalObj[asn].OldNewValue = 0;
                                              } else if (foundItem.RegulationOffPower == -2 && !obj.state.val) {
                                                  log("Regulation Off, PrioMode On für:" + asn);
                                                  setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "1", false);
                                              } else if (foundItem.RegulationOffPower == -2 && obj.state.val) {
                                                  log("Regulation On, PrioMode Off für:" + asn);
                                                  setStateNE(ConfigData.statesPrefix + '.app_' + mqttDaten.UserID + '_' + asn + '_thing_property_set.writeables.SetPrio', "0", false);
                                              }
                                          }
                                      }
                                      ConfigData.Regulation = Boolean(obj.state.val);
                                  });
                              
                                  // Listener for CurrentPrice.level changes
                                  on({ id: 'tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level', change: "any", ack: false }, function (obj) {
                                      checkPriceAndTimeOfDay(obj.state.val);
                                  });
                              
                                  // Initialize with the current price level
                                  const initialPriceLevel = getState('tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level').val;
                                  checkPriceAndTimeOfDay(initialPriceLevel);
                              }
                              

                              Ich dachte mir, dass er Deine Logik nehmen soll, wenn die Preise nicht die definierten Level haben.

                              W Offline
                              W Offline
                              Waly_de
                              schrieb am zuletzt editiert von
                              #694

                              @karo2204 oha... das ist schon beeindruckend, was da so raus kommt... aber ich denke das ist ein wenig über das Ziel hinaus, weil er Teile meines Skriptes übernommen hat, die aber schon im Code vorhanden sind... ich weiss nicht wie das nun zusammen gebracht wurde.

                              Hatte meine kurze Version nicht funktioniert? Die dürfte nichts einspeisen, es sein denn die Waschmaschine hängt an einer Smartplug....

                              K 1 Antwort Letzte Antwort
                              0
                              • A aherby

                                @Waly_de Ich habe gestern Abend mal mit der Delta 2 Max weiter gespielt oder getestet.
                                Also "chgPauseFlag" funktioniert immer, dass das Laden mit setzen vom Wert "1" gestoppt wird.

                                0_userdata.0.ecoflow.app_xxxxx_thing_property_set.writeables.chgPauseFlag 
                                

                                Setzt man den Wert wieder zurück auf "0" startet aber die Ladung nicht mehr, erstmal.
                                Ich kann zwar mit

                                slowChgWatts
                                

                                die Ladewerte verändern, aber die Ladung startet nicht!
                                Komischerweise wenn ich den AC-Ladewert in der App ändere, startet die Ladung sofort wieder.
                                Ein Workaround habe ich erstmal mit der in der App verfügbaren Funktion
                                der Delta 2 Max gefunden.

                                Lab-Funktion ->Automatisierung -> "Laden über Wechselstrom" eingeschaltet ist.
                                

                                Nur war ich mir gestern Abend nicht sicher, ob es immer zu 100% funktioniert.
                                Bisher würde ich sagen zu 80-90%.

                                Kann das vielleicht noch wer mal bitte testen oder bestätigen?
                                Dankeschön

                                W Offline
                                W Offline
                                Waly_de
                                schrieb am zuletzt editiert von Waly_de
                                #695

                                @aherby hmm ich denke das hängt mit diesen 255'er Werten zusammen die teilweise mit gesendet werden... es ist blöd, denn wenn ich eine Delta 2 Max hier hätte, könnte ich das wahrscheinlich schnell lösen. Aber so ist das echt schwierig.

                                ich schicke gleich in diesem Beitrag mal eine neue Version vom Script. Ich habe (ohne es testen zu können) mal versucht die 255 Werte zu berücksichtigen und nicht mit den Werten aus den States zu überschreiben.

                                Neue Version: ecoflow-connector_v116.txt

                                S A 2 Antworten Letzte Antwort
                                0
                                • S sirdir

                                  Das Update hab ich leider nicht bekommen, obwohl man mich die ganze Woche darauf vertröstet hat (hab ein Downgrade bekommen, das das ganze System ausser Betrieb gesetzt hat)...
                                  Anyways, ich glaub ich hab nen Bug gefunden:
                                  Sobald man MinValueMin per externer config auf 0 setzt, kommt:

                                  2023-10-27 20:16:57.194  - info: javascript.0 (1836) script.js.Powerstrean_4_10: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                                  

                                  Wird der Wert konventionell auf 0 gesetzt, klappt alles. Ich hab noch nicht nachgeschaut, woran das liegen kann.

                                  W Offline
                                  W Offline
                                  Waly_de
                                  schrieb am zuletzt editiert von Waly_de
                                  #696

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

                                  @Waly_de
                                  Sollte das Problem wieder auftreten, würde ich als quick fix die Regelfrequenz des scripts gerne drosseln, da die Änderungen eh nicht so schnell übernommen werden und dann alles durcheinander kommt.
                                  An welcher Stelle bzw. in welcher Funktion kann ich das anpassen? Ich würde gerne statt alle 30s nur z.B. alle 5 oder 15 Minuten den Einspeisewert aktualisieren lassen. Die möglichen Nebenwirkungen sind mir bewusst…

                                  /*=======================================================
                                    =========             Timer               ============
                                    =======================================================*/
                                  //jede x Sekunden
                                  var intervalID = setInterval(function () {
                                      if (true || istTag()) {
                                          CheckforReconnect(function () {
                                              //SetBasePower(GetNextAsn());
                                              SetBasePower()
                                          });
                                      } else {
                                          ////SetBasePower(firstPsSn);
                                      }
                                  }, 10 * 1000);
                                  

                                  10 * 1000 heisst alle 10 Sekunden.
                                  30 * 1000 wären alle 30 Sekunden

                                  1 Antwort Letzte Antwort
                                  1
                                  • W Waly_de

                                    @karo2204 oha... das ist schon beeindruckend, was da so raus kommt... aber ich denke das ist ein wenig über das Ziel hinaus, weil er Teile meines Skriptes übernommen hat, die aber schon im Code vorhanden sind... ich weiss nicht wie das nun zusammen gebracht wurde.

                                    Hatte meine kurze Version nicht funktioniert? Die dürfte nichts einspeisen, es sein denn die Waschmaschine hängt an einer Smartplug....

                                    K Offline
                                    K Offline
                                    karo2204
                                    schrieb am zuletzt editiert von
                                    #697

                                    @waly_de Kurz dachte ich es hat funktioniert, aber doch nicht. Heute ist es wieder so, dass er immer wieder einspeist aus dem Akku. Auch wenn nichts läuft (wir sind nicht zu Hause).

                                    Ich habe keine Ahnung warum das nicht funktioniert. Habe immer noch Deine Version vom Script laufen.

                                    ioBroker
                                    Tibber
                                    Ecoflow Powerstream & Delta Max 2000

                                    1 Antwort Letzte Antwort
                                    0
                                    • Nils_1985N Offline
                                      Nils_1985N Offline
                                      Nils_1985
                                      schrieb am zuletzt editiert von Nils_1985
                                      #698

                                      Hallo zusammen,

                                      seit dem letzten PowerStream Update habe ich nun das Problem, dass batSoc nicht mehr aktualisiert wird. Der Wert ist auf null. Das betrifft aber nur den Datenpunkt unter data.InverterHeartbeat. Der Wert unter data.params.bms_bmsStatus.soc wird aktualisiert.

                                      Leider denkt so der Script das Soc 0 ist und regelt nicht. Ändere ich den Wert manuell, dann regelt der Script wie gewohnt.

                                      Wer hat das Problem auch.

                                      VG Nils

                                      Nils_1985N 1 Antwort Letzte Antwort
                                      0
                                      • Nils_1985N Nils_1985

                                        Hallo zusammen,

                                        seit dem letzten PowerStream Update habe ich nun das Problem, dass batSoc nicht mehr aktualisiert wird. Der Wert ist auf null. Das betrifft aber nur den Datenpunkt unter data.InverterHeartbeat. Der Wert unter data.params.bms_bmsStatus.soc wird aktualisiert.

                                        Leider denkt so der Script das Soc 0 ist und regelt nicht. Ändere ich den Wert manuell, dann regelt der Script wie gewohnt.

                                        Wer hat das Problem auch.

                                        VG Nils

                                        Nils_1985N Offline
                                        Nils_1985N Offline
                                        Nils_1985
                                        schrieb am zuletzt editiert von
                                        #699

                                        @nils_1985

                                        Hab den Raspberry Pi neu gestartet. Nun wird der Wert wieder aktualisiert....

                                        Komisch.....

                                        1 Antwort Letzte Antwort
                                        0
                                        • W Waly_de

                                          @aherby hmm ich denke das hängt mit diesen 255'er Werten zusammen die teilweise mit gesendet werden... es ist blöd, denn wenn ich eine Delta 2 Max hier hätte, könnte ich das wahrscheinlich schnell lösen. Aber so ist das echt schwierig.

                                          ich schicke gleich in diesem Beitrag mal eine neue Version vom Script. Ich habe (ohne es testen zu können) mal versucht die 255 Werte zu berücksichtigen und nicht mit den Werten aus den States zu überschreiben.

                                          Neue Version: ecoflow-connector_v116.txt

                                          S Offline
                                          S Offline
                                          sirdir
                                          schrieb am zuletzt editiert von sirdir
                                          #700

                                          @waly_de Mir ist nicht ganz klar, ob das zusammen hängt mit dem was du zu reparieren gehofft hast, aber falls das was hilt: Wenn ich slowChgWatts änder, stoppt die Ladung auch mit der V1.1.6 immer noch.

                                          A 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          755

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe