NEWS
Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro)
-
Fehler
error Function "setObject" is not allowed. Use adapter settings to allow it.Kam aber nur beim ersten Start
@daniel-8 sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
Fehler
error Function "setObject" is not allowed. Use adapter settings to allow it.Kam aber nur beim ersten Start
iobroker JS-Sandbox gibt es Restriktionen für Funktionen
setObject(...)
createState(...) (wenn nicht erlaubt)Damit neue Datenpunkte automatisch aus dem JSON erstellt werden, im JS-Adapter „Enable command setObject“ aktivieren.
Ja, theoretisch gilt das für alle Scripts – aber keine Panik 😄, für dieses Script ist es völlig harmlos. Ohne diese Option kann es keine neuen Datenpunkte anlegen, wenn neue Keys im JSON gesendet werden.
Dafür bleibt alles automatisch aktuell und das Script lässt sich quasi wie ein Adapter verwenden – ohne Konflikte oder Kollisionen. -
@daniel-8 sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
Fehler
error Function "setObject" is not allowed. Use adapter settings to allow it.Kam aber nur beim ersten Start
iobroker JS-Sandbox gibt es Restriktionen für Funktionen
setObject(...)
createState(...) (wenn nicht erlaubt)Damit neue Datenpunkte automatisch aus dem JSON erstellt werden, im JS-Adapter „Enable command setObject“ aktivieren.
Ja, theoretisch gilt das für alle Scripts – aber keine Panik 😄, für dieses Script ist es völlig harmlos. Ohne diese Option kann es keine neuen Datenpunkte anlegen, wenn neue Keys im JSON gesendet werden.
Dafür bleibt alles automatisch aktuell und das Script lässt sich quasi wie ein Adapter verwenden – ohne Konflikte oder Kollisionen.stellst du das script auch oben in den eingangspost oder ist dir das noch zu heikel?
-
stellst du das script auch oben in den eingangspost oder ist dir das noch zu heikel?
@daniel-8
Ist noch nicht eingestellt. Ist nicht zu heikel.
Wurde nur überarbeitet, erweitert und verbessert.
Jetzt sollten auch Commands gesetzt werden können, wie in einem Adapter. :-)Muss man nicht nutzen, kann man aber zusätzlich, falls z. B. MQTT mal Probleme macht oder wenn mehr set-Befehle noch rein sollen.
Hinweis:
Damit neue Datenpunkte automatisch aus dem JSON erstellt werden:
→ Instanzen → JavaScript-Adapter → Allgemeine Einstellungen → „Enable command 'setObject'“ aktivieren!Soviel wie möglich ohne Gerät getestet und simuliert. Extra ohne Schleifen und strukturiert geschrieben, damit jeder das Script verstehen sollte.
Struktur & Aufbau
- Konfiguration: IP, Seriennummer, Intervalle, MQTT
- Definition der Datenpunkte
- HTTP-Queue (curlQueue) zur seriellen Abarbeitung von GET/POST-Requests
Funktionen für:
- getReport()
- setSmartMode()
- getMqttStatus()
- setMqttConnect()
- setControlDP() generisch für ACMode, Input/OutputLimits etc.
- Trigger für Datenpunkte (on) und Intervalle (setInterval)
- processJson() zur JSON-Verarbeitung
Hilfsfunktionen:
-
getBatteryType()
-
iter() (rekursive Verarbeitung der JSON-Daten, inkl. packData)
Erweiterte Switch-Logik in iter() für viele spezielle Keys wie hyperTmp, inputLimit, socSet, solarPower1..6, ts etc. -
Korrekte Umrechnung für SoC (/10), Spannung (/100), Temperatur (-2731/10) usw.
Funktionalität
Das Script:
- Ruft regelmäßig die SmartMode- und MQTT-Statusdaten vom Gerät ab
- Schreibt Werte in die definierten Datenpunkte
- Kann Datenpunkte über UI oder andere Scripte setzen und schreibt die Resultate zurück
- Verarbeitet beliebiges JSON vom Gerät (processJson) und legt automatisch neue Datenpunkte an
- Unterstützt mehrere Batteriepacks und detaillierte Parameter wie Spannungen, Ströme, PV-Eingänge, Grid-Status usw.
Auffälligkeiten / potenzielle Probleme: keine
- Typen bei createState: In einigen Fällen (batcur, maxTemp, socSet etc.) werden Zahlen korrekt als number gesetzt
- Strings wie model sind korrekt als string definiert → alles konsistent
- Zeitstempel (ts, timestamp): formatTime(ts) wird korrekt aufgerufen
- Datenpunkte werden sowohl als number (Unix-ts) als auch string (lesbares Datum) angelegt
- Potenzielle Kollisionen zwischen timestamp und ts wurden sauber abgefangen
- Reihenfolge / asynchrone Operationen: curlQueue sorgt dafür, dass HTTP-Requests nacheinander ausgeführt werden, keine Konflikte
- async/await in processJson und iter korrekt
- Keine offensichtlichen Race-Conditions
Fehlerbehandlung:
- Alle HTTP-Requests haben on("error")
- JSON-Parsing mit try/catch
- Iteration in iter() hat eigenen try/catch
- Spezielle Werte / Umrechnung:
SoC (socSet und minSoc) richtig /10
Spannung /100, Temperatur (-2731)/10 - AC-Limits innerhalb maxInput/OutputLimit
Sonstiges:
- existsObject und existsState korrekt verwendet
- Neue Datenpunkte werden automatisch mit createState angelegt
- Alle on()-Trigger korrekt, keine doppelten
Frühere Versionen der Scripte sind hier (im Spoiler) zu finden.
Die kompletten Scripte sind zu groß für einen Post, daher habe ich sie hierher ausgelagert.
historisch
-
stellst du das script auch oben in den eingangspost oder ist dir das noch zu heikel?
Das aktuelle Script ist jetzt im ersten Eingangs-Post dieses Threads zu finden.
Rückmeldungen
Bitte gebt kurz Bescheid, falls Fehler auftreten oder noch etwas fehlt.
Wenn keine Fehler auftreten, sehe ich das Script als vorläufig abgeschlossen und stabil an.
Frühere Versionen (historisch) sind nun hier im Spoiler abgelegt.
Die kompletten Scripte sind zu groß für einen Post, daher habe ich sie dort ausgelagert. -
@maxclaudi
Skript läuft. Steuerung funktioniert und Änderungen werden angezeigt. Die Umstellung bei MQTT auf 1 / 0 hast Du schon erledigt? Zumindest lässt es sich bei mir schon damit steuern. Die Umstellung bei MQTT dauert zwar sehr lange (gefühlt mehr als 1 Minute), aber es macht dennoch das was es soll!Werde gleich mal meine Skripte etwas tunen ;-)
-
Anfrage an SF2400AC-Besitzer
Für meine Auswertung, weitere Verarbeitung und Tests benötige ich ein paar Infos.
Könnte bitte jemand mit einem SF2400AC das Blockly aus diesem Post HIER ausführen und das Ergebnis-JSON hier als Code (</>) einstellen?
Beim Antworten bitte oben „</> Code“ auswählen und das JSON dort einfügen.
Die Seriennummer dabei durch z. B. WOB1NHMAMXXXXX3 ersetzen.
Bisher hatte ich nur JSON-Daten vom SF800 Pro zur Auswertung. -
Anfrage an 800 Pro & 2400AC-Besitzer
Ich benötige noch ein paar Infos zu den App-Einstellungsmöglichkeiten.
Falls jemand Zeit und Lust hat zu helfen: bitte kurz melden.
Danke.
-
-
Hier ein paar warnmeldungen beim Start des Scripts
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:391:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:393:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:446:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:447:25)und dann kommt noch im Minutentakt folgende Meldung
Error in iter: ReferenceError: Cannot access 'ts' before initialization -
Hier ein paar warnmeldungen beim Start des Scripts
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:391:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:393:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:446:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:447:25)und dann kommt noch im Minutentakt folgende Meldung
Error in iter: ReferenceError: Cannot access 'ts' before initialization@daniel-8 sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
Hier ein paar warnmeldungen beim Start des Scripts
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:391:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:393:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:446:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:447:25)und dann kommt noch im Minutentakt folgende Meldung
Error in iter: ReferenceError: Cannot access 'ts' before initializationVerstehe nicht wie mir das gestern passieren konnte,
Bitte noch einmal testen. Code ist oben aktualisiert.
auch ein Kommentar wurde berichtigt, outputlimit.
Das hat(te) keine Auswirkung.
Danke Daniel, dass Du auch immer gleich log postest :+1: -
@daniel-8 sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
Hier ein paar warnmeldungen beim Start des Scripts
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:391:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:393:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:446:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:447:25)und dann kommt noch im Minutentakt folgende Meldung
Error in iter: ReferenceError: Cannot access 'ts' before initializationVerstehe nicht wie mir das gestern passieren konnte,
Bitte noch einmal testen. Code ist oben aktualisiert.
auch ein Kommentar wurde berichtigt, outputlimit.
Das hat(te) keine Auswirkung.
Danke Daniel, dass Du auch immer gleich log postest :+1:Guten Morgen,
nun komen folgende Meldungen:
Beim Start wieder die Warn. Ist die normal? Wobei es 2 weniger geworden sind.at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:395:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:397:29)und dann wieder im Minutentakt die Error Meldung:
Error in iter: ReferenceError: Cannot access 'ts' before initializationHelfe gerne mit wo ich kann und was in meiner Fähigkeit liegt
-
Guten Morgen,
nun komen folgende Meldungen:
Beim Start wieder die Warn. Ist die normal? Wobei es 2 weniger geworden sind.at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:395:45) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:397:29)und dann wieder im Minutentakt die Error Meldung:
Error in iter: ReferenceError: Cannot access 'ts' before initializationHelfe gerne mit wo ich kann und was in meiner Fähigkeit liegt
-
Heute Abend muss los. Haben denn die ersten 2 Meldungen eine Bedeutung?
-
Heute Abend muss los. Haben denn die ersten 2 Meldungen eine Bedeutung?
@daniel-8
Beim Start des Scripts werden direkt zwei GET-Requests ausgelöst. Wenn das Zendure-Gerät gerade beschäftigt ist, kann es passieren, dass die Antwort leer oder das JSON ungültig ist.
Mit dem neuesten Script habe ich den Timeout von 3000 ms auf 5000 ms erhöht – damit sollte es jetzt zuverlässig sein.
Maximal einmal beim Scriptstart könnte es noch vorkommen, dass ein Request fehlschlägt, falls das Gerät gerade sehr beschäftigt ist. Danach läuft alles stabil. -
@daniel-8
Beim Start des Scripts werden direkt zwei GET-Requests ausgelöst. Wenn das Zendure-Gerät gerade beschäftigt ist, kann es passieren, dass die Antwort leer oder das JSON ungültig ist.
Mit dem neuesten Script habe ich den Timeout von 3000 ms auf 5000 ms erhöht – damit sollte es jetzt zuverlässig sein.
Maximal einmal beim Scriptstart könnte es noch vorkommen, dass ein Request fehlschlägt, falls das Gerät gerade sehr beschäftigt ist. Danach läuft alles stabil.Also es gab nur noch am Anfang eine Warnmeldung was ja nichts zu bedeuten hat.
Sonst gab es keinen Fehler mehr im Minutentakt -
Also es gab nur noch am Anfang eine Warnmeldung was ja nichts zu bedeuten hat.
Sonst gab es keinen Fehler mehr im Minutentakt -
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:394:29) -
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:394:29) -
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:394:29) -
edit Warnung(en) weg. Müsste alles funktionieren. Script ist im ersten Eingangs-Post.
@maxclaudi sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
edit Warnung(en) weg. Müsste alles funktionieren. Script ist im ersten Eingangs-Post.
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:394:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:444:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:445:25)die Eine kam 2 mal
-
@maxclaudi sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
edit Warnung(en) weg. Müsste alles funktionieren. Script ist im ersten Eingangs-Post.
at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:394:29) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:444:25) at IncomingMessage.<anonymous> (script.js.common.Testphase.@maxclaudi_mit_set:445:25)die Eine kam 2 mal
-
@maxclaudi sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
@daniel-8
Eingangspost code.:+1: keine Fehlerausgabe
-
@maxclaudi sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
@daniel-8
Eingangspost code.:+1: keine Fehlerausgabe
@daniel-8 sagte in Zendure SmartMode:1 SolarFlow2400 AC SolarFlow800 ( u. Pro):
:+1: keine Fehlerausgabe
Der Code war nie kaputt – nur die Datenpunkte waren beim ersten Start zu langsam. 😅
Jetzt wird erst angelegt und dann abgefragt. Keine Fehlermeldungen mehr, keine Panik – läuft:+1: