Skip to content
  • Home
  • 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

Community Forum

donate donate
  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.5k

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

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

ecoflow-connector-Script zur dynamischen Leistungsanpassung

Geplant Angeheftet Gesperrt Verschoben JavaScript
1.6k Beiträge 127 Kommentatoren 744.4k 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.
  • K karo2204

    @waly_de Hab's mit ganz nach unten packen probiert und kurz nach den Settings in Zeile 269. Ich bekomme diese Fehlermeldung:

    javascript.0 (498610) script.js.Ecoflow-1161 compile failed:
    at script.js.Ecoflow-1161:964

    kann man das ignorieren?

    Ich habe aus dem Snippet, das mit dem Tag rausgenommen, weil es ja auch manchmal in der Nacht billig ist:

    // alle 60 Sekunden den Tarif prüfen
    var CheckTibber = setInterval(function () {
    
            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);
    
    W Offline
    W Offline
    Waly_de
    schrieb am zuletzt editiert von Waly_de
    #723

    @karo2204 Da hast Du ein paar }); zu viel drin. ;-)
    Compiler-Fehler sollte auch Chat GPT gut beseitigen können.

    Also ich hab es für Dich mal getestet und hier ist eine laufende Version:
    Das kannst Du auch in einem eigenen Script laufen lassen.

    Ob es funktioniert kannst Du nachher im Log sehen, da wird jeder Wechsel des Tibberpreislevels protokolliert.

    Damit es funktioniert müssen aber dringend diese Einstellungen gemacht werden:

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

    Viel Spaß beim Testen ;-)

    const tibberID = 'tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level'
    checkTibber() //Beim Starten des Scripts prüfen und einstellen
    on({ id: tibberID, change: "ne" }, function (obj) {   //Bei jeder Änderung des Status: CurrentPrice.level prüfen und einstellen
        checkTibber()
    });
    function checkTibber() {
        let priceLevel = getState(tibberID).val;
        log("Neuer Tibber Preislevel: " + priceLevel)
        if (priceLevel == 'CHEAP' || priceLevel == 'VERY_CHEAP') {
            setState('0_userdata.0.ecoflow.Regulate', false);  // Set to Battery prio mode
            log("Script abgeschaltet (Batterie-Priomode an)")
        } else {
            setState('0_userdata.0.ecoflow.Regulate', true);  // Set to Power Supply prio mode
            log("Script eingeschaltet (Batterie-Priomode aus)")
        }
    }
    
    K 2 Antworten Letzte Antwort
    0
    • M Milchbeck

      mal ne Frage wollte gerne über dem Script nur die Grundlast plus 50 Watt decken aber wenn ich anstatt Wechselrichter Leistung 800 Watt auf 150 Watt stelle wird nicht mehr in den Akku geladen der Rest geht dann als Überschuss ins Netz , also wie kann ich 150 Watt maximal einspeisen und trotzdem mit voller Leistung laden falls die mal kommt…

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

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

      mal ne Frage wollte gerne über dem Script nur die Grundlast plus 50 Watt decken aber wenn ich anstatt Wechselrichter Leistung 800 Watt auf 150 Watt stelle wird nicht mehr in den Akku geladen der Rest geht dann als Überschuss ins Netz , also wie kann ich 150 Watt maximal einspeisen und trotzdem mit voller Leistung laden falls die mal kommt…

      der Parameter "MaxPower" legt die maximale Einspeiseleistung fest.
      Wieviel der PS in die Batterie lädt kann das Script nicht begrenzen.
      Also sollte alles > "MaxPower" auch in die Batterie gehen.

      M 2 Antworten Letzte Antwort
      1
      • W Waly_de

        @karo2204 Da hast Du ein paar }); zu viel drin. ;-)
        Compiler-Fehler sollte auch Chat GPT gut beseitigen können.

        Also ich hab es für Dich mal getestet und hier ist eine laufende Version:
        Das kannst Du auch in einem eigenen Script laufen lassen.

        Ob es funktioniert kannst Du nachher im Log sehen, da wird jeder Wechsel des Tibberpreislevels protokolliert.

        Damit es funktioniert müssen aber dringend diese Einstellungen gemacht werden:

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

        Viel Spaß beim Testen ;-)

        const tibberID = 'tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level'
        checkTibber() //Beim Starten des Scripts prüfen und einstellen
        on({ id: tibberID, change: "ne" }, function (obj) {   //Bei jeder Änderung des Status: CurrentPrice.level prüfen und einstellen
            checkTibber()
        });
        function checkTibber() {
            let priceLevel = getState(tibberID).val;
            log("Neuer Tibber Preislevel: " + priceLevel)
            if (priceLevel == 'CHEAP' || priceLevel == 'VERY_CHEAP') {
                setState('0_userdata.0.ecoflow.Regulate', false);  // Set to Battery prio mode
                log("Script abgeschaltet (Batterie-Priomode an)")
            } else {
                setState('0_userdata.0.ecoflow.Regulate', true);  // Set to Power Supply prio mode
                log("Script eingeschaltet (Batterie-Priomode aus)")
            }
        }
        
        K Offline
        K Offline
        karo2204
        schrieb am zuletzt editiert von
        #725

        @waly_de OK danke. Ich kann es leider erst heute Abend einbauen. Dann probiere ich es nochmal.

        ioBroker
        Tibber
        Ecoflow Powerstream & Delta Max 2000

        1 Antwort Letzte Antwort
        0
        • W Waly_de

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

          mal ne Frage wollte gerne über dem Script nur die Grundlast plus 50 Watt decken aber wenn ich anstatt Wechselrichter Leistung 800 Watt auf 150 Watt stelle wird nicht mehr in den Akku geladen der Rest geht dann als Überschuss ins Netz , also wie kann ich 150 Watt maximal einspeisen und trotzdem mit voller Leistung laden falls die mal kommt…

          der Parameter "MaxPower" legt die maximale Einspeiseleistung fest.
          Wieviel der PS in die Batterie lädt kann das Script nicht begrenzen.
          Also sollte alles > "MaxPower" auch in die Batterie gehen.

          M Offline
          M Offline
          Milchbeck
          schrieb am zuletzt editiert von
          #726

          @waly_de
          Okay danke für die Antwort und was bewirkt dann Zusatz power Offset?

          1 Antwort Letzte Antwort
          0
          • W Offline
            W Offline
            Waly_de
            schrieb am zuletzt editiert von
            #727

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

            Okay danke für die Antwort und was bewirkt dann Zusatz power Offset?

            Du meinst:

            Zusatzpower_Offset: 10, // Zusatzpower startet ab einer Batterieladeleistung von MaxPower - Zusatzpower_Offset

            Zusatzpower versucht etwas mehr Leistungen aus dem PowerStream heraus zu kitzeln, als durch MaxPower festgelegt ist. D.h. wenn in die Batterie, die durch MaxPower festgelegte Leistung minus Zusatzpower_Offset fließt, versuch das Skript in kleinen Schritten die Einspeiseleistung zu erhöhen. auf diese Weise habe ich schon an die 700 W Gesamtleistung aus einem 600 W PowerStream herausgeholt.

            Wenn du diesen Wert natürlich erhöht hast auf 150 W, dann hat das Skript bei Max Power gleich 800 W ab 650 W versucht mehr Leistung ins Netz einzuspeisen.

            1 Antwort Letzte Antwort
            1
            • W Waly_de

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

              Nur dads chgPauseFlag allein setzen, da dann 255 bei slowChgWatts zu senden dürfte ein Bug sein.

              was schickt die App, wenn du chgPauseFlag setzt?

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

              @waly_de Wie setze ich denn chgPauseFlag über die App? :) Ladetimer? Ich schau mal… Ne, Ladetimer zu setzen tut nix mit chgPauseFlag…

              A 1 Antwort Letzte Antwort
              0
              • S sirdir

                @waly_de Wie setze ich denn chgPauseFlag über die App? :) Ladetimer? Ich schau mal… Ne, Ladetimer zu setzen tut nix mit chgPauseFlag…

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

                @sirdir Ich habe es in der App auch nicht gefunden. Aber cool das es dieses Flag gibt. Die Timersachen sind sehr komplex in Sachen aktivieren per Script. Aktuell bekomme ich feste Werte wie täglich AC-Laden von 00:00 Uhr bis z.B. 3:00 Uhr hin, weil ich einmal den Timer mitgeschnitten habe. Aber die Zeiten und andere Werte wie Tage benötigt vielleicht sogar ein eingenes Script. Vielleicht komme ich in den nächsten Tage hier mal weiter jedoch kann ich kein Script schreiben höchstens Daten liefern.

                S 1 Antwort Letzte Antwort
                0
                • W Waly_de

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

                  Nur dads chgPauseFlag allein setzen, da dann 255 bei slowChgWatts zu senden dürfte ein Bug sein.

                  was schickt die App, wenn du chgPauseFlag setzt?

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

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

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

                  Nur dads chgPauseFlag allein setzen, da dann 255 bei slowChgWatts zu senden dürfte ein Bug sein.

                  was schickt die App, wenn du chgPauseFlag setzt?

                  nachdem ich einen String für die DeltaMax gefunden habe params: { id: 69, chgPause: 1 }, bin ich der Meinung, daß man immer nur den relevanten Parameter schicken braucht. In der APP gibts den ja nicht, aber bei der Homeassistant Implementierung, wenn man noch die alte FW drauf hat (mit direkter Kommunikation ohne cloud).
                  D.h. bei dem chgPauseFlag sollte es auch funktionieren, wenn man slowChgWatts und fastChgWatts weglässt.
                  Ähnlich ist es mit den min/max settings, wenn man über die App steuert, sind beide Werte enthalten, es geht aber auch nur einer zum schicken.

                  Adapterüberblick: Profil Github;

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

                  Ein Aufruf: video

                  W 2 Antworten Letzte Antwort
                  0
                  • A aherby

                    @sirdir Ich habe es in der App auch nicht gefunden. Aber cool das es dieses Flag gibt. Die Timersachen sind sehr komplex in Sachen aktivieren per Script. Aktuell bekomme ich feste Werte wie täglich AC-Laden von 00:00 Uhr bis z.B. 3:00 Uhr hin, weil ich einmal den Timer mitgeschnitten habe. Aber die Zeiten und andere Werte wie Tage benötigt vielleicht sogar ein eingenes Script. Vielleicht komme ich in den nächsten Tage hier mal weiter jedoch kann ich kein Script schreiben höchstens Daten liefern.

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

                    @aherby funktioniert das für dich? Ich hab’s nur mit der River probiert und da funktioniert das mit dem AC Laden/nicht laden nicht zuverlässig. Wenn ich den Task ab/ und wieder anschalte tut es meist in dem Moment, was es tun sollte… Aber ist so ziemlich unbrauchbar.

                    1 Antwort Letzte Antwort
                    0
                    • W Waly_de

                      @karo2204 Da hast Du ein paar }); zu viel drin. ;-)
                      Compiler-Fehler sollte auch Chat GPT gut beseitigen können.

                      Also ich hab es für Dich mal getestet und hier ist eine laufende Version:
                      Das kannst Du auch in einem eigenen Script laufen lassen.

                      Ob es funktioniert kannst Du nachher im Log sehen, da wird jeder Wechsel des Tibberpreislevels protokolliert.

                      Damit es funktioniert müssen aber dringend diese Einstellungen gemacht werden:

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

                      Viel Spaß beim Testen ;-)

                      const tibberID = 'tibberlink.0.Homes.dfefdc35-4e8e-43a8-800f-64e5fe315d10.CurrentPrice.level'
                      checkTibber() //Beim Starten des Scripts prüfen und einstellen
                      on({ id: tibberID, change: "ne" }, function (obj) {   //Bei jeder Änderung des Status: CurrentPrice.level prüfen und einstellen
                          checkTibber()
                      });
                      function checkTibber() {
                          let priceLevel = getState(tibberID).val;
                          log("Neuer Tibber Preislevel: " + priceLevel)
                          if (priceLevel == 'CHEAP' || priceLevel == 'VERY_CHEAP') {
                              setState('0_userdata.0.ecoflow.Regulate', false);  // Set to Battery prio mode
                              log("Script abgeschaltet (Batterie-Priomode an)")
                          } else {
                              setState('0_userdata.0.ecoflow.Regulate', true);  // Set to Power Supply prio mode
                              log("Script eingeschaltet (Batterie-Priomode aus)")
                          }
                      }
                      
                      K Offline
                      K Offline
                      karo2204
                      schrieb am zuletzt editiert von karo2204
                      #732

                      @waly_de Script hat heute Nacht super funktioniert. Danke!

                      Wenn ich jetzt noch etwas frage, dann springst Du wahrscheinlich aus dem Fenster, aber vielleicht ist es ja zu :)

                      Kann man jetzt in das zusätzliche Script einbauen, dass wenn der SOC von 100% erreicht ist, er wieder auf Strom-Prio umschaltet? Also entweder andere Levels oder SOC, was zuerst kommt?

                      ioBroker
                      Tibber
                      Ecoflow Powerstream & Delta Max 2000

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

                        Hmm, ich bin nicht ganz sicher was das Problem ist, da ich keine Fehlermeldung gefunden habe und nix, aber seit ich die Version 1.1.6.1 drauf habe hat das System beide Male am Morgen nichts getan, 0 Einspeisung. Habe wieder ne urtalte Version aktiviert und sofort wurde eingespeist. Bin ich der Einzige?

                        1 Antwort Letzte Antwort
                        0
                        • F foxthefox

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

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

                          Nur dads chgPauseFlag allein setzen, da dann 255 bei slowChgWatts zu senden dürfte ein Bug sein.

                          was schickt die App, wenn du chgPauseFlag setzt?

                          nachdem ich einen String für die DeltaMax gefunden habe params: { id: 69, chgPause: 1 }, bin ich der Meinung, daß man immer nur den relevanten Parameter schicken braucht. In der APP gibts den ja nicht, aber bei der Homeassistant Implementierung, wenn man noch die alte FW drauf hat (mit direkter Kommunikation ohne cloud).
                          D.h. bei dem chgPauseFlag sollte es auch funktionieren, wenn man slowChgWatts und fastChgWatts weglässt.
                          Ähnlich ist es mit den min/max settings, wenn man über die App steuert, sind beide Werte enthalten, es geht aber auch nur einer zum schicken.

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

                          @foxthefox leider ist die „Sprache“ der Deltas bisher von Modell zu Modell unterschiedlich. Ich musste das ja Senden mehrerer Parameter einbauen, weil es mit dem Einzelsenden bei manchen Funktionen nicht funktioniert hat.
                          Bei der Delta 2 Max könnte das vielleicht klappen ( hab ja keine und kann’s nicht selbst testen)

                          Nehmt doch in der Writeables Definition mal die anderen Addparams raus, und guckt was passiert.

                              { id: 0, name: 'chgPauseFlag', ValueName: 'chgPauseFlag', Typ: 'D2M', MT: 3, OT: 'acChgCfg'},
                          
                          
                          F 1 Antwort Letzte Antwort
                          0
                          • F foxthefox

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

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

                            Nur dads chgPauseFlag allein setzen, da dann 255 bei slowChgWatts zu senden dürfte ein Bug sein.

                            was schickt die App, wenn du chgPauseFlag setzt?

                            nachdem ich einen String für die DeltaMax gefunden habe params: { id: 69, chgPause: 1 }, bin ich der Meinung, daß man immer nur den relevanten Parameter schicken braucht. In der APP gibts den ja nicht, aber bei der Homeassistant Implementierung, wenn man noch die alte FW drauf hat (mit direkter Kommunikation ohne cloud).
                            D.h. bei dem chgPauseFlag sollte es auch funktionieren, wenn man slowChgWatts und fastChgWatts weglässt.
                            Ähnlich ist es mit den min/max settings, wenn man über die App steuert, sind beide Werte enthalten, es geht aber auch nur einer zum schicken.

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

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

                            nachdem ich einen String für die DeltaMax gefunden habe params: { id: 69, chgPause: 1 }

                            Hast Du das schon getestet? Das wäre super, wenn das auch bei der Delta Max funktionierte :-)

                            1 Antwort Letzte Antwort
                            0
                            • W Waly_de

                              @foxthefox leider ist die „Sprache“ der Deltas bisher von Modell zu Modell unterschiedlich. Ich musste das ja Senden mehrerer Parameter einbauen, weil es mit dem Einzelsenden bei manchen Funktionen nicht funktioniert hat.
                              Bei der Delta 2 Max könnte das vielleicht klappen ( hab ja keine und kann’s nicht selbst testen)

                              Nehmt doch in der Writeables Definition mal die anderen Addparams raus, und guckt was passiert.

                                  { id: 0, name: 'chgPauseFlag', ValueName: 'chgPauseFlag', Typ: 'D2M', MT: 3, OT: 'acChgCfg'},
                              
                              
                              F Abwesend
                              F Abwesend
                              foxthefox
                              Developer
                              schrieb am zuletzt editiert von
                              #736

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

                              @foxthefox leider ist die „Sprache“ der Deltas bisher von Modell zu Modell unterschiedlich. Ich musste das ja Senden mehrerer Parameter einbauen, weil es mit dem Einzelsenden bei manchen Funktionen nicht funktioniert hat.
                              Bei der Delta 2 Max könnte das vielleicht klappen ( hab ja keine und kann’s nicht selbst testen)

                              Nehmt doch in der Writeables Definition mal die anderen Addparams raus, und guckt was passiert.

                                  { id: 0, name: 'chgPauseFlag', ValueName: 'chgPauseFlag', Typ: 'D2M', MT: 3, OT: 'acChgCfg'},
                              
                              

                              der obige ist für D2M, wäre mal zu probieren, ob es ohne die anderen Parameter geht.

                              also der String muß für DeltaMax (nicht die 2er) der zu senden ist muß so aussehen:

                              msg: {
                              					from: 'Android',
                              					operateType: 'TCP',
                              					id: '747329085',
                              					lang: 'en-us',
                              					params: { id: 69, chgPause: 1 },
                              					version: '1.0'
                              				}
                              

                              mit der DeltaMax geht das wunderbar, 0=keine Pause, 1=Pause

                              ich denke eher, daß es im script für DM so aussehen sollte (MT braucht es nicht)

                              { id: 0, name: 'chgPauseFlag', ValueName: 'chgPause', Typ: 'DM', MT: 3, OT: 'TCP'},
                              

                              Übrigens ist meine Adapterarbeit iobroker.ecoflow-mqtt quasi fertig. Werde ggf. heute noch einen neuen Thread dazu eröffnen.

                              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
                              1
                              • W Waly_de

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

                                mal ne Frage wollte gerne über dem Script nur die Grundlast plus 50 Watt decken aber wenn ich anstatt Wechselrichter Leistung 800 Watt auf 150 Watt stelle wird nicht mehr in den Akku geladen der Rest geht dann als Überschuss ins Netz , also wie kann ich 150 Watt maximal einspeisen und trotzdem mit voller Leistung laden falls die mal kommt…

                                der Parameter "MaxPower" legt die maximale Einspeiseleistung fest.
                                Wieviel der PS in die Batterie lädt kann das Script nicht begrenzen.
                                Also sollte alles > "MaxPower" auch in die Batterie gehen.

                                M Offline
                                M Offline
                                Milchbeck
                                schrieb am zuletzt editiert von
                                #737

                                @waly_de also gerade nochmal beobachtet die Delta 2 Max lädt nur soviel mit Leistung auf wie auch Power steht mit Offset 10Watt sobald ich auf 600 stelle geht alles rein in den Akku was geht

                                F 1 Antwort Letzte Antwort
                                0
                                • M Milchbeck

                                  @waly_de also gerade nochmal beobachtet die Delta 2 Max lädt nur soviel mit Leistung auf wie auch Power steht mit Offset 10Watt sobald ich auf 600 stelle geht alles rein in den Akku was geht

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

                                  Wie schon mal angekündigt, ich habe den Ecoflow Geräten mal einen eigenen Adapter spendiert.
                                  Dank der guten Arbeit von @Waly_de konnte ich mir an manchen Stellen Arbeit sparen.

                                  Der Adapter soll nicht das hier vorhanden script überflüssig machen, vielmehr scheint eine Entkopplung zwischen Gerätelogik und eigentliches Script sinnvoll. Benennung, Einheiten und Umrechnungen sind alle im Adapter enthalten, so daß man sich in den vielen Daten besser zurechtfindet.

                                  Hier der Thread dazu:
                                  https://forum.iobroker.net/topic/69819/neuer-adapter-ecoflow-mqtt

                                  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
                                  • K karo2204

                                    @waly_de Script hat heute Nacht super funktioniert. Danke!

                                    Wenn ich jetzt noch etwas frage, dann springst Du wahrscheinlich aus dem Fenster, aber vielleicht ist es ja zu :)

                                    Kann man jetzt in das zusätzliche Script einbauen, dass wenn der SOC von 100% erreicht ist, er wieder auf Strom-Prio umschaltet? Also entweder andere Levels oder SOC, was zuerst kommt?

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

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

                                    Kann man jetzt in das zusätzliche Script einbauen, dass wenn der SOC von 100% erreicht ist, er wieder auf Strom-Prio umschaltet? Also entweder andere Levels oder SOC, was zuerst kommt?

                                    OK.. Da ich auch Tibber bestellt habe und es vielleicht auch für andere Interessant ist, hab ich ein Modul-Script dafür erstellt. Das kann als eigenes, neues Script neben dem Hauptscript angelegt werden.

                                    Modul Quelltext ist jetzt im Eingansbeitrag

                                    K 2 Antworten Letzte Antwort
                                    0
                                    • W Waly_de

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

                                      Kann man jetzt in das zusätzliche Script einbauen, dass wenn der SOC von 100% erreicht ist, er wieder auf Strom-Prio umschaltet? Also entweder andere Levels oder SOC, was zuerst kommt?

                                      OK.. Da ich auch Tibber bestellt habe und es vielleicht auch für andere Interessant ist, hab ich ein Modul-Script dafür erstellt. Das kann als eigenes, neues Script neben dem Hauptscript angelegt werden.

                                      Modul Quelltext ist jetzt im Eingansbeitrag

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

                                      @waly_de Oh wow danke Dir.

                                      Ich muss sagen seit ich Dein extra Script eingebaut habe, funktioniert es super, auch heute Nacht wieder.

                                      ioBroker
                                      Tibber
                                      Ecoflow Powerstream & Delta Max 2000

                                      1 Antwort Letzte Antwort
                                      0
                                      • W Waly_de

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

                                        Kann man jetzt in das zusätzliche Script einbauen, dass wenn der SOC von 100% erreicht ist, er wieder auf Strom-Prio umschaltet? Also entweder andere Levels oder SOC, was zuerst kommt?

                                        OK.. Da ich auch Tibber bestellt habe und es vielleicht auch für andere Interessant ist, hab ich ein Modul-Script dafür erstellt. Das kann als eigenes, neues Script neben dem Hauptscript angelegt werden.

                                        Modul Quelltext ist jetzt im Eingansbeitrag

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

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

                                                                                                                                                                    //*************************************************************                                                                                                                                                                            // 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') {                                                                                                                                                                                if (getState("0_userdata.0.ecoflow.Settings.ConfigData").val.email !== undefined) {                                                                                                                                                                                    ConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val;                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                                                                                                                                                                                                         /***************************************                                                                                                                                                                            **********  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.")                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                            //*************************************************************                                            
                                        

                                        Ich bekomme hier den Fehler angezeigt:

                                        javascript.0 (52431) script.js.Ecoflow-Tibber: TypeError: Cannot read properties of null (reading 'email')
                                        07:11:14.323	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:25:65
                                        07:11:14.324	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:119:3
                                        

                                        Was kann ich da machen?

                                        ioBroker
                                        Tibber
                                        Ecoflow Powerstream & Delta Max 2000

                                        W K 2 Antworten Letzte Antwort
                                        0
                                        • K karo2204

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

                                                                                                                                                                      //*************************************************************                                                                                                                                                                            // 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') {                                                                                                                                                                                if (getState("0_userdata.0.ecoflow.Settings.ConfigData").val.email !== undefined) {                                                                                                                                                                                    ConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val;                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                                                                                                                                                                                                         /***************************************                                                                                                                                                                            **********  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.")                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                            //*************************************************************                                            
                                          

                                          Ich bekomme hier den Fehler angezeigt:

                                          javascript.0 (52431) script.js.Ecoflow-Tibber: TypeError: Cannot read properties of null (reading 'email')
                                          07:11:14.323	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:25:65
                                          07:11:14.324	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:119:3
                                          

                                          Was kann ich da machen?

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

                                          @karo2204

                                          sorry... mein Fehler. Hier der Fix:

                                          Modul Quelltext ist jetzt im Eingansbeitrag 
                                          
                                          K 2 Antworten Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          759

                                          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
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe