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

  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. ecoflow-connector-Script zur dynamischen Leistungsanpassung

NEWS

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

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

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

ecoflow-connector-Script zur dynamischen Leistungsanpassung

Geplant Angeheftet Gesperrt Verschoben JavaScript
1.6k Beiträge 127 Kommentatoren 742.7k 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.
  • M Milchbeck

    hab eine warnmeldung

    20.11.2023, 14:51:41.506	[info ]: javascript.0 (189) Stop script script.js.Ecoflow_1_6
    20.11.2023, 14:51:41.507	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Ecoflow MQTT-Client beendet
    20.11.2023, 14:51:41.558	[info ]: javascript.0 (189) Start javascript script.js.Ecoflow_1_6
    20.11.2023, 14:51:41.574	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
    20.11.2023, 14:51:41.660	[warn ]: javascript.0 (189)     at script.js.Ecoflow_1_6:1782:68
    20.11.2023, 14:51:41.693	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Verbunden mit dem Ecoflow MQTT-Broker
    20.11.2023, 14:52:17.828	[info ]: javascript.0 (189) Stop script script.js.Ecoflow_1_6
    20.11.2023, 14:52:17.829	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Ecoflow MQTT-Client beendet
    20.11.2023, 14:52:17.876	[info ]: javascript.0 (189) Start javascript script.js.Ecoflow_1_6
    20.11.2023, 14:52:17.887	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
    20.11.2023, 14:52:17.985	[warn ]: javascript.0 (189)     at script.js.Ecoflow_1_6:1782:68
    20.11.2023, 14:52:18.016	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Verbunden mit dem Ecoflow MQTT-Broker
    20.11.2023, 14:52:35.119	[info ]: javascript.0 (189) Stop script script.js.Ecoflow_1_6
    20.11.2023, 14:52:35.120	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Ecoflow MQTT-Client beendet
    20.11.2023, 14:52:47.892	[info ]: javascript.0 (189) Start javascript script.js.Ecoflow_1_6
    20.11.2023, 14:52:47.904	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
    20.11.2023, 14:52:48.003	[warn ]: javascript.0 (189)     at script.js.Ecoflow_1_6:1782:68
    20.11.2023, 14:52:48.037	[info ]: javascript.0 (189) script.js.Ecoflow_1_6: Verbunden mit dem Ecoflow MQTT-Broker
    
    W Offline
    W Offline
    Waly_de
    schrieb am zuletzt editiert von
    #782

    @milchbeck

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

    hab eine warnmeldung

    Kannst Du bitte mal in das große Protokoll (Menüleistenpunkt) sehen? Da sollte einiges mehr an Information stehen.
    Es sieht so aus, als hätte es was mit der Konfiguration zu tun:

    AdditionalPower: [
            {
                name: "Hoymiles2000",
                id: "off-mqtt.0.solar.116491437470.0.power"
            },
        ],
    

    Guck mal bitte, was Du da eingetragen hast.

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

      An die Tibber Nutzer:

      ich habe ein Script geschrieben, das die Zählerdaten des Pulse lokal, also ohne den Umweg über die Cloud auslesen und in IoBroker Zustände schreiben kann.

      Ich weiß, das es mit der Cloud schon mal Probleme gibt, oder die Werte sehr verzögert ankommen.
      Das Script kann bisher nur Zähler auslesen, die die SML-Sprache sprechen. Probier es mal aus, wenn Daten ankommen, aber nicht ausgewertet werden können, meldet Euch bitte mit der genauen Bezeichnung Eures Zählers und einem HexDump der Daten, die der Pulse liefert.
      Die stehen dann im Zustand: 0_userdata.0.TibberPulse.SMLDataHEX

      Im Script muss eigentlich nur das Web-Passwort der Pulse-Bridge eingetragen werden.
      Vielleicht muss auch der Host angepasst werden.
      Ihr müsst nur die Weboberfläche der Bridge dauerhaft aktivieren.
      Wie das geht hat marq24 für seine HomeAssistant Anbindung hier super beschrieben:

      https://github.com/marq24/ha-tibber-pulse-local

      Wenn alles klappt, werden die Zählerdaten alle 2 Sekunden in IOBroker-States geschrieben und Ihr könnt im Script diese Konfiguration angeben:

      SmartmeterID: "0_userdata.0.TibberPulse.SML.Power"
      

      Hier das Script: (update 21.11.23 18:39)

      var TibberConfig = {
          password: "XXXX-XXXX",
          statesPrefix: "0_userdata.0.TibberPulse",
          interval: 2000,
          host: "tibber-host",
      }
      const debug = false
      const http = require('http');
      async function getPulseData(password) {
          const auth = Buffer.from(`admin:${password}`).toString('base64');
          const options = {
              hostname: TibberConfig.host,
              path: '/metrics.json?node_id=1',
              method: 'GET',
              headers: {
                  'Authorization': `Basic ${auth}`,
                  'Host': 'tibber-host',
                  'lang': 'de-de',
                  'content-type': 'application/json',
                  'user-agent': 'okhttp/3.14.9'
              }
          };
      
          function httpRequest(options) {
              return new Promise((resolve, reject) => {
                  const req = http.request(options, res => {
                      let data = '';
                      res.on('data', chunk => {
                          data += chunk;
                      });
                      res.on('end', () => {
                          resolve(data);
                      });
                  });
      
                  req.on('error', error => {
                      reject(error);
                  });
      
                  req.end();
              });
          }
      
          try {
              let response = await (httpRequest(options));
              return response.replace("$type", "type"); // Gibt das Antwortobjekt zurück
          } catch (error) {
              console.error("Ein Fehler bei der Ermittlung der Zugangsdaten ist aufgetreten. Bitte prüfe die Zugangsdaten.");
              throw error;
          }
      }
      function getDataAsHexString(password) {
          return new Promise((resolve, reject) => {
              const auth = Buffer.from(`admin:${password}`).toString('base64');
              const options = {
                  hostname: TibberConfig.host,
                  path: '/data.json?node_id=1',
                  headers: {
                      'Authorization': `Basic ${auth}`
                  }
              };
              http.get(options, res => {
                  const chunks = [];
                  res.on('data', chunk => {
                      chunks.push(chunk);
                  });
                  res.on('end', () => {
                      const buffer = Buffer.concat(chunks);
                      const hexString = buffer.toString('hex');
                      resolve(hexString);
                  });
              }).on('error', error => {
                  reject(error);
              });
          });
      }
      function isState2(strStatePath, strict = true) {
          let mSelector;
          if (strict) {
              mSelector = $(strStatePath);
          } else {
              mSelector = $(strStatePath + "*");
          }
          if (mSelector.length > 0) {
              return true;
          } else {
              return false;
          }
      }
      
      function isValidUnixTimestampAndConvert(n) {
          // Typüberprüfung
          if (typeof n !== 'number') {
              return false;
          }
          // Bereichsüberprüfung (optional)
          const unixEpoch = 0; // UNIX-Epoch: 1. Januar 1970
          const currentTime = Math.floor(Date.now() / 1000);
          if (n < unixEpoch || n > currentTime) {
              return false;
          }
          // Granularität (optional)
          if (Math.floor(n) !== n) {
              return false;
          }
          // Konvertiere zu deutschem Zeitformat
          const date = new Date(n * 1000);
          const germanTimeFormat = date.toLocaleString('de-DE');
          return germanTimeFormat;
      }
      
      function generateAndSyncSub(id, JElements, sub = false, preset = "") {
          //log("Aufruf:" + JElements)
          if (!JElements || typeof JElements !== 'object') {
              log('Ungültige JElements übergeben!: ' + JElements); //
              return;
          }
          for (var JElement in JElements) {
              var AktVal;
              if (typeof JElements[JElement] === "object") {
                  if (id === "") {
                      generateAndSyncSub(JElement, JElements[JElement], true, preset);
                  } else {
                      generateAndSyncSub(id + "." + JElement, JElements[JElement], true, preset);
                  }
      
                  //generateAndSyncSub(id + "." + JElement, JElements[JElement], true, preset);
              } else {
                  try {
                      if (isState2(preset + "." + id + "." + JElement)) AktVal = getState(preset + "." + id + "." + JElement).val; else AktVal = null
                  } catch (e) {
                      log("Fehler: " + e); //
                  }
                  // Überprüfung für den Elementnamen "timestamp"
                  if (JElement === "timestamp") {
                      const TimeValue = isValidUnixTimestampAndConvert(JElements[JElement])
                      if (TimeValue) JElements[JElement] = TimeValue;
                  }
                  if (AktVal == null) {
                      createState(preset + "." + id + "." + JElement, JElements[JElement], false);
                      AktVal = JElements[JElement];
                  }
                  if (AktVal != JElements[JElement]) {
                      if (isState2(preset + "." + id + "." + JElement)) {
                          setState(preset + "." + id + "." + JElement, JElements[JElement], true);
                      }
                  }
              }
          }
      }
      
      const obisCodesWithNames = [
          { code: "0100100700ff", name: "Power" },
          { code: "0100010800ff", name: "Import_total" },
          { code: "0100020800ff", name: "Export_total" },
          { code: "0100010800ff_in_k", name: "Import_total_(kWh)" },
          { code: "0100020800ff_in_k", name: "Export_total_(kWh)" },
          { code: "0100240700ff", name: "Power_L1" },
          { code: "0100380700ff", name: "Power_L2" },
          { code: "01004c0700ff", name: "Power_L3" },
          { code: "0100200700ff", name: "Potential_L1" },
          { code: "0100340700ff", name: "Potential_L2" },
          { code: "0100480700ff", name: "Potential_L3" },
          { code: "01001f0700ff", name: "Current_L1" },
          { code: "0100330700ff", name: "Current_L2" },
          { code: "0100470700ff", name: "Current_L3" },
          { code: "01000e0700ff", name: "Net_frequency" },
          { code: "0100510701ff", name: "Potential_Phase_deviation_L1/L2" },
          { code: "0100510702ff", name: "Potential_Phase_deviation_L1/L3" },
          { code: "0100510704ff", name: "Current/Potential_L1_Phase_deviation" },
          { code: "010051070fff", name: "Current/Potential_L2_Phase_deviation" },
          { code: "010051071aff", name: "Current/Potential_L3_Phase_deviation" }
      ];
      function findObisCodeName(code, obisCodesWithNames) {
          const found = obisCodesWithNames.find(item => item.code === code);
          return found ? found.name : "Unbekannt";
      }
      
      /**
       * Static lookup table
       */
      const dlmsUnits = [
          { code: 0x1, unit: "a", quantity: "time", unitName: "year", siDefinition: "52*7*24*60*60 s" },
          { code: 0x2, unit: "mo", quantity: "time", unitName: "month", siDefinition: "31*24*60*60 s" },
          { code: 0x3, unit: "wk", quantity: "time", unitName: "week", siDefinition: "7*24*60*60 s" },
          { code: 0x4, unit: "d", quantity: "time", unitName: "day", siDefinition: "24*60*60 s" },
          { code: 0x5, unit: "h", quantity: "time", unitName: "hour", siDefinition: "60*60 s" },
          { code: 0x6, unit: "min.", quantity: "time", unitName: "min", siDefinition: "60 s" },
          { code: 0x7, unit: "s", quantity: "time", unitName: "second", siDefinition: "s" },
          { code: 0x8, unit: "°", quantity: "phase angle", unitName: "degree", siDefinition: "rad*180/π" },
          { code: 0x9, unit: "°C", quantity: "temperature", unitName: "degree celsius", siDefinition: "K-273.15" },
          { code: 0xA, unit: "currency", quantity: "local currency", unitName: "", siDefinition: "" },
          { code: 0xB, unit: "m", quantity: "length", unitName: "metre", siDefinition: "m" },
          { code: 0xC, unit: "m/s", quantity: "speed", unitName: "metre per second", siDefinition: "m/s" },
          { code: 0xD, unit: "m³", quantity: "volume", unitName: "cubic metre", siDefinition: "m³" },
          { code: 0xE, unit: "m³", quantity: "corrected volume", unitName: "cubic metre", siDefinition: "m³" },
          { code: 0xF, unit: "m³/h", quantity: "volume flux", unitName: "cubic metre per hour", siDefinition: "m³/(60*60s)" },
          { code: 0x10, unit: "m³/h", quantity: "corrected volume flux", unitName: "cubic metre per hour", siDefinition: "m³/(60*60s)" },
          { code: 0x11, unit: "m³/d", quantity: "volume flux", unitName: "cubic metre per day", siDefinition: "m³/(24*60*60s)" },
          { code: 0x12, unit: "m³/d", quantity: "corrected volume flux", unitName: "cubic metre per day", siDefinition: "m³/(24*60*60s)" },
          { code: 0x13, unit: "l", quantity: "volume", unitName: "litre", siDefinition: "10-3 m³" },
          { code: 0x14, unit: "kg", quantity: "mass", unitName: "kilogram", siDefinition: "" },
          { code: 0x15, unit: "N", quantity: "force", unitName: "newton", siDefinition: "" },
          { code: 0x16, unit: "Nm", quantity: "energy", unitName: "newtonmeter", siDefinition: "J = Nm = Ws" },
          { code: 0x17, unit: "Pa", quantity: "pressure", unitName: "pascal", siDefinition: "N/m²" },
          { code: 0x18, unit: "bar", quantity: "pressure", unitName: "bar", siDefinition: "10⁵ N/m²" },
          { code: 0x19, unit: "J", quantity: "energy", unitName: "joule", siDefinition: "J = Nm = Ws" },
          { code: 0x1A, unit: "J/h", quantity: "thermal power", unitName: "joule per hour", siDefinition: "J/(60*60s)" },
          { code: 0x1B, unit: "W", quantity: "active power", unitName: "watt", siDefinition: "W = J/s" },
          { code: 0x1C, unit: "VA", quantity: "apparent power", unitName: "volt-ampere", siDefinition: "" },
          { code: 0x1D, unit: "var", quantity: "reactive power", unitName: "var", siDefinition: "" },
          { code: 0x1E, unit: "Wh", quantity: "active energy", unitName: "watt-hour", siDefinition: "W*(60*60s)" },
          { code: 0x1F, unit: "VAh", quantity: "apparent energy", unitName: "volt-ampere-hour", siDefinition: "VA*(60*60s)" },
          { code: 0x20, unit: "varh", quantity: "reactive energy", unitName: "var-hour", siDefinition: "var*(60*60s)" },
          { code: 0x21, unit: "A", quantity: "current", unitName: "ampere", siDefinition: "A" },
          { code: 0x22, unit: "C", quantity: "electrical charge", unitName: "coulomb", siDefinition: "C = As" },
          { code: 0x23, unit: "V", quantity: "voltage", unitName: "volt", siDefinition: "V" },
          { code: 0x24, unit: "V/m", quantity: "electric field strength", unitName: "volt per metre", siDefinition: "" },
          { code: 0x25, unit: "F", quantity: "capacitance", unitName: "farad", siDefinition: "C/V = As/V" },
          { code: 0x26, unit: "Ω", quantity: "resistance", unitName: "ohm", siDefinition: "Ω = V/A" },
          { code: 0x27, unit: "Ωm²/m", quantity: "resistivity", unitName: "Ωm", siDefinition: "" },
          { code: 0x28, unit: "Wb", quantity: "magnetic flux", unitName: "weber", siDefinition: "Wb = Vs" },
          { code: 0x29, unit: "T", quantity: "magnetic flux density", unitName: "tesla", siDefinition: "Wb/m2" },
          { code: 0x2A, unit: "A/m", quantity: "magnetic field strength", unitName: "ampere per metre", siDefinition: "A/m" },
          { code: 0x2B, unit: "H", quantity: "inductance", unitName: "henry", siDefinition: "H = Wb/A" },
          { code: 0x2C, unit: "Hz", quantity: "frequency", unitName: "hertz", siDefinition: "1/s" },
          { code: 0x2D, unit: "1/(Wh)", quantity: "R_W", unitName: "Active energy meter constant or pulse value", siDefinition: "" },
          { code: 0x2E, unit: "1/(varh)", quantity: "R_B", unitName: "reactive energy meter constant or pulse value", siDefinition: "" },
          { code: 0x2F, unit: "1/(VAh)", quantity: "R_S", unitName: "apparent energy meter constant or pulse value", siDefinition: "" },
          { code: 0x30, unit: "V²h", quantity: "volt-squared hour", unitName: "volt-squaredhours", siDefinition: "V²(60*60s)" },
          { code: 0x31, unit: "A²h", quantity: "ampere-squared hour", unitName: "ampere-squaredhours", siDefinition: "A²(60*60s)" },
          { code: 0x32, unit: "kg/s", quantity: "mass flux", unitName: "kilogram per second", siDefinition: "kg/s" },
          { code: 0x33, unit: "S, mho", quantity: "conductance siemens", unitName: "siemens", siDefinition: "1/Ω" },
          { code: 0x34, unit: "K", quantity: "temperature", unitName: "kelvin", siDefinition: "" },
          { code: 0x35, unit: "1/(V²h)", quantity: "", unitName: "Volt-squared hour meter constant or pulse value", siDefinition: "" },
          { code: 0x36, unit: "1/(A²h)", quantity: "", unitName: "Ampere-squared hour meter constant or pulse value", siDefinition: "" },
          { code: 0x37, unit: "1/m³", quantity: "R_V", unitName: "meter constant or pulse value (volume)", siDefinition: "" },
          { code: 0x38, unit: "%", quantity: "percentage", unitName: "%", siDefinition: "" },
          { code: 0x39, unit: "Ah", quantity: "ampere-hours", unitName: "ampere-hour", siDefinition: "" },
          { code: 0x3C, unit: "Wh/m³", quantity: "energy per volume", unitName: "", siDefinition: "3,6*103 J/m³" },
          { code: 0x3D, unit: "J/m³", quantity: "calorific value, wobbe", unitName: "", siDefinition: "" },
          { code: 0x3E, unit: "Mol %", quantity: "molar fraction of", unitName: "mole percent", siDefinition: "Basic gas composition unit" },
          { code: 0x3F, unit: "Wh/m³", quantity: "energy per volume", unitName: "", siDefinition: "3,6*103 J/m³" },
          { code: 0x40, unit: "(reserved)", quantity: "", unitName: "", siDefinition: "" },
          { code: 0x41, unit: "(other)", quantity: "", unitName: "", siDefinition: "" },
          { code: 0x42, unit: "(unitless)", quantity: "no unit, unitless, count", unitName: "", siDefinition: "" },
          { code: 0x0, unit: "", quantity: "", unitName: "", siDefinition: "stop condition for iterator" }
      ];
      
      function findDlmsUnitByCode(decimalCode, dlmsUnits) {
          const found = dlmsUnits.find(item => item.code === decimalCode);
          return found ? found.unit : "";
      }
      
      function parseSignedHex(hexStr) {
          let num = BigInt("0x" + hexStr);
          let bitLength = hexStr.length * 4;
          if (bitLength <= 32) {
              // Behandlung als 32-Bit-Zahl
              if (num > 0x7FFFFFFF) {
                  num = num - 0x100000000n;
              }
          } else {
              // Behandlung als 64-Bit-Zahl
              if (num > 0x7FFFFFFFFFFFFFFFn) {
                  num = num - 0x10000000000000000n;
              }
          }
          return Number(num.toString());
      }
      
      function extractAndParseSMLMessages(transfer) {
          const messages = transfer.matchAll(/7707(0100[0-9a-fA-F].{5}?ff).{6,14}?([0-9a-fA-F]{2})52([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{4,16})01(?=7)/g);
          for (const match of messages) {
              let result = {}
              if (debug) console.log('Gesamte Übereinstimmung:' + match[0]);
              //console.log('Gruppe 1:'+ match[1]); // Der Teil, der dem ersten Klammerausdruck entspricht
              //console.log('Gruppe 2:'+ match[2]); // Der Teil, der dem zweiten Klammerausdruck entspricht
              //console.log('Gruppe 3:'+ match[3]); // Der Teil, der dem dritten Klammerausdruck entspricht
              //console.log('Gruppe 4:'+ match[4]); // Der Teil, der dem dritten Klammerausdruck entspricht
              //console.log('Gruppe 5:'+ match[5]); // Der Teil, der dem vierten Klammerausdruck entspricht
              
              result.name = findObisCodeName(match[1], obisCodesWithNames)
              result.value = parseSignedHex(match[5])
              const decimalCode = parseInt(match[2], 16);
              result.unit = findDlmsUnitByCode(decimalCode, dlmsUnits)
              
              if (match[3].toLowerCase() == "ff") {
                  result.value = result.value / 10
              } else if (match[3].toLowerCase() == "fe") {
                  result.value = result.value / 100
              }
              const valId = TibberConfig.statesPrefix + ".SML." + result.name
              if (isState2(valId)) {
                  setStateAsync(valId, result.value, true)
              } else {
                  let common = {
                      name: result.name,
                      type: 'mixed',
                      role: 'state',
                      unit: result.unit,
                      read: true,
                      write: true,
                  };
                  let native = {}
                  createState(valId, result.value, false, common, native);
              }
              if (debug) log(JSON.stringify(result))
          }
      }
      function swapEndianness(hexStr) {
          const result = [];
          for (let i = 0; i < hexStr.length; i += 2) {
              result.unshift(hexStr.substring(i, i + 2));
          }
          return result.join('');
      }
      if (typeof TestData == 'undefined') {
          getPulseData(TibberConfig.password).then(response => {
              if (debug) console.log("Bridge Data: " + response); // 
              generateAndSyncSub("Data", JSON.parse(response), false, TibberConfig.statesPrefix)
          }).catch(error => {
              console.error(error);
          });
      
          //jede x Sekunden
          var intervalID = setInterval(function () {
              // Daten abrufen und als HEX-String ausgeben
              getDataAsHexString(TibberConfig.password).then(hexString => {
                  extractAndParseSMLMessages(hexString);
                  if (debug) console.log(hexString); // Gibt die Daten als HEX-String aus
                  if (isState2(TibberConfig.statesPrefix + ".SMLDataHEX")) {
                      setState(TibberConfig.statesPrefix + ".SMLDataHEX", hexString, true)
                  } else {
                      createState(TibberConfig.statesPrefix + ".SMLDataHEX", hexString, false);
                  }
              }).catch(error => {
                  log('Fehler beim Abrufen der Daten:' + error);
              });
          }, TibberConfig.interval);
      }else{
          const parsedMessages = extractAndParseSMLMessages(TestData);
      }
      
      
      K 1 Antwort Letzte Antwort
      1
      • W Waly_de

        @aherby Ja klar, gerne.
        Geht das jetzt? Ich habe noch immer die alte Software auf der PS. Kann es sein, das die neue Software bisher nur für die 800 W Versionen raus ist?

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

        @waly_de Also ich habe auch nur die 600 W Version. Die neuen Firmware auf alen Smartplugs sind ein muss sonst funktioniert es nicht mit dem aus- oder abwahl der Smarplugs bezüglich berücksichtigen beim Haushaltsbedarf. "Wählen Sie die Geräte aus, die Sie dem System für das Energiemanagement hinzufügen möchten"
        Weiterhin gibt es einen Schalter der wohl ermöglicht bei vollen Akku die Überschusseinspeisung aus- oder einschalten soll

        F 1 Antwort Letzte Antwort
        0
        • A aherby

          @waly_de Also ich habe auch nur die 600 W Version. Die neuen Firmware auf alen Smartplugs sind ein muss sonst funktioniert es nicht mit dem aus- oder abwahl der Smarplugs bezüglich berücksichtigen beim Haushaltsbedarf. "Wählen Sie die Geräte aus, die Sie dem System für das Energiemanagement hinzufügen möchten"
          Weiterhin gibt es einen Schalter der wohl ermöglicht bei vollen Akku die Überschusseinspeisung aus- oder einschalten soll

          F Offline
          F Offline
          foxthefox
          Developer
          schrieb am zuletzt editiert von
          #785

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

          @waly_de Also ich habe auch nur die 600 W Version. Die neuen Firmware auf alen Smartplugs sind ein muss sonst funktioniert es nicht mit dem aus- oder abwahl der Smarplugs bezüglich berücksichtigen beim Haushaltsbedarf. "Wählen Sie die Geräte aus, die Sie dem System für das Energiemanagement hinzufügen möchten"
          Weiterhin gibt es einen Schalter der wohl ermöglicht bei vollen Akku die Überschusseinspeisung aus- oder einschalten soll

          Der Schalter ist mit Version (1.1.6.2) 4.11.2023

          • Neues PowerStream-Writeable "feed_priority" eingebaut 0: Wenn Batt voll, alle PV-Power einspeisen 1: Nur was eingestellt ist

          schon dabei.

          Adapterüberblick: Profil Github;

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

          Ein Aufruf: video

          A 1 Antwort Letzte Antwort
          0
          • F foxthefox

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

            @waly_de Also ich habe auch nur die 600 W Version. Die neuen Firmware auf alen Smartplugs sind ein muss sonst funktioniert es nicht mit dem aus- oder abwahl der Smarplugs bezüglich berücksichtigen beim Haushaltsbedarf. "Wählen Sie die Geräte aus, die Sie dem System für das Energiemanagement hinzufügen möchten"
            Weiterhin gibt es einen Schalter der wohl ermöglicht bei vollen Akku die Überschusseinspeisung aus- oder einschalten soll

            Der Schalter ist mit Version (1.1.6.2) 4.11.2023

            • Neues PowerStream-Writeable "feed_priority" eingebaut 0: Wenn Batt voll, alle PV-Power einspeisen 1: Nur was eingestellt ist

            schon dabei.

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

            @foxthefox Da mein System gerade entladen ist und ich nicht am Ort bin konnte ich es nicht genauer beschreiben. Du hast natürlich völlig recht mit dem "Schalter".
            Hast du für dieses Script dann auchs chon die entsprechenden Codezeilen herausgefunden
            dann muss ich nicht mehr versuchen diese genauer zu ermitteln.

            F 1 Antwort Letzte Antwort
            0
            • A aherby

              @foxthefox Da mein System gerade entladen ist und ich nicht am Ort bin konnte ich es nicht genauer beschreiben. Du hast natürlich völlig recht mit dem "Schalter".
              Hast du für dieses Script dann auchs chon die entsprechenden Codezeilen herausgefunden
              dann muss ich nicht mehr versuchen diese genauer zu ermitteln.

              F Offline
              F Offline
              foxthefox
              Developer
              schrieb am zuletzt editiert von
              #787

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

              @foxthefox Da mein System gerade entladen ist und ich nicht am Ort bin konnte ich es nicht genauer beschreiben. Du hast natürlich völlig recht mit dem "Schalter".
              Hast du für dieses Script dann auchs chon die entsprechenden Codezeilen herausgefunden
              dann muss ich nicht mehr versuchen diese genauer zu ermitteln.

              Ich denk du musst nichts mehr herausfinden. Der Schalter sollte funktionstüchtig sein. Kommando und Ablageort im protobuf sind schon ermittelt.

              Adapterüberblick: Profil Github;

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

              Ein Aufruf: video

              A 1 Antwort Letzte Antwort
              0
              • F foxthefox

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

                @foxthefox Da mein System gerade entladen ist und ich nicht am Ort bin konnte ich es nicht genauer beschreiben. Du hast natürlich völlig recht mit dem "Schalter".
                Hast du für dieses Script dann auchs chon die entsprechenden Codezeilen herausgefunden
                dann muss ich nicht mehr versuchen diese genauer zu ermitteln.

                Ich denk du musst nichts mehr herausfinden. Der Schalter sollte funktionstüchtig sein. Kommando und Ablageort im protobuf sind schon ermittelt.

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

                @foxthefox Sehr cool danke. Und mit den Smartplugs diese bei der Ermittlung vom Haushaltsbedarf zu berücksichtigen oder eben nicht?

                Anderes Thema habt ihr das ggf. auch was ich garnicht so schlecht finde, dass wenn z.B. die D2M einen geringeren Ladestand hat wie in den Einstellungen festgelegt dann wird die Solarenergie direkt ins Hausnetz eingespeist. Also ich finde es gut dann man dann nicht den Akku erst mit verlusten füllt sondern die Energie ins Haus geleitet wird. Sonst wird ja erst bis zu dieser Ladegrenze geladen oder mit einen weiteren Wert von glaube 5%.

                F 1 Antwort Letzte Antwort
                0
                • A aherby

                  @foxthefox Sehr cool danke. Und mit den Smartplugs diese bei der Ermittlung vom Haushaltsbedarf zu berücksichtigen oder eben nicht?

                  Anderes Thema habt ihr das ggf. auch was ich garnicht so schlecht finde, dass wenn z.B. die D2M einen geringeren Ladestand hat wie in den Einstellungen festgelegt dann wird die Solarenergie direkt ins Hausnetz eingespeist. Also ich finde es gut dann man dann nicht den Akku erst mit verlusten füllt sondern die Energie ins Haus geleitet wird. Sonst wird ja erst bis zu dieser Ladegrenze geladen oder mit einen weiteren Wert von glaube 5%.

                  F Offline
                  F Offline
                  foxthefox
                  Developer
                  schrieb am zuletzt editiert von
                  #789

                  @aherby
                  Die Berücksichtigung von Plugs bei der Haushaltslast ist ein neues Thema.
                  Kann mir vorstellen, daß dies als neues Bit im Telegramm der Plugs enthalten ist. Höchstwahrscheinlich nur auf der Bluetooth Ebene.
                  Was wirklich noch fehlt ist die dynamicWatt ohne die plugs schreiben zu können und nicht die permanentWatts zu verwenden.

                  Adapterüberblick: Profil Github;

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

                  Ein Aufruf: video

                  A 1 Antwort Letzte Antwort
                  0
                  • W Waly_de

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

                    Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                    Eine Frage:
                    Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                    Werden die irgendwo ausgelesen durch das Script?

                    Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                    Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                    Hat da jemand einen Tipp?

                    Also ich löse das mit Influxdb 2.0 und grafana. Datenquelle ist der Wert
                    0_userdata.0.ecoflow.totalPV den ich Protokollieren lasse.
                    in Grafana sieht das dann so aus:

                    Bildschirmfoto 2023-11-15 um 10.40.52.jpg

                    hier die Abfrage dazu:

                    from(bucket: "iobroker")
                      |> range(start: -30d, stop: now())
                      |> filter(fn: (r) => r["_measurement"] == "totalPV" and r["_field"] == "value")
                      |> aggregateWindow(every: 60s, fn: mean, createEmpty: false)
                      |> map(fn: (r) => ({
                          _time: r._time,
                          _value: r._value / 60000.0  // Umrechnung von Watt in Kilowatt
                      }))
                      |> aggregateWindow(every: 1d, fn: sum, createEmpty: false, location: {zone: "Europe/Berlin", offset: 0h})  // tägliche Summierung in der angegebenen Zeitzone
                      |> map(fn: (r) => ({
                          _time: r._time,
                         Ertrag: r._value  // Dies ist nun die Summe der Energieverbräuche in kWh pro Tag
                      }))
                      |> yield(name: "kWh_pro_Tag")
                    
                    
                    
                    

                    Kommt bei mir ganz gut hin :-)

                    im Script kannst du ja alle Solarwerte mit den Parametern: AdditionalPower erfassen und in totalPV aufnehmen lassen. Musst nur den Pfad zu dem Zustand in IoBroker angeben.

                    G Offline
                    G Offline
                    guhfy9966
                    schrieb am zuletzt editiert von
                    #790

                    @waly_de

                    Vielen Dank, hat super funktioniert. Kannst du mir noch helfen wie ich mit "Additional Power" einen Solarertrag einer Delta2Max (angeschlossen an PV1) dazu addieren kann?

                    bzw. in TotalPV wird werden nur die Powerstreams summiert oder? Wenn ich also noch einen Eingang einer Delta nutze, muss ich diesen additiv hinzu rechnen?

                    W 1 Antwort Letzte Antwort
                    0
                    • F foxthefox

                      @aherby
                      Die Berücksichtigung von Plugs bei der Haushaltslast ist ein neues Thema.
                      Kann mir vorstellen, daß dies als neues Bit im Telegramm der Plugs enthalten ist. Höchstwahrscheinlich nur auf der Bluetooth Ebene.
                      Was wirklich noch fehlt ist die dynamicWatt ohne die plugs schreiben zu können und nicht die permanentWatts zu verwenden.

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

                      @foxthefox es gab ja jetzt wieder ein Update vom Powerstream, mal schauen was da so durch passiert.
                      mit den Smartplugs und Haushaltslast, könnte es hier in diesem set-Befehlen stecken?

                      /set:0a3b0a020801102018352001280138034002488e015002580170d7b5d02e800113880101ba0103696f73ca0110485735325a4448345346363636353855
                      2023-11-25 09:33:55.889 - warn: javascript.0 (32899) script.js.EcoflowScript_1_1_6_1: Nicht definierter cmd_func-Wert. [SmartPlug 1] cmdId:142 cmdFunc:2
                                    /set:0a35102018352001280138034002488e01580170e5bed02e800113880101ba0103696f73ca0110485735325a4448345346363636353855
                      2023-11-25 09:33:57.057 - warn: javascript.0 (32899) script.js.EcoflowScript_1_1_6_1: Nicht definierter cmd_func-Wert. [SmartPlug 1] cmdId:142 cmdFunc:2
                      
                      F 2 Antworten Letzte Antwort
                      0
                      • A aherby

                        @foxthefox es gab ja jetzt wieder ein Update vom Powerstream, mal schauen was da so durch passiert.
                        mit den Smartplugs und Haushaltslast, könnte es hier in diesem set-Befehlen stecken?

                        /set:0a3b0a020801102018352001280138034002488e015002580170d7b5d02e800113880101ba0103696f73ca0110485735325a4448345346363636353855
                        2023-11-25 09:33:55.889 - warn: javascript.0 (32899) script.js.EcoflowScript_1_1_6_1: Nicht definierter cmd_func-Wert. [SmartPlug 1] cmdId:142 cmdFunc:2
                                      /set:0a35102018352001280138034002488e01580170e5bed02e800113880101ba0103696f73ca0110485735325a4448345346363636353855
                        2023-11-25 09:33:57.057 - warn: javascript.0 (32899) script.js.EcoflowScript_1_1_6_1: Nicht definierter cmd_func-Wert. [SmartPlug 1] cmdId:142 cmdFunc:2
                        
                        F Offline
                        F Offline
                        foxthefox
                        Developer
                        schrieb am zuletzt editiert von
                        #792

                        @aherby
                        Mal schauen was sich daraus ergibt

                        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
                        • G Offline
                          G Offline
                          guhfy9966
                          schrieb am zuletzt editiert von guhfy9966
                          #793

                          Hi,

                          ich habe weiß nicht was bei mir passiert ist, jedoch funktioniert das Script nicht mehr korrekt.
                          Ich habe 3 PS jeweils mit Powerstations (Delta2Max, DeltaPro und Delta Max) verbunden. Ich habe zuletzt ein wenig umgebaut und auch das neuste PS Update gefahren. Seitdem funktioniert nur noch ein PS und bei den anderen speist er nicht mehr aus den Akkus ein, trotz genügend Kapazität. Die PS ist bei Delta Pro an Port 1, ein Shelly Pro EM3 liest den Bedarf

                          //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                  {
                                    seriennummer: "XXX",              // Die Seriennummer des Gerätes
                                      name: "PowerStream (DeltaPro)",                        // beliebiger Namen
                                      MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                      subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                      typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                      // Parameter an hier nur für PowerStream.     
                                      regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                      RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                      hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                      battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                      battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                      prioOffOnDemand: 0,                         // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                      lowBatLimitPozOn: 10, lowBatLimitPozOff: 45,    // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                      lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                  },
                                  
                                  //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                  {
                                      seriennummer: "XXX",              // Die Seriennummer des Gerätes
                                      name: "PowerStream (DeltaMax)",                        // beliebiger Namen
                                      MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                      subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                      typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                      // Parameter an hier nur für PowerStream.     
                                      regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                      RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                      hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                      battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                      battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                      prioOffOnDemand: 0,                        // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                      lowBatLimitPozOn: 10, lowBatLimitPozOff: 45,// Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                      lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                    
                                  },
                                   //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                  {
                                    seriennummer: "XXXX",              // Die Seriennummer des Gerätes
                                      name: "PowerStream (Delta2Max)",                        // beliebiger Namen
                                      MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                      subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                      typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                      // Parameter an hier nur für PowerStream.     
                                      regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                      RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                      hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                      battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                      battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                      prioOffOnDemand: 0,                        // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                      lowBatLimitPozOn: 12, lowBatLimitPozOff: 45,// Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                      lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                  },
                          

                          im Log kommt nur noch die Delta2Max korrekt :

                          PowerStream [PowerStream (Delta2Max)] Batteriestand unter Limit:12% (6%). Limitiere Einspeiseleistung auf: 0W
                          

                          bei den anderen beiden kommt immer nur "Batterie unter 10%, schalte auf Batterie Prio.

                          Habe ich irgendeinen Config Fehler den ich nicht sehe? Er schaltet die Prioritäten nicht mehr korrekt. Ich weiß jetzt nicht ob dies am PS Update oder an meiner CFG liegt.
                          Kann mir hier einer helfen?

                          EDIT: ich habe es nachdem ich gepostet habe selbst gefunden. Der Wert prioOffOnDemand ist ausschlaggebend...wenn man zu lange auf das Script schaut :face_palm:

                          W 1 Antwort Letzte Antwort
                          1
                          • G guhfy9966

                            Hi,

                            ich habe weiß nicht was bei mir passiert ist, jedoch funktioniert das Script nicht mehr korrekt.
                            Ich habe 3 PS jeweils mit Powerstations (Delta2Max, DeltaPro und Delta Max) verbunden. Ich habe zuletzt ein wenig umgebaut und auch das neuste PS Update gefahren. Seitdem funktioniert nur noch ein PS und bei den anderen speist er nicht mehr aus den Akkus ein, trotz genügend Kapazität. Die PS ist bei Delta Pro an Port 1, ein Shelly Pro EM3 liest den Bedarf

                            //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                    {
                                      seriennummer: "XXX",              // Die Seriennummer des Gerätes
                                        name: "PowerStream (DeltaPro)",                        // beliebiger Namen
                                        MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                        subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                        typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                        // Parameter an hier nur für PowerStream.     
                                        regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                        RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                        hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                        battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                        battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                        prioOffOnDemand: 0,                         // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                        lowBatLimitPozOn: 10, lowBatLimitPozOff: 45,    // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                        lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                    },
                                    
                                    //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                    {
                                        seriennummer: "XXX",              // Die Seriennummer des Gerätes
                                        name: "PowerStream (DeltaMax)",                        // beliebiger Namen
                                        MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                        subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                        typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                        // Parameter an hier nur für PowerStream.     
                                        regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                        RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                        hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                        battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                        battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                        prioOffOnDemand: 0,                        // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                        lowBatLimitPozOn: 10, lowBatLimitPozOff: 45,// Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                        lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                      
                                    },
                                     //############# Diesen Abschnitt für jedes einzelne Gerät anlegen ################
                                    {
                                      seriennummer: "XXXX",              // Die Seriennummer des Gerätes
                                        name: "PowerStream (Delta2Max)",                        // beliebiger Namen
                                        MaxPower: 600,                              // Der höchstmögliche Wert in Watt für die Einspeiseleistung
                                        subscribe: true,                            // "true": Alle Daten für dieses Gerät werden angefragt. "false": Es werden keine Statusdaten abgefragt
                                        typ: "PS",                                  // Welches Gerät ist es: Powerstrem:"PS"; DeltaMax:"DM"; Delta2: "D2" ; Delta2 Max: "D2M"; SmartPlug: "SM"; Andere: "NA" 
                                        // Parameter an hier nur für PowerStream.     
                                        regulation: true,                           // "true": Dieser PowerStream soll vom Script reguliert werden
                                        RegulationOffPower: -1,                     // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)
                                        hasBat: true,                               // "true": Eine Batterie ist angeschlossen. Nur für PowerStream relevant.
                                        battPozOn: 10, battPozOff: 50,              // Wenn die Batterie bei battPozOn ist, Einspeisung auf MaxPower. Bei BattPozOff Normalbetrieb
                                        battOnSwitchPrio: true,                    // "true": Bei battPozOn wird in den Batterie-Prioritätsmodus gewechselt
                                        prioOffOnDemand: 0,                        // Wattwert des Bedarfs, bei dem zurück in den Strom-Priomodus gechaltet wird. 0 für kein Rückschalten.   
                                        lowBatLimitPozOn: 12, lowBatLimitPozOff: 45,// Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf 
                                        lowBatLimit: 0,                           // "lowBatLimit" limitiert, bis der Ladezustand wieder bei "lowBatLimitPozOff" ist
                                    },
                            

                            im Log kommt nur noch die Delta2Max korrekt :

                            PowerStream [PowerStream (Delta2Max)] Batteriestand unter Limit:12% (6%). Limitiere Einspeiseleistung auf: 0W
                            

                            bei den anderen beiden kommt immer nur "Batterie unter 10%, schalte auf Batterie Prio.

                            Habe ich irgendeinen Config Fehler den ich nicht sehe? Er schaltet die Prioritäten nicht mehr korrekt. Ich weiß jetzt nicht ob dies am PS Update oder an meiner CFG liegt.
                            Kann mir hier einer helfen?

                            EDIT: ich habe es nachdem ich gepostet habe selbst gefunden. Der Wert prioOffOnDemand ist ausschlaggebend...wenn man zu lange auf das Script schaut :face_palm:

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

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

                            battPozOn: 10, battPozOff: 50,

                            das sieht auch nicht so aus, als sei es dass was Du willst. Bei 10% Batterie soll er mit 600 W einspeisen, ohne zu regeln? Und ab 50% wieder normal arbeiten? gleichzeitig:

                            lowBatLimitPozOn: 10, lowBatLimitPozOff: 45,
                            ab 10% soll auf lowBatLimit: 0. also 0 Watt Ausgang
                            geschaltet werden, bis die Batterie wieder bei 45% ist?

                            Guck Dir dazu doch noch mal die Standardeinstellungen an. Ich denke die sind eine gute Ausgangsbasis...

                            1 Antwort Letzte Antwort
                            0
                            • G Offline
                              G Offline
                              guhfy9966
                              schrieb am zuletzt editiert von
                              #795

                              Danke für den Hinweis, ich glaube das hatte ich anders interpretiert 🙄.

                              Aktuell bleibt das Script einfach stehen und meine grafana Oberfläche steht. Kein Fehler und ich sehe nicht woher das kommt. Jemand einen tip wie ich das debugge?

                              W 1 Antwort Letzte Antwort
                              0
                              • G guhfy9966

                                Danke für den Hinweis, ich glaube das hatte ich anders interpretiert 🙄.

                                Aktuell bleibt das Script einfach stehen und meine grafana Oberfläche steht. Kein Fehler und ich sehe nicht woher das kommt. Jemand einen tip wie ich das debugge?

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

                                @guhfy9966 auch keine Hinweise im Protokoll?
                                In jedem Fall solltest Du das State-Limit in den Einstellungen vom Javascriptadapter deutlich erhöhen. Bei so vielen Geräten kannst Du es ruhig mal auf 8000 stellen...

                                G 1 Antwort Letzte Antwort
                                0
                                • W Waly_de

                                  @guhfy9966 auch keine Hinweise im Protokoll?
                                  In jedem Fall solltest Du das State-Limit in den Einstellungen vom Javascriptadapter deutlich erhöhen. Bei so vielen Geräten kannst Du es ruhig mal auf 8000 stellen...

                                  G Offline
                                  G Offline
                                  guhfy9966
                                  schrieb am zuletzt editiert von guhfy9966
                                  #797

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

                                  @guhfy9966 auch keine Hinweise im Protokoll?
                                  In jedem Fall solltest Du das State-Limit in den Einstellungen vom Javascriptadapter deutlich erhöhen. Bei so vielen Geräten kannst Du es ruhig mal auf 8000 stellen...

                                  ok, versuche ich mal! THX

                                  Edit: Mein Wert von 6000 war wohl zu niedrig. Mit 8000 läuft alles. Danke!

                                  Mir ist aufgefallen, dass die Powerstreams aktuell immer minimale Leistung abgeben, obwohl ich es (Batterie <10% = 0 Watt Abgabe) eingestellt habe:

                                  Bildschirmfoto 2023-12-02 um 22.59.51.png

                                  Zuvor hatte ich da eine sehr saubere Abgab, die entweder am Verbrauch angelehnt war (also mehrere 100Watt) oder eben 0. Woher kann so ein Effekt kommen?

                                  W 1 Antwort Letzte Antwort
                                  0
                                  • G guhfy9966

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

                                    @guhfy9966 auch keine Hinweise im Protokoll?
                                    In jedem Fall solltest Du das State-Limit in den Einstellungen vom Javascriptadapter deutlich erhöhen. Bei so vielen Geräten kannst Du es ruhig mal auf 8000 stellen...

                                    ok, versuche ich mal! THX

                                    Edit: Mein Wert von 6000 war wohl zu niedrig. Mit 8000 läuft alles. Danke!

                                    Mir ist aufgefallen, dass die Powerstreams aktuell immer minimale Leistung abgeben, obwohl ich es (Batterie <10% = 0 Watt Abgabe) eingestellt habe:

                                    Bildschirmfoto 2023-12-02 um 22.59.51.png

                                    Zuvor hatte ich da eine sehr saubere Abgab, die entweder am Verbrauch angelehnt war (also mehrere 100Watt) oder eben 0. Woher kann so ein Effekt kommen?

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

                                    @guhfy9966 ich habe das bei mir nach dem letzten Firmwareupdate auch beobachtet. Habe da im Moment keine Erklärung oder Lösung. Eigentlich sollte die PS das eigenständig unterbinden.

                                    1 Antwort Letzte Antwort
                                    0
                                    • G guhfy9966

                                      @waly_de

                                      Vielen Dank, hat super funktioniert. Kannst du mir noch helfen wie ich mit "Additional Power" einen Solarertrag einer Delta2Max (angeschlossen an PV1) dazu addieren kann?

                                      bzw. in TotalPV wird werden nur die Powerstreams summiert oder? Wenn ich also noch einen Eingang einer Delta nutze, muss ich diesen additiv hinzu rechnen?

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

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

                                      Vielen Dank, hat super funktioniert. Kannst du mir noch helfen wie ich mit "Additional Power" einen Solarertrag einer Delta2Max (angeschlossen an PV1) dazu addieren kann?

                                      Hast Du das gelöst?
                                      bei mir (Delta Max) sieht das so aus:

                                      AdditionalPower: [
                                              {
                                                  name: "Hoymiles2000",
                                                  id: "mqtt.0.solar.ac.power"
                                              },
                                              {
                                                  name: "Delta PV-Input",
                                                  id: "0_userdata.0.ecoflow.app_device_property_XXX.data.params.mppt.inWatts",
                                                  factor: 10
                                              },
                                          ],
                                      

                                      Das mit dem Faktor funktioniert aber erst in der neuen Version des Skriptes (1.2) das vor der Tür steht.
                                      Die Leistung wird auf diese Weise in "TotalPV" mit aufgenommen.
                                      Ich brauche jetzt nur ein wenig Sonne für den abschießenden Test... also Daumen drücken... ;-)

                                      Ich spoiler schon mal das Changelog:

                                      (1.2) 04.12.2023

                                      • Neue Funktion Überschussladung implementiert:
                                        Bei überschüssiger Leistung kann nun ein zusätzlicher Speicher aktiviert werden.
                                        Da die neue Firmware für die DELTAs inzwischen duales Laden (Solar und AC gleichzeitig) unterstützt, kann damit die
                                        Ladeleistung der Deltas bis 2000W oder mehr erhöht werden. Auch eine Integration von weiteren Wechselrichtern ohne eigene
                                        Batterie wird möglich.
                                        Konfiguration: siehe Einstellungen weiter unten zu "ExcessCharge" (Überschussladung)
                                      • Neuer Parameter unter AdditionalPower: "factor" für den Divisionsfaktor. Bei den Deltas dort 10 angeben.
                                      • Filter gegen Datenflut der Deltas eingebaut, der das System entlastet, wenn auch die Deltas auf "subscribe: true" gestellt werden
                                      • Verschiedene Optimierungen und Bugfixes

                                      die Einstellungen:

                                          //****************************************
                                          // Überschussladung:
                                          //****************************************
                                          ExcessCharge: false,                                //Überschussladung AN/AUS (true/false)
                                                                                              //ID zum Einstellen der Ladeleistung des Speichers in Watt: 
                                          ExcessChargePowerID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.slowChgPower",
                                                                                              //ID des aktuellen Ladestandes des Speichers in %: 
                                          ExcessChargePowerBatSocID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.bmsMaster.soc",
                                          ExcessChargeSwitchMin: 5,                           //Zeit in Minuten die der Schalter mindestens in der letzten geschalteten Position verbleiben muss. 
                                          ExcessChargeMaxPower: 2000,                         //Maximale Ladeleistung des Speichers in Watt
                                          ExcessChargeStartPower: 50,                         //Mindest-Überschussleistung zum Einschalten des Speichers
                                          ExcessChargeStartPowerDurationMin: 2,               //Mindestdauer in Minuten, die ExcessChargeStartPower nicht unterschritten werden darf, bevor der Speicher eingeschaltet wird.
                                          //----------------------------------------
                                          // Beispiel für Delta-Nutzung ohne Schlaltersteckdose:
                                          // Wird an einer Delta auch der PV-Eingang genutzt, bitte die PV-Leistung unter AdditionalPower anlegen. Die passende ID ist:
                                          // 0_userdata.0.ecoflow.app_device_property_xxx.data.params.mppt.inWatts
                                          // Bei der Delta: "subscribe: true" konfigurieren
                                          //----------------------------------------
                                                                                              //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                          //ExcessActualPowerID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.inv.inputWatts",
                                                                                              //ID des Schalters, der den Speicher aktiviert: 
                                          //ExcessChargeSwitchID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.chgPause", 
                                          //ExcessChargeSwitchOn: 0,                          //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                          //ExcessChargeSwitchOff: 1,                         //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                          //----------------------------------------
                                          // Beispiel für Nutzung einer Schlaltersteckdose:
                                          //----------------------------------------
                                                                                              //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                          ExcessActualPowerID: "sonoff.0.NOUS-DVES_F0A844.ENERGY_Power",
                                                                                              //ID des Schalters, der den Speicher aktiviert: 
                                          ExcessChargeSwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", 
                                          ExcessChargeSwitchOn: true,                         //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                          ExcessChargeSwitchOff: false,                       //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                          //----------------------------------------
                                          //****************************************
                                      
                                      G 1 Antwort Letzte Antwort
                                      0
                                      • W Waly_de

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

                                        Vielen Dank, hat super funktioniert. Kannst du mir noch helfen wie ich mit "Additional Power" einen Solarertrag einer Delta2Max (angeschlossen an PV1) dazu addieren kann?

                                        Hast Du das gelöst?
                                        bei mir (Delta Max) sieht das so aus:

                                        AdditionalPower: [
                                                {
                                                    name: "Hoymiles2000",
                                                    id: "mqtt.0.solar.ac.power"
                                                },
                                                {
                                                    name: "Delta PV-Input",
                                                    id: "0_userdata.0.ecoflow.app_device_property_XXX.data.params.mppt.inWatts",
                                                    factor: 10
                                                },
                                            ],
                                        

                                        Das mit dem Faktor funktioniert aber erst in der neuen Version des Skriptes (1.2) das vor der Tür steht.
                                        Die Leistung wird auf diese Weise in "TotalPV" mit aufgenommen.
                                        Ich brauche jetzt nur ein wenig Sonne für den abschießenden Test... also Daumen drücken... ;-)

                                        Ich spoiler schon mal das Changelog:

                                        (1.2) 04.12.2023

                                        • Neue Funktion Überschussladung implementiert:
                                          Bei überschüssiger Leistung kann nun ein zusätzlicher Speicher aktiviert werden.
                                          Da die neue Firmware für die DELTAs inzwischen duales Laden (Solar und AC gleichzeitig) unterstützt, kann damit die
                                          Ladeleistung der Deltas bis 2000W oder mehr erhöht werden. Auch eine Integration von weiteren Wechselrichtern ohne eigene
                                          Batterie wird möglich.
                                          Konfiguration: siehe Einstellungen weiter unten zu "ExcessCharge" (Überschussladung)
                                        • Neuer Parameter unter AdditionalPower: "factor" für den Divisionsfaktor. Bei den Deltas dort 10 angeben.
                                        • Filter gegen Datenflut der Deltas eingebaut, der das System entlastet, wenn auch die Deltas auf "subscribe: true" gestellt werden
                                        • Verschiedene Optimierungen und Bugfixes

                                        die Einstellungen:

                                            //****************************************
                                            // Überschussladung:
                                            //****************************************
                                            ExcessCharge: false,                                //Überschussladung AN/AUS (true/false)
                                                                                                //ID zum Einstellen der Ladeleistung des Speichers in Watt: 
                                            ExcessChargePowerID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.slowChgPower",
                                                                                                //ID des aktuellen Ladestandes des Speichers in %: 
                                            ExcessChargePowerBatSocID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.bmsMaster.soc",
                                            ExcessChargeSwitchMin: 5,                           //Zeit in Minuten die der Schalter mindestens in der letzten geschalteten Position verbleiben muss. 
                                            ExcessChargeMaxPower: 2000,                         //Maximale Ladeleistung des Speichers in Watt
                                            ExcessChargeStartPower: 50,                         //Mindest-Überschussleistung zum Einschalten des Speichers
                                            ExcessChargeStartPowerDurationMin: 2,               //Mindestdauer in Minuten, die ExcessChargeStartPower nicht unterschritten werden darf, bevor der Speicher eingeschaltet wird.
                                            //----------------------------------------
                                            // Beispiel für Delta-Nutzung ohne Schlaltersteckdose:
                                            // Wird an einer Delta auch der PV-Eingang genutzt, bitte die PV-Leistung unter AdditionalPower anlegen. Die passende ID ist:
                                            // 0_userdata.0.ecoflow.app_device_property_xxx.data.params.mppt.inWatts
                                            // Bei der Delta: "subscribe: true" konfigurieren
                                            //----------------------------------------
                                                                                                //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                            //ExcessActualPowerID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.inv.inputWatts",
                                                                                                //ID des Schalters, der den Speicher aktiviert: 
                                            //ExcessChargeSwitchID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.chgPause", 
                                            //ExcessChargeSwitchOn: 0,                          //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                            //ExcessChargeSwitchOff: 1,                         //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                            //----------------------------------------
                                            // Beispiel für Nutzung einer Schlaltersteckdose:
                                            //----------------------------------------
                                                                                                //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                            ExcessActualPowerID: "sonoff.0.NOUS-DVES_F0A844.ENERGY_Power",
                                                                                                //ID des Schalters, der den Speicher aktiviert: 
                                            ExcessChargeSwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", 
                                            ExcessChargeSwitchOn: true,                         //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                            ExcessChargeSwitchOff: false,                       //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                            //----------------------------------------
                                            //****************************************
                                        
                                        G Offline
                                        G Offline
                                        guhfy9966
                                        schrieb am zuletzt editiert von
                                        #800

                                        @waly_de
                                        Habe es aktuell mit einem eigenen Umrechnungsscript gelöst. Deine neuen Integrationen kommen daher wie gerufen.
                                        Super, freue mich darauf!

                                        😊👍

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

                                          So. Zwar gestaltet sich das Testen bei dem bisschen Sonne sehr schwierig. Aber ich wage dennoch mal die Veröffentlichung der neuen Version.

                                          (1.2) 04.12.2023

                                          • Neue Funktion Überschussladung implementiert:
                                            Bei überschüssiger Leistung kann nun ein zusätzlicher Speicher aktiviert werden.
                                            Da die neue Firmware für die DELTAs inzwischen duales Laden (Solar und AC gleichzeitig) unterstützt, kann damit die
                                            Ladeleistung der Deltas bis 2000W oder mehr erhöht werden. Auch eine Integration von weiteren Wechselrichtern ohne eigene
                                            Batterie wird möglich.
                                            Konfiguration: siehe Einstellungen weiter unten zu "ExcessCharge" (Überschussladung)
                                          • Neuer Parameter unter AdditionalPower: "factor" für den Divisionsfaktor. Bei den Deltas dort 10 angeben.
                                          • Filter gegen Datenflut der Deltas eingebaut, der das System entlastet, wenn auch die Deltas auf "subscribe: true" gestellt werden
                                          • Verschiedene Optimierungen und Bugfixes

                                          die Einstellungen:

                                              //****************************************
                                              // Überschussladung:
                                              //****************************************
                                              ExcessCharge: false,                                //Überschussladung AN/AUS (true/false)
                                                                                                  //ID zum Einstellen der Ladeleistung des Speichers in Watt: 
                                              ExcessChargePowerID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.slowChgPower",
                                                                                                  //ID des aktuellen Ladestandes des Speichers in %: 
                                              ExcessChargePowerBatSocID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.bmsMaster.soc",
                                              ExcessChargeSwitchMin: 5,                           //Zeit in Minuten die der Schalter mindestens in der letzten geschalteten Position verbleiben muss. 
                                              ExcessChargeMaxPower: 2000,                         //Maximale Ladeleistung des Speichers in Watt
                                              ExcessChargeOffsetPower: 0,                         //Wird der Leistungsanforderung hinzugerechnet um Messabweichungen auszugleichen. 
                                              ExcessChargeStartPower: 50,                         //Mindest-Überschussleistung zum Einschalten des Speichers
                                              ExcessChargeStartPowerDurationMin: 2,               //Mindestdauer in Minuten, die ExcessChargeStartPower nicht unterschritten werden darf, bevor der Speicher eingeschaltet wird.
                                              //----------------------------------------
                                              // Beispiel für Delta-Nutzung ohne Schlaltersteckdose:
                                              // Wird an einer Delta auch der PV-Eingang genutzt, bitte die PV-Leistung unter AdditionalPower anlegen. Die passende ID ist:
                                              // 0_userdata.0.ecoflow.app_device_property_xxx.data.params.mppt.inWatts
                                              // Bei der Delta: "subscribe: true" konfigurieren
                                              //----------------------------------------
                                                                                                  //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                              //ExcessActualPowerID: "0_userdata.0.ecoflow.app_device_property_xx.data.params.inv.inputWatts",
                                                                                                  //ID des Schalters, der den Speicher aktiviert: 
                                              //ExcessChargeSwitchID: "0_userdata.0.ecoflow.app_xx_xx_thing_property_set.writeables.chgPause", 
                                              //ExcessChargeSwitchOn: 0,                          //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                              //ExcessChargeSwitchOff: 1,                         //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                              //----------------------------------------
                                              // Beispiel für Nutzung einer Schlaltersteckdose:
                                              //----------------------------------------
                                                                                                  //ID mit dem Messwert der aktuellen Leistungsaufnahme des Speichers in Watt:
                                              ExcessActualPowerID: "sonoff.0.NOUS-DVES_F0A844.ENERGY_Power",
                                                                                                  //ID des Schalters, der den Speicher aktiviert: 
                                              ExcessChargeSwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", 
                                              ExcessChargeSwitchOn: true,                         //Wert, der zum Aktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                              ExcessChargeSwitchOff: false,                       //Wert, der zum Deaktivieren des Schalters gesetzt werden muss (1/0, true/false, "ON"/"OFF"...)
                                              //----------------------------------------
                                              //****************************************
                                          

                                          Download:

                                          ecoflow-connector_v12_.04.12.2023.txt

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          622

                                          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