NEWS
SONOFF NSPanel mit Lovelace UI
-
Doch noch Errors im Protokoll entdeckt ABER diese kommen nur 1x beim Starten des Skriptes:
javascript.02024-09-21 19:06:17.560 error at Script.runInContext (node:vm:135:12) javascript.0 2024-09-21 19:06:17.559 error at script.js.NSPanel_v4_4_0_5:1176:19 javascript.0 2024-09-21 19:06:17.559 error at require (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:552:28) javascript.0 2024-09-21 19:06:17.559 error at require (node:internal/modules/cjs/helpers:121:18) javascript.0 2024-09-21 19:06:17.558 error at Module.require (node:internal/modules/cjs/loader:1143:19) javascript.0 2024-09-21 19:06:17.558 error script.js.NSPanel_v4_4_0_5: Error: Cannot find module '@iobroker-javascript.0/moment-parseformat'
-
-
-
@gre4t0ne Das Script hat eine eigene script-Debug-Funktion. Einschalten über das Panel im Servicemenü unter Einstellungen/Script oder den Datenpunkt
0_userdata.0.NSPanel.1.Config.ScripgtDebugStatus
auf true setzen. Damit bekommen wir die Daten, die wir fürs erste brauchen. -
Ich habe schon mehrere Videos gesehen, in dem auf einem Shelly Wall Display, Home Assitant läuft.
Wäre denn nicht sowas ähnliches auf dem Ns Panel mit Iobroker möglich? -
Kann mir da nun nichts drunter vorstellen... Du meinst per Web-Seite? Oder HA auf dem NSPanel?
-
-
Ah okay - HA-Dashboard - verstanden
geht nicht mit dem Sonoff NSPanel - aber mit dem Sonoff NSPanel Pro. (andere Baustelle)
Sowohl das NSPanel Pro als auch das Shelly Wall Display arbeiten nicht unter ESP32/Tasmota mit Nextion, sondern sind ganz normale Android-Geräte.
Beim Shelly Wall Display, funktioniert das ohne Jailbreak offensichtlich nur mit HA. Auf dem NSPanel Pro kannst du mit den bekannten Hacks z.B. eine ioBroker VIS als Webseite laden...
Preislich liegen Shelly Wall Display und NSPanel Pro nah zusammen - aber immer noch ca. 60€ über dem NSPanel (habe die meisten bei ca. 40€ geschossen). Daher bleibt das NSPanel wohl die günstigste komplett Visu für das komplette Smart Home
-
@armilar
Ah ok.
Danke für die ausgiebige Erklärung. Aber es ist auch eine einfacher Programmierung des Ns Panels geplant, bzw. in Arbeit, oder? -
@lustig29
Ja es ist ein Adapter in Planung. Der über die Admin Oberfläche konfiguriert wird. Die HMI ist noch in der Planungsphase. -
Zuerst einmal: vielen Dank für eure Arbeit - super!!
Trotzdem brauche ich mal Unterstützung ...
Auf dem NSPanel ist Tasmota 13.4 und die Display Firmware nspanel-v4.4.0.tft installiert (mit Tasmota 14.2 konnte v4.4.0 nicht aufgespielt werden). Als MQTT-Server wird ein externer Mosquitto Server benutzt. Unter HomeAssistant konnte das NSPanel erfolgreich in Betrieb genommen werden - läuft. Da ich einen Vergleich mit dem ioBroker wollte, habe ich auch hier die Installation mit dem DEV-Script v4.4.0.6 (wg. MQTT-Client) durchgeführt.
Hier passiert der erste Fehler: der automatische Updater im Script knallt bei der Erstinstallation des NSPanels im ioBroker den Display Firmware 3.3.1 auf das NSPanel, obwohl schon die benötigte 4.4.0 auf dem Gerät war. Ergebnis: um 90 Grad gedrehte Fehlermeldung im Display. Mit dem Befehl
FlashNextion http://nspanel.pky.eu/lovelace-ui/github/nspanel-v4.4.0.tft
in der Tasmota Konsole kann das wieder bereinigt werden ...
Als Reminder würde ich einen Feature Request vorschlagen:
- Auto-Config Flags für das Unterdücken eines Auto-Updates in den Funktionen
- update_tasmota_firmware();
- update_berry_driver_version();
- update_tft_firmware();
jeweils im vor dem try-Bereich
Dann wird das Script erneut gestartet, aber es wird nichts über den MQTT-Server Richtung NSPanel geschickt. 0_userdate und alias sind vom Script richtig erzeugt worden, auch der CustomSend Eintrag ist vorhanden. Die MQTT publish Geräte-Einstellung ist für CustomSend, GetDriverVersion und POWER gesetzt. Stattdessen wird alle 6 Sekunden die Init-Schleife durchlaufen (CustomSend = Null)
26.9.2024, 19:00:30.124 [info ]: javascript.0 (600) Compiling TypeScript source script.js.common.NSPanel.NSPanelTs_073 26.9.2024, 19:00:30.500 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: source code did not change, using cached compilation result... 26.9.2024, 19:00:30.678 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: setObjects enabled - create Alias Channels possible 26.9.2024, 19:00:30.679 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: weather alias for accuweather.0. already exists 26.9.2024, 19:00:30.710 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: registered 40 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 26.9.2024, 19:00:30.974 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Desired TFT Firmware: 53 / v4.4.0 26.9.2024, 19:00:30.974 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Installed TFT Firmware: 53 / v4.4.0 26.9.2024, 19:00:31.081 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Debug mode disabled 26.9.2024, 19:00:32.060 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: hidden Cards disabled 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Start MQTT-Port-Check ------------------------------------- 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- admin.0 - 8081 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- hm-rpc.0 - 0 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- hm-rpc.1 - 0 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- hm-rpc.2 - 0 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- hm-rpc.3 - 0 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- mqtt-client.0 - 1883 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- simple-api.0 - 8087 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: -- web.0 - 8082 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: - MQTT-Port-Check OK: Instance of Adapter: mqtt-client.0 is running on Port:1883 26.9.2024, 19:00:33.611 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: End MQTT-Port-Check --------------------------------------- 26.9.2024, 19:00:34.808 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Desired TFT Firmware: 53 / v4.4.0 26.9.2024, 19:00:34.808 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Installed TFT Firmware: 53 / v4.4.0 26.9.2024, 19:00:40.797 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Desired TFT Firmware: 53 / v4.4.0 26.9.2024, 19:00:40.797 [info ]: javascript.0 (600) script.js.common.NSPanel.NSPanelTs_073: Installed TFT Firmware: 53 / v4.4.0
Bei der Jscript Version 8.8.3 sind die NPM Modulen axios, moment, moment-parseformat und dayjs angegeben.
Was habe ich übersehen - wo ist der Fehler?
- Auto-Config Flags für das Unterdücken eines Auto-Updates in den Funktionen
-
@armilar sagte in SONOFF NSPanel mit Lovelace UI:
Beim Shelly Wall Display, funktioniert das ohne Jailbreak offensichtlich nur mit HA. Auf dem NSPanel Pro kannst du mit den bekannten Hacks z.B. eine ioBroker VIS als Webseite laden...
Klaro, Shelly hat auf der IFA ja bekannt gegeben, dass sie mit HA nun auch kooperieren. Klingt für mich nur logisch, dass man dann die App nativ auf dem Gerät installieren/nutzen kann.
LG
-
Zum MQTT Thema zu einem externen Mosquitto-Server kann die bestimmt @TT-Tom etwas mehr erzählen. Ich denke der Weg über den mqtt.0 wäre für die bidirektionale Kommunikation geeigneter als der mqtt-client. Habe letztens auch eine Kombination aus beiden gesehen:
https://forum.iobroker.net/topic/76996/mqtt-broker-client-sendet-nur-beim-start?page=1
eventuell hilft es dir weiter...
Zum Thema Auto-Updates:
Es gibt bereits einen Datenpunkt der per Default mit false angelegt wird und für Auto-Updates zuständig ist.
Ich kann den Fehler weder reproduzieren, noch gibt es einen Hinweis auf eine TFT-Version 3.3.1 in den Skripten v4.4.X
Kann es sein, dass du das NSPanel auch vorher schon mit einer Version 3.3.1 im ioBroker am Laufen hattest und der Ordner des NSPanels noch vorhanden war? Ansonsten könnte ich mir das Verhalten nicht erklären.
-
@armilar
Danke für die schnelle Antwort!Bei dem Update-Problem waren die 0_userdate und alias Einträge vorher gelöscht worden - war für mich reproduzierbar. Ich bin davon ausgegangen, dass sich der Updater eine 'falsche' Default Datei holt ...
Werde morgen den Test-ioBroker (Proxmox) mal zurücksetzen und das ganze nochmal verifizieren.
Kannst Du mir sagen, bei welcher Zeile der zu sendende MQTT Code für das Versenden bereitsteht ... dann brauche ich nicht den gesamten Code durchsehen - ich will ein bischen debuggen. Danke! -
Für das NSPanel in:
Dein Problem dürfte aber ein paar Zeilen drunter sein, dass der startup nicht durchgeht...
Das wäre also das, was über den tele.RESULT vom NSPanel kommt.
Bestenfalls mal den mqtt.0 nutzen. Irgendetwas stimmt in deiner MQTT-Kommunikation nicht...
Wie du aber siehst, sollte das Script-Debug (ebenfalls per DP oder Menü aktivierbar) schon die Antworten liefern.
-
@armilar sagte in SONOFF NSPanel mit Lovelace UI:
Beim Shelly Wall Display, funktioniert das ohne Jailbreak offensichtlich nur mit HA.
Man kann die URL auch manuell angeben. Sieht ja erstmal aus wie ein normaler Browser. Könnte mir gut vorstellen, dass man damit jede beliebige Seite aufrufen kann. Muss ich mal testen, gestern wenig Zeit gehabt.
-
@armilar
Dein Tipp zum Einstiegspunkt war genau richtig ...@Alle
Wie in der ioBroker Basisinstallation beschrieben, hatte ich auf dem MQTT-Server mit dem MQTT-Explorer den CMND-Topic über PUBLISH (json) angelegt:myHOME/devices/nspanel_xyz/cmnd/CustomSend
Im ioBroker taucht der Eintrag dann auch im MQTT-Client auf ... und jetzt ganz wichtig: mit dem Wert (null) - und genau DAS war mein Fehler: ich hatte übersehen, dass mit dem Topic auch '12:00' als Wert mit zu übergeben ist, damit der Topic eben NICHT (null) ist!!!
Achtung: wenn man den MQTT-Client einsetzt, wird der Wert '12:00' NICHT im ioBroker gesetzt - dh. der MQTT-Pfad wird erzeugt, aber der Wert steht auf (null) und nicht auf '12:00'. Es muss zuerst für 'CustomSend' die Publish-Funktion aktiviert werden (Zahnrad rechte Seite) - erst jetzt kann man nochmal den Wert mit dem MQTT-Explorer publischen oder den Wert '12:00' direkt im ioBroker unter 'CustomSend' eingeben.
Anmerkung: ich habe im MQTT-Client für alle Topics des NSPanels das Publish-Flag gesetzt.
Erläuterung: ... für die Experten, warum dieser kleine Fehler dazu geführt hat, dass das NSPanel nicht angelaufen ist ...
Alle MQTT-Ausgaben im Script laufen über die Funktion 'setIfExists'. In dieser Funktion wird mit der JS-Funktion 'existsState' überprüft, ob die Objekt-Instanz vorhanden ist. Im vorliegenden Fall zeigt die Instanz bei mir auf:
mqtt-client.0.myHOME.devices.nspanel_xyz.cmnd.CustomSend
Beim Starten des Skripts war der MQTT-Pfad im Objektbaum zwar vorhanden, jedoch sorgte '(null)' dafür, dass die JS-Funktion 'existsState' in der Script-Funktion 'setIfExists' immer 'false' zurück gibt ... Ergebnis: es fand keine MQTT-Ausgabe zum NSPanel statt. Sobald im MQTT-Client Topic etwas eingetragen wurde, läuft die Verbindung zum NSPanel sofort an.@armilar
Beim Debuggen sind mir noch zwei Dinge aufgefallen, die Du bitte noch korrigieren kannst:1.) Fehler Zeile 1074 - a enthält 'mqtt' oder 'mqtt-client'
Original: if (a === 'mqtt' && !isNaN(Number(i))) { Neu: if (a.substring(0, 4) === 'mqtt' && !isNaN(Number(i))) {
2.) Fehlende Debug-Ausgabe in Funktion 'SendToPanel' hinzugefügt - ab Zeile 3520
async function SendToPanel(val: NSPanel.Payload | NSPanel.Payload[]) { try { if (Array.isArray(val)) { val.forEach(function (id) { setIfExists(config.panelSendTopic, id.payload); if (Debug) { log('function SendToPanel id-payload: ' + id.payload, 'info'); } }); } else { setIfExists(config.panelSendTopic, val.payload); if (Debug) { log('function SendToPanel val-payload: ' + val.payload, 'info'); } } } catch (err: any) { log('error at function SendToPanel: ' + err.message, 'warn'); } }
Danke für die Unterstützung - ich hoffe der Beitrag hilft den Leuten, die nur einen MQTT-Client einsetzen
-
Vielen Dank für den Beitrag...
Wir werden die Anleitung für den MQTT-Client Adapter mit ins Wiki übernehmen... Auch die beiden Änderungen machen im Kontext mit dem MQTT-Client Adapter sinn...
-
https://github.com/joBr99/nspanel-lovelace-ui/blob/main/ioBroker/NsPanelTs.ts
Änderungen betreffen ausschließlich den unteren Teil ab:
PR hatte @TT-Tom schon vorbereitet
-
... und da ist ja noch die Sache mit der manuellen Erstinstallation eines NSPanels im ioBroker ...
Gut, dass es Proxmox gibt ... nach vielen Debug-Sitzungen mit einer minimal Default-Konfiguration denke ich, dass ich jetzt verstanden habe, warum und wann der beschriebene Fehler auftritt: beim erstmaligen Start des Scripts installiert der automatische Updater (bei mir reproduzierbar) die online TFT-Firmware, obwohl die aktuelle Firmware auf dem NSPanel vorhanden ist. Das Ganze endet immer mit einer um 90 Grad gedrehten Fehlermeldung im Display des NSPanels.
Zuerst habe ich im ioBroker / Script gesucht, warum dort die Firmware 3.3.1 eingetragen ist - gefunden habe ich folgendes unter:
0_userdata.0.nspanel_073.1.Display_Firmware.TFT.currentVersion = 0 / v3.3.1
Erzeugt wird dieser Eintrag an dieser Stelle (ab Scriptzeile1266):
async function Init_Release() { const FWVersion = [41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56]; const FWRelease = ['3.3.1', '3.4.0', '3.5.0', '3.5.X', '3.6.0', '3.7.3', '3.8.0', '3.8.3', '3.9.4', '4.0.5', '4.1.4', '4.2.1', '4.4.0', '4.4.0', '4.5.0', '4.6.0']; try { if (existsObject(NSPanel_Path + 'Display_Firmware.desiredVersion') == false) { await createStateAsync(NSPanel_Path + 'Display_Firmware.desiredVersion', desired_display_firmware_version, { type: 'number', write: false }); } else { await setStateAsync(NSPanel_Path + 'Display_Firmware.desiredVersion', desired_display_firmware_version, true); } if (existsObject(NSPanel_Path + 'Config.Update.activ') == false) { await createStateAsync(NSPanel_Path + 'Config.Update.activ', 1, { type: 'number', write: false }); } else { await setStateAsync(NSPanel_Path + 'Config.Update.activ', 0, true); } let currentFW = 0; let findFWIndex = 0; log('Desired TFT Firmware: ' + desired_display_firmware_version + ' / ' + tft_version, 'info'); if (existsObject(NSPanel_Path + 'Display_Firmware.currentVersion')) { currentFW = parseInt(getState(NSPanel_Path + 'Display_Firmware.currentVersion').val); findFWIndex = FWVersion.indexOf(currentFW); log('Installed TFT Firmware: ' + currentFW + ' / v' + FWRelease[findFWIndex], 'info'); }
Beim ersten Durchlauf gibt es zwar das Objekt 'Display_Firmware.currentVersion', aber der Inhalt ist leer ... das führt dann zu dem Index '0', der dann aus 'FWRelease' den ersten Eintrag '3.3.1' nimmt ... und schon steht '0 / v3.3.1' als aktuelle TFT-Firmware Version da (btw: besser wäre bei 'unbekannt' der Eintrag '0 / v0' gewesen).
Aber warum kommt es überhaupt soweit, dass der Objekt-Eintrag leer ist? Der Knackpunkt liegt in den Scriptzeilen ab Zeile 2687:
// Updates currently compare every 12 hours let scheduleCheckUpdates = adapterSchedule(undefined, 60 * 60 * 12, () => { get_tasmota_status0(); get_panel_update_data(); check_updates(); }); // Check for updates with Start get_locales(); get_locales_servicemenu(); setIfExists(config.panelSendTopic, 'pageType~pageStartup'); get_tasmota_status0(); get_panel_update_data(); check_updates();
Nach Aufruf der Initialisierungsfunktionen sollen beim Start die Updates gecheckt werden (8 ... 14) - dabei werden dann auch fehlende Objekt-Einträge automatisch angelegt. Gleichzeitig ist jedoch auch der Scheduler 'scheduleCheckUpdates' gestartet worden (2 ... 6) ... und hier lauert jetzt der Fehler: der startet (direkt) parallel zum laufenden Update-Prozess einen zweiten Update-Prozess, in dem die gleichen Funktionen 'get_tasmota_status0', 'get_panel_update_data' und 'check_updates' aufgerufen werden. So kommt es dann zu einer 'undefinierten Initialisierung' - zufällig wird bei mir eben die TFT-Firmware aktualisiert ... bei anderen Konstellationen kann was anderes dabei rauskommen.
Ich habe mehrere Szenarien für die Inbetriebnahme durchgespielt - das würde aber diesen Rahmen hier sprengen - Github ist da vielleicht besser zur Diskussion geeignet. Leider habe ich keinen 'einfachen Weg' gefunden - es wären m.E. immer einige Code-Anpassungen notwendig ... und da möchte ich Dir nicht vorgreifen.
Vielleicht hast Du ja auch noch die ioBroker Integration im Blick ...