NEWS
jarvis v3.2.x - just another remarkable vis
-
@mcu Ja, hab ich auch schon getestet.
-
@mcu Wenn ich auf der Konfigurationsseite den Adapter stoppe, hört der Dauerreload auf. Die Einstellungen werden aber nicht geladen. Es bleibt nur der Ladedonut aktiv.
Wenn ich den Adapter dann wieder starte, kommen die Einstellwerte und der Dauerreload kommt auch nicht mehr.
Dann kann ich auch ändern und speichern.
Wenn ich das Fenster dann schließe und wieder öffne, kommt wieder der Dauerreload. -
@meinzisas hast du den Web Adapter installiert?
-
@zefau Sorry für die späte Antwort. Ja, der web-Adapter ist installiert.
-
@meinzisas Was steht hier drin?
jarvis.0.settings.language
Wechselt der Inhalt auch dauernd?Welche web-Instanz ist vorhanden / wird genutzt?
web.0
Kannst du mal ein Video machen, damit es sehen kann, was genau passiert?
ScreenToGif
-
@mcu In language steht nix drinn. Den hab ich beim Probieren wegen dem Problem mal gelöscht. Der Wert vorher war de-DE.
Hab das mal als Video hochgeladen. So läuft das in der Dauerschleife.
web-Instanz ist web.0
-
@mcu Das steht bei Seite untersuchen in Chrome.
[2024-09-24T04:20:32.603Z] Try to connect "Upload Configuration": {"en": "Upload Configuration", "de": "Upload Configuration", "ru": "Upload Configuration", "pt": "Upload Configuration", "nl": "Upload Configuration", "fr": "Upload Configuration", "es": "Upload Configuration", "pl": "Upload Configuration", "it": "Upload Configuration", "zh-cn": "Upload Configuration"}, "Download Configuration": {"en": "Download Configuration", "de": "Download Configuration", "ru": "Download Configuration", "pt": "Download Configuration", "nl": "Download Configuration", "fr": "Download Configuration", "es": "Download Configuration", "pl": "Download Configuration", "it": "Download Configuration", "zh-cn": "Download Configuration"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Cancel": {"en": "Cancel", "de": "Cancel", "ru": "Cancel", "pt": "Cancel", "nl": "Cancel", "fr": "Cancel", "es": "Cancel", "pl": "Cancel", "it": "Cancel", "zh-cn": "Cancel"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Please be aware that backups will be deleted when the adapter is updated.": {"en": "Please be aware that backups will be deleted when the adapter is updated.", "de": "Please be aware that backups will be deleted when the adapter is updated.", "ru": "Please be aware that backups will be deleted when the adapter is updated.", "pt": "Please be aware that backups will be deleted when the adapter is updated.", "nl": "Please be aware that backups will be deleted when the adapter is updated.", "fr": "Please be aware that backups will be deleted when the adapter is updated.", "es": "Please be aware that backups will be deleted when the adapter is updated.", "pl": "Please be aware that backups will be deleted when the adapter is updated.", "it": "Please be aware that backups will be deleted when the adapter is updated.", "zh-cn": "Please be aware that backups will be deleted when the adapter is updated."}, "Devices": {"en": "Devices", "de": "Devices", "ru": "Devices", "pt": "Devices", "nl": "Devices", "fr": "Devices", "es": "Devices", "pl": "Devices", "it": "Devices", "zh-cn": "Devices"}, "Layout": {"en": "Layout", "de": "Layout", "ru": "Layout", "pt": "Layout", "nl": "Layout", "fr": "Layout", "es": "Layout", "pl": "Layout", "it": "Layout", "zh-cn": "Layout"}, "Widgets": {"en": "Widgets", "de": "Widgets", "ru": "Widgets", "pt": "Widgets", "nl": "Widgets", "fr": "Widgets", "es": "Widgets", "pl": "Widgets", "it": "Widgets", "zh-cn": "Widgets"}, "Settings": {"en": "Settings", "de": "Settings", "ru": "Settings", "pt": "Settings", "nl": "Settings", "fr": "Settings", "es": "Settings", "pl": "Settings", "it": "Settings", "zh-cn": "Settings"}, "Styles": {"en": "Styles", "de": "Styles", "ru": "Styles", "pt": "Styles", "nl": "Styles", "fr": "Styles", "es": "Styles", "pl": "Styles", "it": "Styles", "zh-cn": "Styles"}, "Scripts": {"en": "Scripts", "de": "Scripts", "ru": "Scripts", "pt": "Scripts", "nl": "Scripts", "fr": "Scripts", "es": "Scripts", "pl": "Scripts", "it": "Scripts", "zh-cn": "Scripts"}, Get backups for "devices"... Get backups for "layout"... Get backups for "widgets"... Get backups for "settings"... Get backups for "styles"... Get backups for "scripts"... Got backups for "devices". Got backups for "layout". Got backups for "widgets". Got backups for "settings". Got backups for "styles". Got backups for "scripts". "Upload Configuration": {"en": "Upload Configuration", "de": "Upload Configuration", "ru": "Upload Configuration", "pt": "Upload Configuration", "nl": "Upload Configuration", "fr": "Upload Configuration", "es": "Upload Configuration", "pl": "Upload Configuration", "it": "Upload Configuration", "zh-cn": "Upload Configuration"}, "Download Configuration": {"en": "Download Configuration", "de": "Download Configuration", "ru": "Download Configuration", "pt": "Download Configuration", "nl": "Download Configuration", "fr": "Download Configuration", "es": "Download Configuration", "pl": "Download Configuration", "it": "Download Configuration", "zh-cn": "Download Configuration"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Cancel": {"en": "Cancel", "de": "Cancel", "ru": "Cancel", "pt": "Cancel", "nl": "Cancel", "fr": "Cancel", "es": "Cancel", "pl": "Cancel", "it": "Cancel", "zh-cn": "Cancel"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Please be aware that backups will be deleted when the adapter is updated.": {"en": "Please be aware that backups will be deleted when the adapter is updated.", "de": "Please be aware that backups will be deleted when the adapter is updated.", "ru": "Please be aware that backups will be deleted when the adapter is updated.", "pt": "Please be aware that backups will be deleted when the adapter is updated.", "nl": "Please be aware that backups will be deleted when the adapter is updated.", "fr": "Please be aware that backups will be deleted when the adapter is updated.", "es": "Please be aware that backups will be deleted when the adapter is updated.", "pl": "Please be aware that backups will be deleted when the adapter is updated.", "it": "Please be aware that backups will be deleted when the adapter is updated.", "zh-cn": "Please be aware that backups will be deleted when the adapter is updated."}, "Devices": {"en": "Devices", "de": "Devices", "ru": "Devices", "pt": "Devices", "nl": "Devices", "fr": "Devices", "es": "Devices", "pl": "Devices", "it": "Devices", "zh-cn": "Devices"}, "Layout": {"en": "Layout", "de": "Layout", "ru": "Layout", "pt": "Layout", "nl": "Layout", "fr": "Layout", "es": "Layout", "pl": "Layout", "it": "Layout", "zh-cn": "Layout"}, "Widgets": {"en": "Widgets", "de": "Widgets", "ru": "Widgets", "pt": "Widgets", "nl": "Widgets", "fr": "Widgets", "es": "Widgets", "pl": "Widgets", "it": "Widgets", "zh-cn": "Widgets"}, "Settings": {"en": "Settings", "de": "Settings", "ru": "Settings", "pt": "Settings", "nl": "Settings", "fr": "Settings", "es": "Settings", "pl": "Settings", "it": "Settings", "zh-cn": "Settings"}, "Styles": {"en": "Styles", "de": "Styles", "ru": "Styles", "pt": "Styles", "nl": "Styles", "fr": "Styles", "es": "Styles", "pl": "Styles", "it": "Styles", "zh-cn": "Styles"}, "Scripts": {"en": "Scripts", "de": "Scripts", "ru": "Scripts", "pt": "Scripts", "nl": "Scripts", "fr": "Scripts", "es": "Scripts", "pl": "Scripts", "it": "Scripts", "zh-cn": "Scripts"}, Message broker queried succesfully. 3 jarvis Load setting "authentication" (radio) with value: none [object Object] jarvis Load setting "authenticationGroup" (select) with value: system.group.user,system.group.administrator [object Object] 3 jarvis Load setting "authenticationConfiguration" (radio) with value: none [object Object] jarvis Load setting "authenticationConfigurationGroup" (select) with value: system.group.user,system.group.administrator [object Object] jarvis Load setting "certPublic" (select) with value: [object Object] jarvis Load setting "certPrivate" (select) with value: [object Object] jarvis Load setting "certChained" (select) with value: [object Object] jarvis Load setting "socketPort" (number) with value: 8400 [object Object] jarvis Load setting "socketSecure" (checkbox) with value: false [object Object] jarvis Load setting "authenticationPassword" (password) with value: [object Object] jarvis Load setting "authenticationConfigurationPassword" (password) with value: [object Object] Instances.tsx:1090 Width: xl [2024-09-24T04:20:33.693Z] Try to connect "Upload Configuration": {"en": "Upload Configuration", "de": "Upload Configuration", "ru": "Upload Configuration", "pt": "Upload Configuration", "nl": "Upload Configuration", "fr": "Upload Configuration", "es": "Upload Configuration", "pl": "Upload Configuration", "it": "Upload Configuration", "zh-cn": "Upload Configuration"}, "Download Configuration": {"en": "Download Configuration", "de": "Download Configuration", "ru": "Download Configuration", "pt": "Download Configuration", "nl": "Download Configuration", "fr": "Download Configuration", "es": "Download Configuration", "pl": "Download Configuration", "it": "Download Configuration", "zh-cn": "Download Configuration"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Cancel": {"en": "Cancel", "de": "Cancel", "ru": "Cancel", "pt": "Cancel", "nl": "Cancel", "fr": "Cancel", "es": "Cancel", "pl": "Cancel", "it": "Cancel", "zh-cn": "Cancel"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Please be aware that backups will be deleted when the adapter is updated.": {"en": "Please be aware that backups will be deleted when the adapter is updated.", "de": "Please be aware that backups will be deleted when the adapter is updated.", "ru": "Please be aware that backups will be deleted when the adapter is updated.", "pt": "Please be aware that backups will be deleted when the adapter is updated.", "nl": "Please be aware that backups will be deleted when the adapter is updated.", "fr": "Please be aware that backups will be deleted when the adapter is updated.", "es": "Please be aware that backups will be deleted when the adapter is updated.", "pl": "Please be aware that backups will be deleted when the adapter is updated.", "it": "Please be aware that backups will be deleted when the adapter is updated.", "zh-cn": "Please be aware that backups will be deleted when the adapter is updated."}, "Devices": {"en": "Devices", "de": "Devices", "ru": "Devices", "pt": "Devices", "nl": "Devices", "fr": "Devices", "es": "Devices", "pl": "Devices", "it": "Devices", "zh-cn": "Devices"}, "Layout": {"en": "Layout", "de": "Layout", "ru": "Layout", "pt": "Layout", "nl": "Layout", "fr": "Layout", "es": "Layout", "pl": "Layout", "it": "Layout", "zh-cn": "Layout"}, "Widgets": {"en": "Widgets", "de": "Widgets", "ru": "Widgets", "pt": "Widgets", "nl": "Widgets", "fr": "Widgets", "es": "Widgets", "pl": "Widgets", "it": "Widgets", "zh-cn": "Widgets"}, "Settings": {"en": "Settings", "de": "Settings", "ru": "Settings", "pt": "Settings", "nl": "Settings", "fr": "Settings", "es": "Settings", "pl": "Settings", "it": "Settings", "zh-cn": "Settings"}, "Styles": {"en": "Styles", "de": "Styles", "ru": "Styles", "pt": "Styles", "nl": "Styles", "fr": "Styles", "es": "Styles", "pl": "Styles", "it": "Styles", "zh-cn": "Styles"}, "Scripts": {"en": "Scripts", "de": "Scripts", "ru": "Scripts", "pt": "Scripts", "nl": "Scripts", "fr": "Scripts", "es": "Scripts", "pl": "Scripts", "it": "Scripts", "zh-cn": "Scripts"}, Get backups for "devices"... Get backups for "layout"... Get backups for "widgets"... Get backups for "settings"... Get backups for "styles"... Get backups for "scripts"... Got backups for "devices". Got backups for "layout". Got backups for "widgets". Got backups for "settings". Got backups for "styles". Got backups for "scripts". Message broker queried succesfully. "Upload Configuration": {"en": "Upload Configuration", "de": "Upload Configuration", "ru": "Upload Configuration", "pt": "Upload Configuration", "nl": "Upload Configuration", "fr": "Upload Configuration", "es": "Upload Configuration", "pl": "Upload Configuration", "it": "Upload Configuration", "zh-cn": "Upload Configuration"}, "Download Configuration": {"en": "Download Configuration", "de": "Download Configuration", "ru": "Download Configuration", "pt": "Download Configuration", "nl": "Download Configuration", "fr": "Download Configuration", "es": "Download Configuration", "pl": "Download Configuration", "it": "Download Configuration", "zh-cn": "Download Configuration"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Cancel": {"en": "Cancel", "de": "Cancel", "ru": "Cancel", "pt": "Cancel", "nl": "Cancel", "fr": "Cancel", "es": "Cancel", "pl": "Cancel", "it": "Cancel", "zh-cn": "Cancel"}, "Restore": {"en": "Restore", "de": "Restore", "ru": "Restore", "pt": "Restore", "nl": "Restore", "fr": "Restore", "es": "Restore", "pl": "Restore", "it": "Restore", "zh-cn": "Restore"}, "Please be aware that backups will be deleted when the adapter is updated.": {"en": "Please be aware that backups will be deleted when the adapter is updated.", "de": "Please be aware that backups will be deleted when the adapter is updated.", "ru": "Please be aware that backups will be deleted when the adapter is updated.", "pt": "Please be aware that backups will be deleted when the adapter is updated.", "nl": "Please be aware that backups will be deleted when the adapter is updated.", "fr": "Please be aware that backups will be deleted when the adapter is updated.", "es": "Please be aware that backups will be deleted when the adapter is updated.", "pl": "Please be aware that backups will be deleted when the adapter is updated.", "it": "Please be aware that backups will be deleted when the adapter is updated.", "zh-cn": "Please be aware that backups will be deleted when the adapter is updated."}, "Devices": {"en": "Devices", "de": "Devices", "ru": "Devices", "pt": "Devices", "nl": "Devices", "fr": "Devices", "es": "Devices", "pl": "Devices", "it": "Devices", "zh-cn": "Devices"}, "Layout": {"en": "Layout", "de": "Layout", "ru": "Layout", "pt": "Layout", "nl": "Layout", "fr": "Layout", "es": "Layout", "pl": "Layout", "it": "Layout", "zh-cn": "Layout"}, "Widgets": {"en": "Widgets", "de": "Widgets", "ru": "Widgets", "pt": "Widgets", "nl": "Widgets", "fr": "Widgets", "es": "Widgets", "pl": "Widgets", "it": "Widgets", "zh-cn": "Widgets"}, "Settings": {"en": "Settings", "de": "Settings", "ru": "Settings", "pt": "Settings", "nl": "Settings", "fr": "Settings", "es": "Settings", "pl": "Settings", "it": "Settings", "zh-cn": "Settings"}, "Styles": {"en": "Styles", "de": "Styles", "ru": "Styles", "pt": "Styles", "nl": "Styles", "fr": "Styles", "es": "Styles", "pl": "Styles", "it": "Styles", "zh-cn": "Styles"}, "Scripts": {"en": "Scripts", "de": "Scripts", "ru": "Scripts", "pt": "Scripts", "nl": "Scripts", "fr": "Scripts", "es": "Scripts", "pl": "Scripts", "it": "Scripts", "zh-cn": "Scripts"}, 3 jarvis Load setting "authentication" (radio) with value: none [object Object] jarvis Load setting "authenticationGroup" (select) with value: system.group.user,system.group.administrator [object Object] 3 jarvis Load setting "authenticationConfiguration" (radio) with value: none [object Object] jarvis Load setting "authenticationConfigurationGroup" (select) with value: system.group.user,system.group.administrator [object Object] jarvis Load setting "certPublic" (select) with value: [object Object] jarvis Load setting "certPrivate" (select) with value: [object Object] jarvis Load setting "certChained" (select) with value: [object Object] jarvis Load setting "socketPort" (number) with value: 8400 [object Object] jarvis Load setting "socketSecure" (checkbox) with value: false [object Object] jarvis Load setting "authenticationPassword" (password) with value: [object Object] jarvis Load setting "authenticationConfigurationPassword" (password) with value: [object Object] Instances.tsx:1090 Width: xl [2024-09-24T04:20:34.972Z] Try to connect
Wiederholen sich immer die selben Einträge. Wenn ich die Konfigseite so laufen lasse, hört das Laden dann irgendwann auf und die Werte stehen drinn.
-
Hi,
ich habe jetzt die Version v3.2.0-rc.5 installiert in Kombination mit dem neuen Admin-Panel 7.1.3.
Leider funktioniert seit dem update mein iobroker sehr störrisch. Ich habe unter Übersicht jetzt 2 Jarvis. Einmal mit dem Port 8400, welche auch Funktioniert und einmal mit Port: undefined, welche nicht funktioniert.
Wie bekomme ich die alte Version weg?
Vielen Dank für die Hilfe.
Meike -
@Homoran @Thomas-Braun Weiß jemand, wie man solch alte Einträge (Übersicht Anzeige Jarvis mit altem Port 8082, der aber nicht genutzt wird-> undefined) weg bekommt?
Upload?
Wo werden die Einträge gespeichert?
Muss man evtl. jarvis komplett entfernen, damit auch alle Einträge einmal gelöscht werden. -
Da ich keine GUI hier laufen habe kann ich dazu nichts erhellendes beitragen.
Zwei Instanzen am Start?
iob diag
wäre mal wieder hilfreich.
-
Leider funktioniert seit dem update mein iobroker sehr störrisch
Warum? Wegen der Übersicht?
Jarvis ist noch beta!, da sind noch einige offene Punkte.VORHER bitte ein Bild mit dem undefined, möchte es mit in die Doku nehmen. Danke.
Man kann in der Übersicht den fehlerhaften Eintrag entfernen.
rechts unten klicken und dann das Element anklicken, welches entfernt werden soll. Auf den blauen Haken klicken.
-> Element hat einen grauen Haken
dann unten rechts auf den grünen Haken klicken und es wird gespeichert.
-
@mcu Vielen Dank.
Aber es ist ja nicht wirklich gelöscht, sondern nur ausgeblendet. Kann man das nicht irgendwo entfernen. Es muss ja noch irgendwo ein Verweis zur alten Version sein.
-
@meikie Weiß ich leider nicht. Müsste man beim iobroker.admin mal ein Issue setzen.
Danke für das Bild, hab in die Doku mit aufgenommen. -
Hallo, weiß jemand wie ich in jarvis einen Wert von Watt Stunden in kilowatt Stunden umrechen kann? Mit einer Nachkommastelle? Geht das oder muss ich da ein Blockly oder sowas machen?
also 36500 Wh in 36,5 kWh wäre die Umrechnung z.B.
-
-
Hi zusammen,
vielleicht könnt ihr mir helfen, ich habe heute Jarvis auf v3.2.0-rc.5 aktualisiert, das hat soweit auch alles funktioniert. Anfangs läuft auch alles schick, nach einiger Zeit (wenn der Tab sich schlafen legt?) kommt es zu folgender Fehlermeldung und Jarvis wird frecherweise deaktiviert..:jarvis.0 2024-09-30 17:23:17.856 info terminating jarvis.0 2024-09-30 17:23:17.354 warn Terminated (UNCAUGHT_EXCEPTION): Without reason jarvis.0 2024-09-30 17:23:17.353 info terminating jarvis.0 2024-09-30 17:23:17.352 info Adapter stopped und unloaded. jarvis.0 2024-09-30 17:23:17.351 error unhandled promise rejection: null jarvis.0 2024-09-30 17:23:17.350 error Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). jarvis.0 2024-09-30 17:18:41.414 warn Failed moving user scripts due to "ENOENT: no such file or directory, lstat '/opt/iobroker/node_modules/iobroker.jarvis/../../iobroker-data/files/0_userdata.0/jarvis-scripts'"! jarvis.0 2024-09-30 17:18:36.098 info Connection: WebSocket opened on port 8400 using http... jarvis.0 2024-09-30 17:18:35.933 info starting. Version 3.2.0-rc.5 in /opt/iobroker/node_modules/iobroker.jarvis, node: v20.17.0, js-controller: 6.0.11
Unter Dateien / Benutzerdaten hat Jarvis den entsprechenden Ordner angelegt...
Beste Grüße
Mirko
-
@miwolf Der Ordner ist angelegt. Wenn du jetzt jarvis wieder startest, passiert was?
-
@mcu
Es gibt leider keine Änderung. Der Ordner war ja auch schon vorher da (im IOBroker unter Dateien)...Beste Grüße Mirko
jarvis.0 2024-10-01 11:03:02.561 info Adapter stopped und unloaded. jarvis.0 2024-10-01 11:03:02.560 error unhandled promise rejection: null jarvis.0 2024-10-01 11:03:02.559 error Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). jarvis.0 2024-10-01 11:01:36.829 warn Failed moving user scripts due to "ENOENT: no such file or directory, lstat '/opt/iobroker/node_modules/iobroker.jarvis/../../iobroker-data/files/0_userdata.0/jarvis-scripts'"! jarvis.0 2024-10-01 11:01:31.535 info Connection: WebSocket opened on port 8400 using http... jarvis.0 2024-10-01 11:01:31.372 info starting. Version 3.2.0-rc.5 in /opt/iobroker/node_modules/iobroker.jarvis, node: v20.17.0, js-controller: 6.0.11
Nachtrag:
ich habe gerade gesehen, das bei mir unter /opt/iobroker/iobroker-data/files kein Ordner 0_userdata.0 existiert. Da findet sich nur admin.admin, backitup.admin und discorvery.admin. Spannenderweise sehe in im IOBroker unter "Dateien" die entsprechende Ordnerstruktur..Ich erzeuge mal die Ordner händisch und melde mich wieder.
Btw: Das was bei mir "nicht" normal ist... Ich hab eine Redis-Installation, wo der Redis-Server auf einem anderen System als den Raspi läuft.. ansonsten ist es eine frische Installation die via BackitUp wieder hergestellt wurde...Nachtrag 2:
lege ich die Ordnerstruktur im Filesystem händisch an, startet Jarvis problemlos..
Nachtrag 3:
leider scheint das aber nicht die Ursache für die Exception gewesen zu sein, die besteht leider weiterhin:
-
@miwolf Nutzt du denn scripts?
Was sagt denn der Browser-LOG (F12)?
Admin Version 7? -
In der Console bekomme ich die folgende Fehlermeldung:
Ich bin mal durch den Code debugged und bin hier gelandet
(Sorry für den Screenshot)
Ich hab keine Scripts und kein CustomCSS
Admin ist Version 7.1.5.