NEWS
Alpha Test js-controller Kiera (v6.0)
-
@dlehmann ok irgendwie ist der repo Eintrag undefined, kann ich morgen abfangen.
-
Ich glaube, ich habe die klemmende Stelle gefunden. Die Daten kommen per mqtt rein, das funktioniert auch.
Dann werden die über dieses Skript aufgedröselt und nach 0_userdata.0 geschrieben. Aber da kommen keine aktualisierten Werte an. Mit dem stable js-controller funktioniert es, mit der alpha nicht.
Ich kann nur kein JavaSkript...// where the mqtt messages arrive const mqttDatenpunktObjectId = 'mqtt.0.solix.site.Stromstausee.scenInfo'; // where the states should appear const userDataFolder = '0_userdata.0.solix'; // ############## end user config // receive on(mqttDatenpunktObjectId, (obj) => { const jsonString = obj.state.val; const jsonData = JSON.parse(jsonString); function createObjectsRecursively(parent, data) { for (const key in data) { const obj = data[key]; const stateName = `${parent}.${key}`; if (typeof obj === 'object') { createObjectsRecursively(stateName, obj); } else { let value = obj; // Check if the state already exists. If it does, just update the value. // If it does not exist create the states. if (!existsState(stateName)) { // If the state does not exist, create it and set the value createState(stateName, value, { name: key, type: typeof value, role: "value", read: true, write: true }); log(`Created state ${stateName}`); } else { setState(stateName, value, true); } } } } createObjectsRecursively(userDataFolder, jsonData); });
-
@foxriver76 sagte in Alpha Test js-controller Kiera (v6.0):
Der letzte Adapter wo kommt der her? Finde ich weder im Repo noch auf npm noch mit einer kurzen Google Suche, vermute der ist schwer veraltet.
Der Samsung Adapter ist dieser hier https://github.com/iobroker-community-adapters/ioBroker.samsung aber auf meinem Testsystem hatte ich aus irgendwelchen Gründen eine github Installation drauf. Ich hab jetzt mal die letzte Version installiert und gestartet und das hier kommt dann im Log:
host.ioBrokerTestsystem 2024-05-23 20:30:59.837 error instance system.adapter.samsung.0 terminated with code 1 (JS_CONTROLLER_STOPPED) host.ioBrokerTestsystem 2024-05-23 20:30:59.835 error Caught by controller[1]: Node.js v18.20.3 host.ioBrokerTestsystem 2024-05-23 20:30:59.832 error Caught by controller[0]: at node:internal/main/run_main_module:28:49 host.ioBrokerTestsystem 2024-05-23 20:30:59.829 error Caught by controller[0]: at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:128:12) host.ioBrokerTestsystem 2024-05-23 20:30:59.827 error Caught by controller[0]: at Module._load (node:internal/modules/cjs/loader:1019:12) host.ioBrokerTestsystem 2024-05-23 20:30:59.825 error Caught by controller[0]: at Module.load (node:internal/modules/cjs/loader:1203:32) host.ioBrokerTestsystem 2024-05-23 20:30:59.822 error Caught by controller[0]: at Module._extensions..js (node:internal/modules/cjs/loader:1422:10) host.ioBrokerTestsystem 2024-05-23 20:30:59.820 error Caught by controller[0]: at Module._compile (node:internal/modules/cjs/loader:1364:14) host.ioBrokerTestsystem 2024-05-23 20:30:59.818 error Caught by controller[0]: at Object.<anonymous> (/opt/iobroker/node_modules/iobroker.samsung/main.js:118:21) host.ioBrokerTestsystem 2024-05-23 20:30:59.815 error Caught by controller[0]: TypeError: utils.Adapter is not a function host.ioBrokerTestsystem 2024-05-23 20:30:59.813 error Caught by controller[0]: ^ host.ioBrokerTestsystem 2024-05-23 20:30:59.810 error Caught by controller[0]: var adapter = utils.Adapter({ host.ioBrokerTestsystem 2024-05-23 20:30:59.807 error Caught by controller[0]: /opt/iobroker/node_modules/iobroker.samsung/main.js:118 host.ioBrokerTestsystem 2024-05-23 20:30:56.456 info instance system.adapter.samsung.0 started with pid 22910 host.ioBrokerTestsystem 2024-05-23 20:30:54.659 info "system.adapter.samsung.0" enabled
-
@feuersturm Ohje ja der ist komplett veraltet, der funktioniert aber mit 5.0.19 auch nicht oder? Aber ja kann man wieder lauffähig bekommen müsste man auf Adapter Core überhaupt mal umstellen.
-
@foxriver76 said in Alpha Test js-controller Kiera (v6.0):
@feuersturm Ohje ja der ist komplett veraltet, der funktioniert aber mit 5.0.19 auch nicht oder? Aber ja kann man wieder lauffähig bekommen müsste man auf Adapter Core überhaupt mal umstellen.
Der ist mir durchgerutscht.
Ja da sind die Tests auf rot. Hab ich übersehen. Wie Foxriver schon geschrieben brauchts da Adapter core. Kann ich mir ansehen wenns nicht mehr heute od. morgen sein muss.
Tests gäbs ja dannP.S: Kann mir aber nicht vorstellen, dass der unter 5.0.19 funktioniert hat ...
-
@thomas-braun kannst du mal in Zeile 18 (Referenz hier in Code Tags) ein mit einbauen ob das überhaupt noch getriggert wird. Aber scheint dann nicht alias spezifisch zu sein
-
@foxriver76 sagte in Alpha Test js-controller Kiera (v6.0):
@thomas-braun kannst du mal in Zeile 18 (Referenz hier in Code Tags) ein mit einbauen ob das überhaupt noch getriggert wird. Aber scheint dann nicht alias spezifisch zu sein
Nein, mit alias hat das nix zu tun dann, die aliasisierung erfolgt ja später in der Kette.
Aber was soll ich da genau einbauen? Wie gesagt, mein JavaSkript-Wissen ist 'non-existent'. -
@thomas-braun zb
log(JSON.stringify(obj.state.val))
und dann schauen ob da was geloggt wird wenn der mqtt Datenpunkt aktualisiert wird. -
@foxriver76 sagte in Alpha Test js-controller Kiera (v6.0):
@thomas-braun zb log(JSON.stringify(obj.state.val)) und dann schauen ob da was geloggt wird wenn der mqtt Datenpunkt aktualisiert wird.
Ja, da kommt was um's Eck:
2024-05-23 20:59:00.288 - info: javascript.0 (7173) script.js.solix2mqtt: "{\"home_info\":{\"home_name\":\"Home\",\"home_img\":\"\",\"charging_power\":\"0.00\",\"power_unit\":\"W\"},\"solar_list\":[],\"pps_info\":{\"pps_list\":[],\"total_charging_power\":\"0.00\",\"power_unit\":\"W\",\"total_battery_power\":\"0.00\",\"updated_time\":\"\",\"pps_status\":0},\"statistics\":[{\"type\":\"1\",\"total\":\"312.70\",\"unit\":\"kwh\"},{\"type\":\"2\",\"total\":\"311.76\",\"unit\":\"kg\"},{\"type\":\"3\",\"total\":\"87.56\",\"unit\":\"€\"}],\"topology_type\":\"1\",\"solarbank_info\":{\"solarbank_list\":[{\"device_pn\":\"GELÖSCHT\",\"device_sn\":\"GELÖSCHT\",\"device_name\":\"Solarbank E1600\",\"device_img\":\"https://public-aiot-fra-prod.s3.dualstack.eu-central-1.amazonaws.com/anker-power/public/product/2024/05/10/iot-admin/FycBdab/20230719-144818.png\",\"battery_power\":\"91\",\"bind_site_status\":\"\",\"charging_power\":\"151\",\"power_unit\":\"W\",\"charging_status\":\"2\",\"status\":\"1\",\"wireless_type\":\"1\",\"main_version\":\"\",\"photovoltaic_power\":\"0\",\"output_power\":\"151\",\"create_time\":1695834954,\"set_load_power\":\"\",\"output_cutoff_data\":10,\"is_display\":true}],\"total_charging_power\":\"0\",\"power_unit\":\"W\",\"charging_status\":\"0\",\"total_battery_power\":\"0.91\",\"updated_time\":\"2024-05-23 20:58:57\",\"total_photovoltaic_power\":\"0\",\"total_output_power\":\"151.00\",\"display_set_power\":false,\"is_display_data\":true},\"retain_load\":\"150W\",\"updated_time\":\"01-01-0001 00:00:00\",\"power_site_type\":2,\"site_id\":\"GELÖSCHT\",\"powerpanel_list\":[]}" 2024-05-23 20:59:04.901 - info: javascript.0 (7173) script.js.stromzaehler2: "{\"Time\":\"2024-05-23T20:59:03\",\"SML\":{\"total_bez\":5519602.3,\"total_bez_kwh\":5519.6,\"netz_frequenz\":50.2,\"aktuelle_wirkleistung\":101,\"strom_l1\":0.21,\"strom_l2\":1.17,\"strom_l3\":0.00,\"spannung_l1\":232.4,\"spannung_l2\":233.3,\"spannung_l3\":231.3,\"delta_phi_I_U_L1\":16,\"delta_phi_I_U_L2\":-72,\"delta_phi_I_U_L3\":0}}"
Das ist wohl das rohe mqtt-Telegramm oder wie das heißt.
-
@foxriver76 sagte in Alpha Test js-controller Kiera (v6.0):
@feuersturm die oberen mit dem zipFiles muss ich schauen wie wir das gefixt bekommen, liegt nicht direkt an den Adaptern, ist dort zwar fixbar aber wäre zu viel Aufwand für alle. Ist ja eh eine Testinstallation nehme ich an. Kannst du mal in /opt/iobroker den Befehl npm update ausführen. Und dann neustarten und schauen ob die oberen 3 Adapter laufen.
npm update durchgeführt:
proxmox@ioBrokerTestsystem:~$ cd /opt/iobroker/ proxmox@ioBrokerTestsystem:/opt/iobroker$ npm update [sudo] password for proxmox: npm warn ERESOLVE overriding peer dependency npm warn While resolving: @mui/x-date-pickers@7.5.1 npm warn Found: @mui/material@5.14.14 npm warn node_modules/@iobroker/adapter-react-v5/node_modules/@mui/material npm warn @mui/material@"5.14.14" from @iobroker/adapter-react-v5@4.13.22 npm warn node_modules/@iobroker/adapter-react-v5 npm warn @iobroker/adapter-react-v5@"^4.13.13" from iobroker.radar-trap@2.2.0 npm warn node_modules/iobroker.radar-trap npm warn 1 more (@iobroker/json-config) npm warn npm warn Could not resolve dependency: npm warn peer @mui/material@"^5.15.14" from @mui/x-date-pickers@7.5.1 npm warn node_modules/@iobroker/adapter-react-v5/node_modules/@mui/x-date-pickers npm warn @mui/x-date-pickers@"^7.5.0" from @iobroker/adapter-react-v5@4.13.22 npm warn node_modules/@iobroker/adapter-react-v5 npm warn npm warn Conflicting peer dependency: @mui/material@5.15.18 npm warn node_modules/@mui/material npm warn peer @mui/material@"^5.15.14" from @mui/x-date-pickers@7.5.1 npm warn node_modules/@iobroker/adapter-react-v5/node_modules/@mui/x-date-pickers npm warn @mui/x-date-pickers@"^7.5.0" from @iobroker/adapter-react-v5@4.13.22 npm warn node_modules/@iobroker/adapter-react-v5 npm warn reify invalid or damaged lockfile detected npm warn reify please re-try this operation once it completes npm warn reify so that the damage can be corrected, or perform npm warn reify a fresh install with no lockfile if the problem persists. npm warn skipping integrity check for git dependency ssh://git@github.com/xXBJXx/ioBroker.fully-tablet-control.git npm warn deprecated npmlog@2.0.4: This package is no longer supported. npm warn deprecated har-validator@5.1.5: this library is no longer supported npm warn deprecated are-we-there-yet@1.1.7: This package is no longer supported. npm warn deprecated gauge@1.2.7: This package is no longer supported. npm warn deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm warn deprecated npmlog@5.0.1: This package is no longer supported. npm warn deprecated are-we-there-yet@2.0.0: This package is no longer supported. npm warn deprecated gauge@3.0.2: This package is no longer supported. npm warn deprecated @appland/appmap-agent-js@13.9.2: This package has been deprecated. Please use appmap-node instead added 354 packages, removed 314 packages, and changed 344 packages in 5m 391 packages are looking for funding run `npm fund` for details
Nach dem npm update und einem iob stop und start sind alle Adapter ohne Probleme gestartet
-
@thomas-braun und vor der Zeile
setState(stateName, value, true);
mallog(stateName + ': ' + value)
, weil dann müsste er auf jeden Fall den State setzen wenn er da was loggt, evtl. gibt uns die Ausgabe trotzdem einen Hinweis. -
Hallo,
auf meinem Testsystem läuft jetzt auch der neue Controller. Im Testsystem laufen alle Adapter mit dem Beta-Repro und sind auf dem letzten Stand.Der Fahrplan Adapter 1.2.3 startet nicht und bringt folgende Meldungen.läuft jetzt nachnpm update
Bei dem Javascript Adapter 8.3.1 ist mir folgendes aufgefallen, dass die Module nicht mehr einzeln in der Config stehen.
habe sie jetzt neu eingetragen, sie werden aber laut Log-Ausgabe nicht geladen / installiert, was mir diese Fehlermeldung bestätigt.
javascript.0 2024-05-24 11:37:12.904 info Compiling TypeScript source script.js.common.NSPanel4400 javascript.0 2024-05-24 11:37:15.383 info script.js.common.NSPanel4400: source code did not change, using cached compilation result... javascript.0 2024-05-24 11:37:15.728 warn script.js.common.NSPanel4400: error at function init_dayjs: dayjs_1.locale is not a function javascript.0 2024-05-24 11:37:15.747 info script.js.common.NSPanel4400: setObjects enabled - create Alias Channels possible javascript.0 2024-05-24 11:37:15.772 info script.js.common.NSPanel4400: weather alias for accuweather.0. already exists javascript.0 2024-05-24 11:37:15.897 info script.js.common.NSPanel4400: registered 33 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions javascript.0 2024-05-24 11:37:16.379 info script.js.common.NSPanel4400: Desired TFT Firmware: 54 / v4.4.0 javascript.0 2024-05-24 11:37:16.381 info script.js.common.NSPanel4400: Installed TFT Firmware: 53 / v4.3.3 javascript.0 2024-05-24 11:37:16.824 info script.js.common.NSPanel4400: Debug mode disabled javascript.0 2024-05-24 11:37:17.243 info script.js.common.NSPanel4400: Desired TFT Firmware: 54 / v4.4.0 javascript.0 2024-05-24 11:37:17.244 info script.js.common.NSPanel4400: Installed TFT Firmware: 53 / v4.3.3 javascript.0 2024-05-24 11:37:17.799 info script.js.common.NSPanel4400: Desired TFT Firmware: 54 / v4.4.0 javascript.0 2024-05-24 11:37:17.800 info script.js.common.NSPanel4400: Installed TFT Firmware: 53 / v4.3.3 javascript.0 2024-05-24 11:37:17.910 info script.js.common.NSPanel4400: Desired TFT Firmware: 54 / v4.4.0 javascript.0 2024-05-24 11:37:17.911 info script.js.common.NSPanel4400: Installed TFT Firmware: 53 / v4.3.3 javascript.0 2024-05-24 11:37:29.303 warn script.js.common.NSPanel4400: error at function HandleScreensaverUpdate: parseFormat is not a function javascript.0 2024-05-24 11:37:53.476 info Stopping script script.js.common.NSPanel4400
der netamo-crawler Adapter 0.8.1 läuft auch nicht mehr , selbst im Debug modus der Instanz kommen nicht mehr Daten.Läuft jetzt nachnpm update
das waren die ersten Sachen die ich gefunden habe bei mir.
-
@tt-tom said in Alpha Test js-controller Kiera (v6.0):
zipFiles.js
Dazu gabs weiter oben schon einen Beitrag. Ich glaub ein npm upgrade oder so hat das was gefixed. Ist - wenn ichs richtig im Kopf hab - ein offenes Problem. Schau mal frühere Beoiträge durch.
-
@sigi234
OK, aber auch diese haben einen "ungewöhnlichen" Existstatus beim Beenden. -
@mcm1957 danke für die Info, läuft jetzt soweit bis auf die Sache mit dem Javascript Adapter.
-
@tt-tom said in Alpha Test js-controller Kiera (v6.0):
@mcm1957 danke für die Info, läuft jetzt soweit bis auf die Sache mit dem Javascript Adapter.
@haus-automatisierung
Soweit ich weiß hat sich mit js-controller 6 und / oder (?) Javascript 8.x.x was mit der Installation der zusätzlichen npm Module geändert. Wahrscheinlich kann da haus-automatisierung am besten helfen um festzustellen ob da ein Problem vorliegt oder "nur" eine Anpassung durch dich notwendig ist.Ref zu deinem ersten Fehlerbericht https://forum.iobroker.net/topic/74822/alpha-test-js-controller-kiera-v6-0/106
-
@tt-tom sagte in Alpha Test js-controller Kiera (v6.0):
Bei dem Javascript Adapter 8.3.1 ist mir folgendes aufgefallen, dass die Module nicht mehr einzeln in der Config stehen.
Von welcher Version bist Du denn vorher gekommen? Denke mal das hängt mit dem Wechsel auf jsonConfig zusammen und dass der alte Wert ggf. nicht richtig migriert wird.
-
@haus-automatisierung Das Verhalten sehe ich bei mir auch.
In der Javascript Instanz v8.0.3 auf meinem Produktivsystem werden die npm Module korrekt einzeln dargestellt.
Auf meinem Testsystem ist Javascript auf 8.3.1 und dort sieht es jetzt auch so aus, das alles in einem item steht
-
@feuersturm sagte in Alpha Test js-controller Kiera (v6.0):
In der Javascript Instanz v8.0.3 auf meinem Produktivsystem werden die npm Module korrekt einzeln dargestellt.
Dann zeig mal bitte das Native-Objekt aus dem Instanz-Objekt.
-
@haus-automatisierung Meinst du das hier?