NEWS
[Vorlage] Tasmota One Click Firmware Update Vis Javascript.
-
@fischi87
hallo...
lief denn das script schonmal bei dir und du hast nun 2 Geräte entfernt?
Dann musst du sicher stellen, dass du diese im Konfigbereich herausnimmst und das diese Geräte nicht mehr im Sonoff Adapter im Objektbaum aufgelistet sind.Dann das script wieder neu starten.
Updates bekommst du nur angezeigt, wenn sich die Version welche online verfügbar ist neuer ist als die installierte...
Wenn es noch nicht lief, akribisch an die Kommentare im Konfigbereich achten...
-
ja das skript lief bereits einmal und es ist richtig ich habe 2 entfernt aber sowohl aus dem skript als auch aus den objekten des sonoff adapters.
-
@fischi87 sieht fast so aus als waeren ip Adressen falsch eingetragen...haben deine geräte ne feste ip?
-
ja haben sie. hab gerade nochmal alles nachgeschaut, die ips passen.
mir ist gerade aufgefallen dass das Skript mir ein gerät anzeigt was ich noch gar nicht in der Skript eingepflegt haben?1
-
@fischi87 ja....das kann sein, das liegt an der cacheselector Funktion. Hiermit habe ich begonnen das Skript ein Stück weit unabhängig von User Eingaben zu machen. Das Script zählt hier selbstständig die anzahl der geräte welche im Objektbaum hinterlegt sind. Mir fehlt halt im Moment die Zeit das durchgängig in allen Bereichen umzusetzen. Ziel ist, dass gar keine User Eingaben im Konfigberecih mehr nötig sind um bei Hardwareänderungen neuen oder gelöschten Geräten keine manuellen Eingriffe im Script machen zu müssen.
Aber im Momemt habe ich andere Projekte..Für dich heist das, oder generell. Alle vorhandenen Tasmota Geräte müssen im Script manuell gepflegt sein.
-
Soooo
Heute gab es ein neues tasmota und was soll ich sagen... Der Supergau... Er zeigt Updates an per Mail. Ich klicke auf den Button Update all... Er bleibt in einer Schleife hängen, weil ich dussel die falschen ips angegeben hatte, denn ich musste die Fritz Box neu machen. Also IP Adressen korrigiert und neu versuchen... Im Log sagt er die Versionen der Geräte sind alt, eine Nachricht verschickt er aber nicht. Der Datenpunkt Update verfügbar wird nicht true und wenn ich trotzdem ein Update Versuche heißt es immer in der Console "Upgrade failed server did not report size"
Ich bin etwas ratlos...In den Codezeilen ab 362 stehen nur zwanzig Geräte, wenn ich mehr als die habe muss ich dann die Anzahl anpassen? ich weis steht zwar unterhalb von ab hier nichts meh ändern, aber würde sonst für mich keinen Sinn ergeben....
Es wird auch ein Fehler angezeigt. Er sagt in der entsprechende Zeile Cannot find module node-ssh. Es ist aber in die Module mit aufgenommen...
-
@Dragon sagte in [Vorlage] Tasmota One Click Firmware Update Vis Javascript.:
In den Codezeilen ab 362 stehen nur zwanzig Geräte, wenn ich mehr als die habe muss ich dann die Anzahl anpassen? ich weis steht zwar unterhalb von ab hier nichts meh ändern, aber würde sonst für mich keinen Sinn ergeben....
Die IP Adressen sollten schon stimmen.
Ja..Die Zeilen danach kannst du generell an deine Anzahl Geräte angepassen.Wenn es mehr sind ist es sogar zwingend nötig.
Bei Weniger nicht..Aber die Abarbeiteung wird hiermit beendet...
if(count === AnzahlDevice){ clearSchedule(trigger);
Das Skript kann man bestimmt auch so schreiben , dass es alles automatisch macht. Dazu bin ich nicht mehr gekommen. Weil es bei mir aber nun so tut, stecke ich da keine Zeit mehr rein.
Überlege ob ich es noch um das sichern der Konfig erweitere . also Backup ablegen.
Wegen Cannot find module node-ssh....
Den Hinweis habe ich auch im Script...sollte nix machen... -
@smartboart Hab mal das Skript ein wenig überarbeitet, aber nicht getestet:
-
@cruzix Hi,
danke für das Update, den post hatte ich schon fast aus den Augen verloren. Hatte bei mir auch noch Kleinigkeiten geändert aber nicht mehr großartig daran weiter gearbeit. Meine Änderungen wollte ich bei Gelegenheit hier noch einstellen, bin aber gerade anderweitig bei nem größßeren Projekt im Garten stark eingebunden.
Seit den letzetn Updates haben sich ja auch die Info states im sonoff namentlich geändert. Das hast natürlich clever gelöst. Ich hatte noch ein state bei der Update Vorwahl eingespart und mit Vorwahl 0 alle selektiert. Damit ist es dann auch ein klick weniger und das one click im Namen passt dann auch.
Bei nächster Gelegenheit schaue ich mir das mal genauer an. Wenn du es getestet hast oder andere sag bescheid ansosnten lass ich es nochmal durchlaufen und aktualisiere dann den 1. post... -
Hallo zusammen,
habe das Script bei mir auch teilweise zum laufen gebracht. Da bei mir derzeit alle Geräte bereits auf den aktuellen Stand sind, habe ich halt ein "test" Gerät mit der 9.1.0 installiert.
Die Firmware wird auch in den entsprechenden Ordner heruntergeladen und ist über den Browser erreichbar.Leider erkennt das Script nicht das Gerät und meldet, dass hier noch eine ältere Firmware auf dem Gerät ist.
Hat jemand eine Idee?Ich habe hier auch mal den direkten Pfad eingestellt - ohne Erfolg
//var cacheSelectorTasmotaVersions = $('channel[state.id=sonoff.0.*.Version]'); var cacheSelectorTasmotaVersions = $('channel[state.id=sonoff.0.test.INFO.Version]');
Es soll sich hier um ein "normales" Gerät mit Standart Firmware handeln
// Device 18 + sind Standart Firmware Geräten vorbehalten. var Device18 = '192.168.178.23';//SteckdosenleisteWZ
@smartboart tolle Arbeit!
Edit: jetzt läuft es. Ich habe mal alle NPM-Module aus dem JS Adapter rausgelöscht und wieder
eingetragen. Keine Ahnung, warum - aber es geht. Ein Einfacher Neustart vom JS Adapter
hatte leider nichts gebracht. -
@smartboart Tatsächlich hab ich das gesamte Skript bisher noch nie laufen, weil ich normaler Weise die Updates mit Tasmoadmin mache.
Bin noch nicht dazu gekommen mal zu überlegen inwieweit das Skript für mich einen Mehrwert hat, da ich den tasmoadmin server eh schon laufen habe
Hab nur gerade mal aus Interesse und etw Zeit dein Skript gefunden und ein wenig "optimiert" -
@falke69 Freut mich. Du musst nun darauf achten, wenn du die aktuellste Version geladen hast, dass sich mit der aktuellen Version die Statebezeichner geändert haben.
ich habe des bereits geändert aber noch nicht oben aktualisiert.
-
@cruzix sagte in [Vorlage] Tasmota One Click Firmware Update Vis Javascript.:
@smartboart Tatsächlich hab ich das gesamte Skript bisher noch nie laufen, weil ich normaler Weise die Updates mit Tasmoadmin mache.
Bin noch nicht dazu gekommen mal zu überlegen inwieweit das Skript für mich einen Mehrwert hat, da ich den tasmoadmin server eh schon laufen habe
Hab nur gerade mal aus Interesse und etw Zeit dein Skript gefunden und ein wenig "optimiert"Ja wenn der Server bei dir eh läuft brauchst es ja net unbedingt. Aber finde es gerade deshalb toll das du trotzdem optimiert hast. Hoffe ich finde bald Zeit das zu testen..
-
So ich habe oben jetzt mal aktualisiert um die Version wie es gerade bei mir läuft.
24.02.2021
V0.0.5 State UpdateAll kann entfallen Auswahl Update all erfolgt nun über den State Auswahl
Bei Update All Nach Ende Update sicher beenden if (count >= AnzahlDevice)01.03.2021
V0.0.6 Tasmota Statebezeichner haben sich geändert, dies habe ich nun berücksichtigt.
Anzahl Device wieder manuell in der Konfig angeben. Autozählung Hat unter bestimmten umständen zu Fehlern geführt.Die Optimierung von cruzix muss ich erst noch testen. Danke @CruziX .
Sobald ich bestätigen kann dass die läuft werde ich sie ebenfalls um meine letzten Änderungen anpassen und oben bereit stellen. Wenn es vorher jemand testet, gebt bescheid. -
@cruzix So jetzt hab ich mich doch gleich mit deiner Optimierung beschaäftigt.
Ich habe meine Aktualisierungen noch gleich mit eingearbeitet. Hier und da hast ein async vergessen, weshalb es beim await noch zu Fehlermeldungen beim Abspeichern kam. Bei der Pfadangabe muss der totale Pfad also mit / voran gestellt werden. Hattest noch vergessen.trim(). .replace('(sonoff)', '').trim()
trim(). war ein Punkt zu viel.. weshalb er .replace noch angemeckert hat..
Das mit dem Download klappt so nicht. Man muss jeden link separat downloaden und nen separaten Destpath zuweisen, weil das mit dem abspeichern sonst nicht klappt. In deiner version wurde 3 mal die selbe Datei beschrieben. Mit der Funktion habe ich mich damals lange rumgeärgert und ausprobiert bis das mit dem download geklappt hat.Wenn man das in einer Funktion machen möchte, muss man immer den Destpath 1 -3 und den Downloadlink 1 -3 mit ändern und ein delay zwischen den aufrufen einbauen.
Ansonsten sieht das richtig gut aus. Toll gelöst auch das mit der Hostname Darstellung.Einen Durchlauf habe ich jetzt noch nicht getestet. Mache ich später...
Habe jetzt schon bei mehreren gesehen, das anstatt var const verwendet wird. Welche Vorteile hat das?Habe die Kleinigkeiten nun mal korrigiert und auf aktuellen stand gebracht. Das Script zum weiter Testen hier.
Noch ein kleinen Fehler korrigiert...'+Hostname+ ' bei nicht aktuellen Geräten ersetzt mit ${hostName} damit dieserr auch richtig angezeigt wird..
Einzelne Updates funktionieren schon mal.Es wäre glaube ich noch von Vorteil, wenn im Updateprozess zusätlich zur IP im Log auch noch der Hostname steht...
-
ok. Danke für den Hinweis!
Habe gerade mal Deinen Hinweis umgesetzt.
var cacheSelectorTasmotaVersions = $('channel[state.id=sonoff.0.*.Info1_Version]');
Da erhalte ich für all meine Geräte diese Fehlermeldung:
javascript.0 2021-07-16 06:12:08.887 warn (4523) at processTicksAndRejections (internal/process/task_queues.js:84:21) javascript.0 2021-07-16 06:12:08.887 warn (4523) at endReadableNT (_stream_readable.js:1241:12) javascript.0 2021-07-16 06:12:08.887 warn (4523) at IncomingMessage.emit (events.js:326:22) javascript.0 2021-07-16 06:12:08.886 warn (4523) at Object.onceWrapper (events.js:420:28) javascript.0 2021-07-16 06:12:08.886 warn (4523) at IncomingMessage.<anonymous> (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1076:12) javascript.0 2021-07-16 06:12:08.886 warn (4523) at Request.emit (events.js:314:20) javascript.0 2021-07-16 06:12:08.885 warn (4523) at Request.<anonymous> (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1154:10) javascript.0 2021-07-16 06:12:08.885 warn (4523) at Request.emit (events.js:314:20) javascript.0 2021-07-16 06:12:08.884 warn (4523) at Request.self.callback (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:185:22) javascript.0 2021-07-16 06:12:08.884 warn (4523) at Request._callback (/opt/iobroker/node_modules/iobroker.javascript/lib/request.js:27:17) javascript.0 2021-07-16 06:12:08.883 warn (4523) at script.js.Test.Tasmota_Update:430:42 javascript.0 2021-07-16 06:12:08.883 warn (4523) at Object.result.each (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:801:29) javascript.0 2021-07-16 06:12:08.883 warn (4523) at script.js.Test.Tasmota_Update:446:32 javascript.0 2021-07-16 06:12:08.881 warn (4523) getState "sonoff.0.Waschmaschiene.INFO.Hostname" not found (3) javascript.0 2021-07-16 06:12:08.881 info (4523) script.js.Test.Tasmota_Update: Tasmota: Installierte Firmware für Gerät null ist aktuell.
-
@falke69 ja, du musst das an mehreren Stellen anpassen . Vergleich es mit meiner aktualisierten Version , habe ich oben mittlerweile eingefügt. Die Namensänderung kam mit V 9.5.0 oder eine Version früher...natürlich müssen die states bei dir auch entsprechend *.Info1_Version angelegt worden sein, also auch die neue Verfsion geladen sein.
-
vielen Dank!
Die neue Version habe ich jetzt geladen und soweit eingerichtet.
Aktuell werden mir im Log Geräte als Warnung angezeigt, die derzeit nicht
erreichbar sind (Weihnachtsbeleuchtung. ).Leider habe ich das Problem, dass die OTA URL nicht in das entsprechende Gerät abgesetzt werden kann. Wenn ich das richtig im Script deute, sollten doch die IP Adressen für die entsprechenden Geräte ausgelesen werden sollte.
javascript.0 2021-07-16 13:28:38.831 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Fehler beim setzen der OTA Minimal URL für: Error: Invalid URI "http:///cm?cmnd=OtaUrl%20http://192.168.178.xxx:8000/Tasmota/tasmota-minimal javascript.0 2021-07-16 13:28:21.713 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Folgende IP wurde für das Update vorgewählt: javascript.0 2021-07-16 13:28:18.128 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Folgende IP wurde für das Update vorgewählt: javascript.0 2021-07-16 13:28:02.246 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Fehler beim setzen der OTA Minimal URL für: Error: Invalid URI "http:///cm?cmnd=OtaUrl%20http://192.168.178.xxx:8000/Tasmota/tasmota-minima javascript.0 2021-07-16 13:27:51.423 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Firmwaredownload tasmota-sensors.bin gestartet. /home/pi/Tasmota/tasmota-sensors.bin.gz javascript.0 2021-07-16 13:27:51.400 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Firmwaredownload tasmota.bin gestartet. /home/pi/Tasmota/tasmota.bin.gz javascript.0 2021-07-16 13:27:51.367 info (22536) script.js.Tasmota_Update.Tasmota_Update: Tasmota: Firmwaredownload tasmota-minimal.bin gestartet. /home/pi/Tasmota/tasmota-minimal.bin.gz
-
@falke69 sagte in [Vorlage] Tasmota One Click Firmware Update Vis Javascript.:
Aktuell werden mir im Log Geräte als Warnung angezeigt, die derzeit nicht
erreichbar sind (Weihnachtsbeleuchtung. ).Nicht erreichbar für das skript oder generell offline? Also nicht im wlan?
Aktuell gibt es kein mechanismus der erreichbare und nicht erreichbare geräte unterscheidet. Es wird davon ausgegangen dass alle konfigurierten Geräte auch erreichbar sind.
Welche version hast du jetzt laufen? Die Testversion oder die von ganz oben? Die Testversion aus den threat vorher habe ich nur mit einzelnen Geräten lauffähig gemacht und getestet noch nicht update all. -
genau. Das sehe ich aber nicht so schlimm.
Mir geht es aktuell darum, dass die OTA URL nicht gesetzt werden kann.