Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. ecoflow-connector-Script zur dynamischen Leistungsanpassung

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    12
    2
    240

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

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

ecoflow-connector-Script zur dynamischen Leistungsanpassung

ecoflow-connector-Script zur dynamischen Leistungsanpassung

Scheduled Pinned Locked Moved JavaScript
1.6k Posts 127 Posters 741.2k Views 127 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Offline
    M Offline
    Mario1995
    wrote on last edited by Mario1995
    #1165

    Guten Morgen,

    ich habe heute die neue 2 kWh Batterie in Betrieb genommen. Eco Flow hat meinen PowerStream auf die Version 1.0.1.195 geupdatet (durch den Service), da ansonsten der PowerStream die Batterie nicht erkannt hat.

    Das Skript läuft grundsätzlich bei mir (ohne erkennbare Fehler oder Abbrüche).
    Der Timber Pulse (Lokale Auslosung, nicht über die Cloud), liefert auch zuverlässig die Daten.

    Leider erfolgen keine Änderungen durch das Skript (Anpassung an den aktuellen Stromverbrauch). Die Batterie wird unter Objekte in IoBroker auch nicht mit Werten gefüllt (habe alle möglichen Batterietypen ausgetestet).

    Ich glaube tatsächlich das Skript müsste angepasst werden. Oder hat jemand das ganze schon zum laufen bekommen?

    Wie kann ich helfen? Was für Logdateien etc. werden benötigt?

    Ergänzung:

    Ich habe jetzt doch einen Fehler im Skript bei mir gefunden:

    
    javascript.0
    2024-04-06 12:01:01.909	info	script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout
    
    javascript.0
    2024-04-06 12:01:01.908	info	script.js.common.Ecoflow: getLowestValue-error: timeout
    
    javascript.0
    2024-04-06 12:00:46.909	info	script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout
    
    javascript.0
    2024-04-06 12:00:46.908	info	script.js.common.Ecoflow: getLowestValue-error: timeout
    

    Stand 12:40 Uhr:

    Es war der History Adapter, der gefehlt hatte.. Habs in den anderen Beiträgen gefunden. Das Skript läuft jetzt! Die Batterie wird dennoch nicht erkannt (Wert Null für Batteriezustand)

    Ich habe das Ganze jetzt erstmal so gelöst, dass bei dieser Zeile folgende Werte reinkommen (weil Batteriestand ja unbekannt):

    lowBatLimitPozOn: 0, lowBatLimitPozOff: -1, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
    
    W 1 Reply Last reply
    1
    • W Waly_de

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

      Guten Abend und vielen Dank für das Skript. Ich habe zwei Fragen: Ich bekomme nächste Woche von Ecoflow die 2 KW Batterie für den Outdoorgebrauch. Einen speziellen Namen hat das Modell irgendwie nicht. Hier der Link: https://de.ecoflow.com/products/powerstream-balcony-solar-system-waterproof-battery-series-600-w-800-w

      1. Frage: Ist das Skript mit dieser Batterie auch kompatibel?

      Vielleicht ... leider habe ich das Gerät noch nicht gesehen. Grundsätzlich würde es funktionieren, wenn das Gerät die Daten wie die Deltas liefert. Muss man einfach testen, indem du es im Script per seriennummer einträgst. Ich sehe mir das Teil bei Gelegenheit mal an...

      1. Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
        Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?

      Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.

      M Offline
      M Offline
      Mario1995
      wrote on last edited by
      #1166
      1. Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
        Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?

      Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.

      Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.

      RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.

      Hast du vielleicht noch eine Idee, woran das liegen könnte?

      Thomas WellerT M 2 Replies Last reply
      0
      • M Mario1995
        1. Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
          Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?

        Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.

        Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.

        RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.

        Hast du vielleicht noch eine Idee, woran das liegen könnte?

        Thomas WellerT Offline
        Thomas WellerT Offline
        Thomas Weller
        wrote on last edited by
        #1167

        @Waly_de

        Von mir einfach nochmal ein Riesen Dankeschön!!!

        Hier mein März mit dem genialen Skript:
        Screenshot_20240407-073312.png

        W 1 Reply Last reply
        1
        • M Mario1995
          1. Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
            Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?

          Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.

          Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.

          RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.

          Hast du vielleicht noch eine Idee, woran das liegen könnte?

          M Offline
          M Offline
          Mario1995
          wrote on last edited by
          #1168

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

          1. Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
            Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?

          Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.

          Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.

          RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.

          Hast du vielleicht noch eine Idee, woran das liegen könnte?

          Ich hab das Problem lösen können.. Ich habe über Blockly ein Skript geschrieben. Aktueller Stromverbrauch laut Tibber ./. dieser einen Fritz!Box Steckdose = Wert über Stromverbrauch für das Ecoflow Skript. Das hat geklappt.

          Tut mir leid falls das zu viele Fragen hier im Forum waren. Musste mich erstmal belesen. Habe iOBroker eigentlich nur für dieses Ecoflow Skript 🙂

          1 Reply Last reply
          1
          • 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)
            G Offline
            G Offline
            gooflo
            wrote on last edited by gooflo
            #1169

            @waly_de nächste Frage: Unterstützung von zwei Shelly 3EM oder Regelung mit Nutzung von Smartplugs. Anwendungsfall: ich habe ein Haus mit zwei Sicherungskasten und habe den Shelly 3EM bisher nur an einem. Nun würde ich natürlich gerne den restlichen Teil des Hauses auch mit regeln lassen, was ich entweder über "übrige" Smartplugs lösen könnte oder über einen zweiten Shelly 3EM im zweiten Sicherungskasten (oder natürlich über einen IR Sensor im Zählerschrank, was aber einen Elektriker braucht wg. Steckdose). Soweit ich das Skript verstehe, funktioniert das (noch) nicht, müsste aber (vermutlich) relativ einfach sein, einzubauen. Wäre also ein Featurewunsch von mir bzw. die Frage, ob Du mir Hinweise geben könntest, wo ich es einbauen muss, dann würde ich das mal versuchen.

            Erster Versuch: alle 4 Plugs, die nicht im Shelly 3EM inbegriffen sind, abonnieren (und einmal Verbraucher einschalten), dann bei

            //Gesamtbedarf ist:
            let NewValue = lowestValue - ConfigData.BasePowerOffset
            NewValue = NewValue + getPlugsWatt() // Verbrauch der Plugs hinzufügen
            

            wobei

            function getPlugsWatt() {
               let sum = 0
               sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
               sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
               sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
               sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
               return sum
            }
            

            Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...

            Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?

            W 1 Reply Last reply
            0
            • D Offline
              D Offline
              Dreffi
              wrote on last edited by Dreffi
              #1170

              Ich hätte auch noch einen Wunsch:

              RegulationMultiPsMode: 2 = invers
              Ziel soll sein die Last in umgekehrter Reihenfolge auf die Powerstreams zu verteilen als sonst bei seriell.

              1 Reply Last reply
              1
              • M Mario1995

                Guten Morgen,

                ich habe heute die neue 2 kWh Batterie in Betrieb genommen. Eco Flow hat meinen PowerStream auf die Version 1.0.1.195 geupdatet (durch den Service), da ansonsten der PowerStream die Batterie nicht erkannt hat.

                Das Skript läuft grundsätzlich bei mir (ohne erkennbare Fehler oder Abbrüche).
                Der Timber Pulse (Lokale Auslosung, nicht über die Cloud), liefert auch zuverlässig die Daten.

                Leider erfolgen keine Änderungen durch das Skript (Anpassung an den aktuellen Stromverbrauch). Die Batterie wird unter Objekte in IoBroker auch nicht mit Werten gefüllt (habe alle möglichen Batterietypen ausgetestet).

                Ich glaube tatsächlich das Skript müsste angepasst werden. Oder hat jemand das ganze schon zum laufen bekommen?

                Wie kann ich helfen? Was für Logdateien etc. werden benötigt?

                Ergänzung:

                Ich habe jetzt doch einen Fehler im Skript bei mir gefunden:

                
                javascript.0
                2024-04-06 12:01:01.909	info	script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout
                
                javascript.0
                2024-04-06 12:01:01.908	info	script.js.common.Ecoflow: getLowestValue-error: timeout
                
                javascript.0
                2024-04-06 12:00:46.909	info	script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout
                
                javascript.0
                2024-04-06 12:00:46.908	info	script.js.common.Ecoflow: getLowestValue-error: timeout
                

                Stand 12:40 Uhr:

                Es war der History Adapter, der gefehlt hatte.. Habs in den anderen Beiträgen gefunden. Das Skript läuft jetzt! Die Batterie wird dennoch nicht erkannt (Wert Null für Batteriezustand)

                Ich habe das Ganze jetzt erstmal so gelöst, dass bei dieser Zeile folgende Werte reinkommen (weil Batteriestand ja unbekannt):

                lowBatLimitPozOn: 0, lowBatLimitPozOff: -1, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                
                W Offline
                W Offline
                Waly_de
                wrote on last edited by
                #1171

                @mario1995 das hast du gut gelöst!
                Was hast du denn für eine Batterie angeschlossen?
                Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
                Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
                Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein.

                M 1 Reply Last reply
                2
                • G gooflo

                  @waly_de nächste Frage: Unterstützung von zwei Shelly 3EM oder Regelung mit Nutzung von Smartplugs. Anwendungsfall: ich habe ein Haus mit zwei Sicherungskasten und habe den Shelly 3EM bisher nur an einem. Nun würde ich natürlich gerne den restlichen Teil des Hauses auch mit regeln lassen, was ich entweder über "übrige" Smartplugs lösen könnte oder über einen zweiten Shelly 3EM im zweiten Sicherungskasten (oder natürlich über einen IR Sensor im Zählerschrank, was aber einen Elektriker braucht wg. Steckdose). Soweit ich das Skript verstehe, funktioniert das (noch) nicht, müsste aber (vermutlich) relativ einfach sein, einzubauen. Wäre also ein Featurewunsch von mir bzw. die Frage, ob Du mir Hinweise geben könntest, wo ich es einbauen muss, dann würde ich das mal versuchen.

                  Erster Versuch: alle 4 Plugs, die nicht im Shelly 3EM inbegriffen sind, abonnieren (und einmal Verbraucher einschalten), dann bei

                  //Gesamtbedarf ist:
                  let NewValue = lowestValue - ConfigData.BasePowerOffset
                  NewValue = NewValue + getPlugsWatt() // Verbrauch der Plugs hinzufügen
                  

                  wobei

                  function getPlugsWatt() {
                     let sum = 0
                     sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
                     sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
                     sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
                     sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 
                     return sum
                  }
                  

                  Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...

                  Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?

                  W Offline
                  W Offline
                  Waly_de
                  wrote on last edited by Waly_de
                  #1172

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

                  Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...
                  Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?

                  Nein, das ist im Skript nicht so vorgesehen. Ich würde das wie folgt lösen: lege ein eigenes Objekt manuell an, in das du deinen Zählerstand zuzüglich der Summen deiner Plugs schreibst. Das geht prima mit einem Blocky oder aber mit einem kleinen Extra Skript.
                  Dieses neu angelegte Objekt gibst du dann im Skript als Smartmeter ID an.

                  G 1 Reply Last reply
                  0
                  • Thomas WellerT Thomas Weller

                    @Waly_de

                    Von mir einfach nochmal ein Riesen Dankeschön!!!

                    Hier mein März mit dem genialen Skript:
                    Screenshot_20240407-073312.png

                    W Offline
                    W Offline
                    Waly_de
                    wrote on last edited by
                    #1173

                    @thomas-weller sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                    Von mir einfach nochmal ein Riesen Dankeschön!!!
                    Hier mein März mit dem genialen Skript:

                    Das sieht Großartig aus... freut mich 😉

                    1 Reply Last reply
                    0
                    • W Waly_de

                      @mario1995 das hast du gut gelöst!
                      Was hast du denn für eine Batterie angeschlossen?
                      Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
                      Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
                      Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein.

                      M Offline
                      M Offline
                      Mario1995
                      wrote on last edited by Mario1995
                      #1174

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

                      @mario1995 das hast du gut gelöst!
                      Was hast du denn für eine Batterie angeschlossen?
                      Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
                      Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
                      Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein.

                      Das ist die neue 2kwh Batterie (Wasserfest). Einen einprägsamen Namen hat diese bisher nicht.

                      Durch ein Update des Powerstreams auf die Version 1.0.1.195 durch den Support wird die Batterie mit Temperatur und Prozentzahl angezeigt.

                      Home-Assistant kann die Daten der Batterie auch auslesen (Ecoflow Integration).

                      Welche Werte werden denn zur Verwendung des Skripts benötigt? z.B. Wenn ich die Delta 2 (D2) im Skript einstelle?

                      Das wären doch diese Angaben, oder?

                         { id: 0, name: 'acChgCfg_D2', ValueName: 'chgWatts', Typ: 'D2', MT: 5, AddParam: '{"chgWatts":600,"chgPauseFlag":255}' },
                          { id: 0, name: 'acOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 3 },
                          { id: 0, name: 'dcOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 1 },
                          { id: 0, name: 'quietMode_D2', ValueName: 'enabled', Typ: 'D2', MT: 5 },
                          { id: 0, name: 'dcChgCfg_D2', ValueName: 'dcChgCfg', Typ: 'D2', MT: 5 },
                      

                      Wäre es möglich, dass diese Daten der Batterie allesamt vom Powerstream kommen?

                      Für mich wäre das eine Erklärung dafür, warum Home Assistant die Funktion schon hat...

                      Weil ich glaube tatsächlich, dass dieser Akku sich nicht getrennt per Wlan oder Bluetooth anmeldet sondern die Daten über den Powerstream einreicht...

                      Nachtrag:

                      Unter dem Powerstream werden die Daten dieser neuen Batterie abgelegt.

                      Zu finden sind diese unter: Objekte - app_device_property_SeriennummerderPowerstation- Data - InverterHeartbeat. Dort sind folgende Informationen zur Batterie angegeben:

                      0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputVolt
                      0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputWatts
                      0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batSoc
                      0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batTemp

                      W 1 Reply Last reply
                      0
                      • M Mario1995

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

                        @mario1995 das hast du gut gelöst!
                        Was hast du denn für eine Batterie angeschlossen?
                        Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
                        Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
                        Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein.

                        Das ist die neue 2kwh Batterie (Wasserfest). Einen einprägsamen Namen hat diese bisher nicht.

                        Durch ein Update des Powerstreams auf die Version 1.0.1.195 durch den Support wird die Batterie mit Temperatur und Prozentzahl angezeigt.

                        Home-Assistant kann die Daten der Batterie auch auslesen (Ecoflow Integration).

                        Welche Werte werden denn zur Verwendung des Skripts benötigt? z.B. Wenn ich die Delta 2 (D2) im Skript einstelle?

                        Das wären doch diese Angaben, oder?

                           { id: 0, name: 'acChgCfg_D2', ValueName: 'chgWatts', Typ: 'D2', MT: 5, AddParam: '{"chgWatts":600,"chgPauseFlag":255}' },
                            { id: 0, name: 'acOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 3 },
                            { id: 0, name: 'dcOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 1 },
                            { id: 0, name: 'quietMode_D2', ValueName: 'enabled', Typ: 'D2', MT: 5 },
                            { id: 0, name: 'dcChgCfg_D2', ValueName: 'dcChgCfg', Typ: 'D2', MT: 5 },
                        

                        Wäre es möglich, dass diese Daten der Batterie allesamt vom Powerstream kommen?

                        Für mich wäre das eine Erklärung dafür, warum Home Assistant die Funktion schon hat...

                        Weil ich glaube tatsächlich, dass dieser Akku sich nicht getrennt per Wlan oder Bluetooth anmeldet sondern die Daten über den Powerstream einreicht...

                        Nachtrag:

                        Unter dem Powerstream werden die Daten dieser neuen Batterie abgelegt.

                        Zu finden sind diese unter: Objekte - app_device_property_SeriennummerderPowerstation- Data - InverterHeartbeat. Dort sind folgende Informationen zur Batterie angegeben:

                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputVolt
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputWatts
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batSoc
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batTemp

                        W Offline
                        W Offline
                        Waly_de
                        wrote on last edited by Waly_de
                        #1175

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

                        Zu finden sind diese unter: Objekte - app_device_property_SeriennummerderPowerstation- Data - InverterHeartbeat. Dort sind folgende Informationen zur Batterie angegeben:
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputVolt
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputWatts
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batSoc
                        0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batTemp

                        Also wenn da die richtigen aktuellen Daten eingetragen sind, dann hat das Skript auch den Batteriestand zur Verfügung genau wie bei den anderen Deltas.
                        Es müsste also ganz normal funktionieren. Bitte beachte aber, dass die Batteriestanddaten nicht sofort übertragen werden, sondern in der Regel nur dann, wenn sich der Wert ändert. Daher musst du nach dem Starten des Skripts vielleicht ein wenig Geduld haben oder mal einen größeren Verbrauch eine Zeit lang einschalten, um zu sehen, was passiert, wenn sich der Batteriestand ändert.

                        1 Reply Last reply
                        0
                        • A Offline
                          A Offline
                          Audiofreak
                          wrote on last edited by Audiofreak
                          #1176

                          Hi zusammen

                          Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
                          Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
                          Grüsse aus der Schweiz
                          Rafal

                          8.4.2024, 14:59:59.789	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:00:01.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                          8.4.2024, 15:00:01.583	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                          8.4.2024, 15:02:01.370	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:02:01.377	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                          8.4.2024, 15:02:01.452	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:02:01.513	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                          8.4.2024, 15:02:01.734	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                          8.4.2024, 15:02:14.799	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:02:14.801	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                          8.4.2024, 15:02:14.878	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:02:14.924	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                          8.4.2024, 15:02:15.111	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                          8.4.2024, 15:04:19.766	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                          8.4.2024, 15:04:19.769	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:04:19.772	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                          8.4.2024, 15:06:09.014	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:06:09.098	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:06:09.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                          8.4.2024, 15:06:09.440	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                          8.4.2024, 15:06:24.159	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                          8.4.2024, 15:08:19.767	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                          8.4.2024, 15:08:19.770	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                          8.4.2024, 15:08:19.773	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                          
                          W 1 Reply Last reply
                          0
                          • A Audiofreak

                            Hi zusammen

                            Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
                            Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
                            Grüsse aus der Schweiz
                            Rafal

                            8.4.2024, 14:59:59.789	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:00:01.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:00:01.583	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:02:01.370	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:01.377	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:02:01.452	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:01.513	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:02:01.734	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:02:14.799	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:14.801	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:02:14.878	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:14.924	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:02:15.111	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:04:19.766	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                            8.4.2024, 15:04:19.769	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:04:19.772	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:06:09.014	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:06:09.098	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:06:09.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:06:09.440	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:06:24.159	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                            8.4.2024, 15:08:19.767	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                            8.4.2024, 15:08:19.770	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:08:19.773	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            
                            W Offline
                            W Offline
                            Waly_de
                            wrote on last edited by
                            #1177

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

                            Hi zusammen

                            Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
                            Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
                            Grüsse aus der Schweiz
                            Rafal

                            8.4.2024, 14:59:59.789	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:00:01.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:00:01.583	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:02:01.370	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:01.377	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:02:01.452	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:01.513	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:02:01.734	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:02:14.799	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:14.801	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:02:14.878	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:02:14.924	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:02:15.111	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:04:19.766	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                            8.4.2024, 15:04:19.769	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:04:19.772	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            8.4.2024, 15:06:09.014	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:06:09.098	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:06:09.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                            8.4.2024, 15:06:09.440	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                            8.4.2024, 15:06:24.159	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                            8.4.2024, 15:08:19.767	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                            8.4.2024, 15:08:19.770	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                            8.4.2024, 15:08:19.773	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                            

                            siehe den Eingangsbeitrag dieses Threads... da ist beschrieben was zu tun ist.

                            A 1 Reply Last reply
                            0
                            • W Waly_de

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

                              Hi zusammen

                              Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
                              Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
                              Grüsse aus der Schweiz
                              Rafal

                              8.4.2024, 14:59:59.789	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:00:01.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                              8.4.2024, 15:00:01.583	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                              8.4.2024, 15:02:01.370	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:02:01.377	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                              8.4.2024, 15:02:01.452	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:02:01.513	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                              8.4.2024, 15:02:01.734	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                              8.4.2024, 15:02:14.799	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:02:14.801	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                              8.4.2024, 15:02:14.878	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:02:14.924	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                              8.4.2024, 15:02:15.111	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                              8.4.2024, 15:04:19.766	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                              8.4.2024, 15:04:19.769	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:04:19.772	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                              8.4.2024, 15:06:09.014	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:06:09.098	[info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:06:09.161	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                              8.4.2024, 15:06:09.440	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker
                              8.4.2024, 15:06:24.159	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data
                              8.4.2024, 15:08:19.767	[error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script!
                              8.4.2024, 15:08:19.770	[info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2
                              8.4.2024, 15:08:19.773	[info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
                              

                              siehe den Eingangsbeitrag dieses Threads... da ist beschrieben was zu tun ist.

                              A Offline
                              A Offline
                              Audiofreak
                              wrote on last edited by
                              #1178

                              @waly_de said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                              siehe den Eingangsbeitrag dieses Threads... da ist beschrieben was zu tun ist.

                              Hi Markus

                              Sorry, hätte ich drauf kommen können im ersten Post nachzuschauen.. Habs jetzt auf 3000 erhöht 👍

                              1 Reply Last reply
                              0
                              • W Waly_de

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

                                Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...
                                Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?

                                Nein, das ist im Skript nicht so vorgesehen. Ich würde das wie folgt lösen: lege ein eigenes Objekt manuell an, in das du deinen Zählerstand zuzüglich der Summen deiner Plugs schreibst. Das geht prima mit einem Blocky oder aber mit einem kleinen Extra Skript.
                                Dieses neu angelegte Objekt gibst du dann im Skript als Smartmeter ID an.

                                G Offline
                                G Offline
                                gooflo
                                wrote on last edited by
                                #1179

                                @waly_de danke für den Tip. Falls jemand auch diesen Anwendungsfall hat, hier meine aktuelle Lösung mit einem zweiten Skript, wobei ich im Originalskript in der Konfiguration das hier setze:

                                SmartmeterID: "0_userdata.0.ecoflow.TotalActivePowerPlusPlugs",     // State, der den aktuellen Gesamtverbrauch in Watt anzeigt
                                

                                und hier das neue Skript:

                                // globale Konfiguration
                                var ConfigData = {
                                    statesPrefix: "0_userdata.0.ecoflow",                                          // übernommen 
                                    TotalActivePower : ".TotalActivePower",                                        // Shelly total active power
                                    TotalActivePowerPlusPlugs : ".TotalActivePowerPlusPlugs",                      // Neuer State für Power mit Plugs in den Userdaten
                                    SmartmeterID: "shelly.0.shellypro3em#XXXXXXXXXXX.EM0.TotalActivePower",     // übernommen State, der den aktuellen Gesamtverbrauch in Watt anzeigt    
                                }
                                
                                // state TotalActivePowerPlusPlugs anlegen
                                if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs)) {
                                  createState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0,{name: "TotalActivePowerPlusPlugs",  type: 'number', role: 'value'}, function () {}); 
                                } else {
                                  setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0);
                                }
                                
                                // state TotalActivePower anlegen
                                if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePower)) {
                                  createState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0,{name: "TotalActivePower",  type: 'number', role: 'value'}, function () {}); 
                                } else {
                                  setState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0);
                                }
                                
                                /**
                                * @param {string} id
                                */
                                function getPlugWatts(id)
                                {
                                    let watts = 0
                                
                                    let age_min = (Date.now() - getState(id).ts) / (1000 * 60)
                                    let w = Number(getState(id).val)/10 
                                
                                    // sanity check: nur wenn die Daten Daten jünger als 4 min sind oder nicht so hoch werden sie verwendet
                                    if (age_min < 4 ||  w < 50) { 
                                       watts += w 
                                    } 
                                   
                                    // log(id + " " + watts + " W, age (min) = " + age_min)
                                    return watts
                                }
                                
                                // wenn der Smartmeter gesetzt wird, die Plugs Watt ermitteln und die states setzen
                                on({id: ConfigData.SmartmeterID}, function (obj) {
                                 
                                   let smartMeterTotal = Math.floor(Number(getState(ConfigData.SmartmeterID).val))
                                   setState(ConfigData.statesPrefix + ConfigData.TotalActivePower, smartMeterTotal) // store initial TotalActivePower
                                
                                   let plugsSum = 0
                                   plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_1.data.plug_heartbeat_pack.watts")
                                   plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_2.data.plug_heartbeat_pack.watts")
                                   plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_3data.plug_heartbeat_pack.watts")
                                   plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_4.data.plug_heartbeat_pack.watts")
                                
                                   // log("Plugs Watts = " + plugsSum)
                                   setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs, Math.floor(smartMeterTotal + plugsSum))
                                });
                                

                                Natürlich müssen für Shelly und Plugs die entsprechenden IDs gesetzt werden.

                                AndréBA 1 Reply Last reply
                                1
                                • Tom GoosT Offline
                                  Tom GoosT Offline
                                  Tom Goos
                                  wrote on last edited by
                                  #1180

                                  Hi,
                                  seit knapp einer Woche steuert das script meine Einspeiseleistung nicht mehr bzw stellt sie auf 0. Der Verbrauch wird regelmäßig aktualisiert und auch das 2 Minuten-Minimum aktualisiert sich entsprechend, nur wird "setac" immer auf 0 gesetzt. Wenn ich den Wert unter Objekte anpasse speist der Powerstream dann auch ein und nach kurzer Zeit wird der Wert wieder mit 0 überschrieben. Hatte jemand schonmal das selbe Problem oder hat eine Idee was ich ändern kann? Der Ladestand der Delta 2 war eigentlich so ziemlich schon so ziemlich jeder Wert zwischen 5 und 100%.
                                  Danke schonmal 🙂

                                  F 1 Reply Last reply
                                  0
                                  • Tom GoosT Tom Goos

                                    Hi,
                                    seit knapp einer Woche steuert das script meine Einspeiseleistung nicht mehr bzw stellt sie auf 0. Der Verbrauch wird regelmäßig aktualisiert und auch das 2 Minuten-Minimum aktualisiert sich entsprechend, nur wird "setac" immer auf 0 gesetzt. Wenn ich den Wert unter Objekte anpasse speist der Powerstream dann auch ein und nach kurzer Zeit wird der Wert wieder mit 0 überschrieben. Hatte jemand schonmal das selbe Problem oder hat eine Idee was ich ändern kann? Der Ladestand der Delta 2 war eigentlich so ziemlich schon so ziemlich jeder Wert zwischen 5 und 100%.
                                    Danke schonmal 🙂

                                    F Offline
                                    F Offline
                                    florism
                                    wrote on last edited by
                                    #1181

                                    @tom-goos hast du zufällig in der App für Backup Reserve aktiviert? Das hatte ich auch schon 🙈

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      solarsummer
                                      wrote on last edited by
                                      #1182

                                      @Waly_de Lieben dank für das Script. Dank dem Tibber script zum lokalen auslesen und dem ecoflow-connector-Script braucht mein neue Powerstream keine smartplugs. Es funktioniert alles, obwohl ich neu in iobroker bin, doch eine Sache konnte ich noch nicht finden:

                                      Wie bekomme ich die korrekte Nach-Kommastelle hin z.b für invOutputWatts ?


                                      2024-04-13_13-19.png

                                      F 1 Reply Last reply
                                      0
                                      • A Offline
                                        A Offline
                                        Accu
                                        wrote on last edited by
                                        #1183

                                        @Waly_de ich hatte heute wieder das Szenario, dass mein PS mit 560W eingespeist hat, während die das Skript den Ladeeingang der DP angeschalten hat und diese mit 300W geladen hat. kann man das nicht irgendwie umgehen, dass der AC Ladeeingang der DP nicht eingeschaltet wird, wenn der PS einspeist. Sonst gehts ja vorne raus und hinten wieder rein.

                                        1 Reply Last reply
                                        0
                                        • G gooflo

                                          @waly_de danke für den Tip. Falls jemand auch diesen Anwendungsfall hat, hier meine aktuelle Lösung mit einem zweiten Skript, wobei ich im Originalskript in der Konfiguration das hier setze:

                                          SmartmeterID: "0_userdata.0.ecoflow.TotalActivePowerPlusPlugs",     // State, der den aktuellen Gesamtverbrauch in Watt anzeigt
                                          

                                          und hier das neue Skript:

                                          // globale Konfiguration
                                          var ConfigData = {
                                              statesPrefix: "0_userdata.0.ecoflow",                                          // übernommen 
                                              TotalActivePower : ".TotalActivePower",                                        // Shelly total active power
                                              TotalActivePowerPlusPlugs : ".TotalActivePowerPlusPlugs",                      // Neuer State für Power mit Plugs in den Userdaten
                                              SmartmeterID: "shelly.0.shellypro3em#XXXXXXXXXXX.EM0.TotalActivePower",     // übernommen State, der den aktuellen Gesamtverbrauch in Watt anzeigt    
                                          }
                                          
                                          // state TotalActivePowerPlusPlugs anlegen
                                          if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs)) {
                                            createState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0,{name: "TotalActivePowerPlusPlugs",  type: 'number', role: 'value'}, function () {}); 
                                          } else {
                                            setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0);
                                          }
                                          
                                          // state TotalActivePower anlegen
                                          if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePower)) {
                                            createState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0,{name: "TotalActivePower",  type: 'number', role: 'value'}, function () {}); 
                                          } else {
                                            setState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0);
                                          }
                                          
                                          /**
                                          * @param {string} id
                                          */
                                          function getPlugWatts(id)
                                          {
                                              let watts = 0
                                          
                                              let age_min = (Date.now() - getState(id).ts) / (1000 * 60)
                                              let w = Number(getState(id).val)/10 
                                          
                                              // sanity check: nur wenn die Daten Daten jünger als 4 min sind oder nicht so hoch werden sie verwendet
                                              if (age_min < 4 ||  w < 50) { 
                                                 watts += w 
                                              } 
                                             
                                              // log(id + " " + watts + " W, age (min) = " + age_min)
                                              return watts
                                          }
                                          
                                          // wenn der Smartmeter gesetzt wird, die Plugs Watt ermitteln und die states setzen
                                          on({id: ConfigData.SmartmeterID}, function (obj) {
                                           
                                             let smartMeterTotal = Math.floor(Number(getState(ConfigData.SmartmeterID).val))
                                             setState(ConfigData.statesPrefix + ConfigData.TotalActivePower, smartMeterTotal) // store initial TotalActivePower
                                          
                                             let plugsSum = 0
                                             plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_1.data.plug_heartbeat_pack.watts")
                                             plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_2.data.plug_heartbeat_pack.watts")
                                             plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_3data.plug_heartbeat_pack.watts")
                                             plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_4.data.plug_heartbeat_pack.watts")
                                          
                                             // log("Plugs Watts = " + plugsSum)
                                             setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs, Math.floor(smartMeterTotal + plugsSum))
                                          });
                                          

                                          Natürlich müssen für Shelly und Plugs die entsprechenden IDs gesetzt werden.

                                          AndréBA Offline
                                          AndréBA Offline
                                          AndréB
                                          wrote on last edited by
                                          #1184

                                          Hey @Waly_de, super Arbeit! Ich setze das grad alles bei mir auf. Da ich Programmierer bin, könnte ich bei Bedarf gern helfen, das Skript weiter zu verbessern und anzupassen.
                                          Dafür wäre es aber notwendig, es auf GitHub zu veröffentlichen. Dann könnte man da prima zusammen dran arbeiten und Feedback bzw. Bugs "einsammeln" und erreicht auch potentiell mehr Leute. Falls du Interesse hast, meld dich gern mal. Wenn du da keinen Bock drauf oder keine Zeit dafür hast, könnte ich das auch übernehmen - aber es ist ja dein Skript, da bräuchte ich natürlich auch dein OK für 🙂

                                          Cheers
                                          André

                                          AndréBA 1 Reply Last reply
                                          2
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          79

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe