NEWS
[Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.
-
Einerseits natürlich mysteriös.
Aber wenns so auch klappt , umso besser.
Aber das warum würde mich trotzdem interessieren. -
@haselchen
mich auchFernbedienung via Home Widget gebastelt.
-
@haselchen sagte in [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.:
Aber das warum würde mich trotzdem interessieren.
Tatsächlich mysterös. Das einzige was ich mir noch vorstellen kann, ist, dass nach Authentifizierung das ganze lokal läuft. Dann sollte aber spätestens nach Neustart des JS Controller Feierabend sein, weil sich das Skript ja nimmer an der Cloud anmelden kann. @Hannnes probier das mal.
-
Ok, Test beendet:
Dein Skript funktioniert nach SkriptAdaptet-Neustart nicht mehr.
Die HomeBridge jedoch schon. Also theoretisch könnte man dem Skript bestimmt beibringen auch ohne Cloud zu leben, ohne das jetzt selbst zu können. Mir zeigt das aber, dass der Ventilator nach wie vor lauscht und das Skript ohne Nachfrage bei der Cloud senden kann.
EDIT:
Ein restart der HomeBridge hat nichts lahmgelegt. Der Fan 2S ist weiterhin über HomeKit steuerbar. -
seit unserem Chat hier habe ich den Ventilator vom Internet getrennt gelassen. Hatte jedoch in der Xiaomi-Cloud das Ding wieder eingehängt (dazu hatte ich den Ventilator natürlich kurz online).
Heute habe ich aus Neugier die Datenpunkte mal ausprobiert, und was soll ich sagen. Jetzt gehen sie plötzlich wieder. Auch wenn ich die Java-Engine neu starte und der Ventilator weiterhin keinen Zugriff aufs Internet hat.Jetzt kommt mir eine Idee: Würde es Sinn machen, eine weitere boolsche Variable im Skript zu implementieren, die die Kontaktaufnahme zur Cloud zulässt/unterbindet? Dann könnte man, einmal alles eingerichtet, die Abfrage und die Erstellung der Datenpunkte abschalten, da ja bereits erledigt. Und nur, wenn man in die Cloud neue Geräte hängen möchte, oder die Xiaomi-App nutzen möchte (was bei mir nicht der Fall ist), man die Verbindung zulässt.
Was sagst Du @Pittini ?
-
@hannnes Solang nicht klar ist was da eigentlich passiert und vorallem warum, werd ich da nix ändern/einbaun.
-
Hi, sorry wenn ich mich an dieses Topic anhänge, aber scheint ja aktiv zu sein
Simple Frage: tut bei euch noch alles ? bei mir ist am 30.06. einfach alles stehen geblieben.
Hätte ich irgend ein Node oder Javascript update nicht machen dürfen ?im Protokoll steht:
javascript.0
2022-07-22 18:11:41.921 error FetchError: network timeout at: https://api.io.mi.com/app/home/device_list at Timeout.<anonymous> (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-fetch/lib/index.js:1484:13) at listOnTimeout (internal/timers.js:557:17) at processTimers (internal/timers.js:500:7)javascript.0
2022-07-22 18:11:41.921 error Error: network timeout at: https://api.io.mi.com/app/home/device_listjavascript.0
2022-07-22 18:11:41.921 error An error happened which is most likely from one of your scripts, but the originating script could not be detected.javascript.0
2022-07-22 18:11:36.881 info script.js.Mi_Home_Note-Home: Retrieving your in cn registered MiHome DevicesGruß
MikeLösung:
Hallo zusammen,
auf Github hat jemand eine Lösung für das Timeout gepostet!George-Cara commented 8 days ago •
Hi . For this error with newer JSCRIPT Adapter (>6) the developer should modify the code. until then please go to /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-mihome/lib and edit the file protocol-micloud.js . You will find
this.REQUEST_TIMEOUT = that you should set to 20000
This is the proper timeout for me. I think it will work for you also.Hat bei mir funktioniert, ich kann den Luftreiniger wieder steuern.
Mike
-
Welche Javascript Version hast Du ?
-
Ja, hab ich auch:
2022-07-22 19:05:42.199 - info: javascript.0 (155217) Start javascript script.js.common.nodemihome 2022-07-22 19:05:42.394 - info: javascript.0 (155217) script.js.common.nodemihome: Starting AllMyMi V.0.2.29 2022-07-22 19:05:42.500 - info: javascript.0 (155217) script.js.common.nodemihome: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 2022-07-22 19:05:43.259 - info: javascript.0 (155217) script.js.common.nodemihome: Retrieving your in cn registered MiHome Devices 2022-07-22 19:05:48.288 - error: javascript.0 (155217) An error happened which is most likely from one of your scripts, but the originating script could not be detected. 2022-07-22 19:05:48.290 - error: javascript.0 (155217) Error: network timeout at: https://api.io.mi.com/app/home/device_list 2022-07-22 19:05:48.291 - error: javascript.0 (155217) FetchError: network timeout at: https://api.io.mi.com/app/home/device_list at Timeout.<anonymous> (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-fetch/lib/index.js:1484:13) at listOnTimeout (node:internal/timers:564:17) at processTimers (node:internal/timers:507:7)
Issue angelegt:
-
Dann müssen wir eure Gemeinsamkeiten finden.
Ich habe das Problem nicht.Skript Version 0.2.23
Javascript Version 5.7.0Da eigentlich nur der Javascript Adapter ein Update bekommen hat, dürfte da vermutlich eure Gemeinsamkeit liegen.
Wenn ihr bei V6 seid, macht doch ein Downgrade und schreibt dann noch mal euer Ergebnis.
-
@haselchen
Ich vermute eher, das liegt an nodejs>14.
Wenn ich mich recht entsinne ist da bei fetch was geändert worden.Edit: Gegentest mit javascript 5.7.0 (stable): Läuft. Es muss sich also bei 6.0 was getan haben.
-
@haselchen said in [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.:
Welche Javascript Version hast Du ?
Ihr seid ja schneller, als ich hier wieder reinschauen konnte
Ich hatte eigentlich nur das Javascipt geupdated...
Mir fällt das leider nicht auf, wenns nicht geht, weil das Script bei mir den Air Purifier hochdreht, sobald ich außer Haus bin....Javascrip 5.7.0
Node.js v14.20.0 , okay sollte ich evtl updaten
script: 0.2.29Edit: Keine Änderung mit Node.js v16.16.0
-
Bis du das Update von Node gemacht hast, hatten wir die gleiche Konfig.
Naja fast, ich habe 0.2.23 vom Skript.
Ob das jetzt den Unterschied macht?! -
@haselchen said in [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.:
Bis du das Update von Node gemacht hast, hatten wir die gleiche Konfig.
Naja fast, ich habe 0.2.23 vom Skript.
Ob das jetzt den Unterschied macht?!Nein, leider nicht, weil ich in der Sekunde 0.2.23 ausprobiert habe....
-
Und immer genau der gleiche Fehler im Log?
Aus der App mal ausgeloggt und dann das Skript gestartet?
-
@haselchen said in [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.:
Und immer genau der gleiche Fehler im Log?
Aus der App mal ausgeloggt und dann das Skript gestartet?
javascript.0
2022-07-23 00:32:36.955 error FetchError: network timeout at: https://de.api.io.mi.com/app/home/device_list at Timeout.<anonymous> (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-fetch/lib/index.js:1484:13) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
javascript.0
2022-07-23 00:32:36.955 error Error: network timeout at: https://de.api.io.mi.com/app/home/device_list
javascript.0
2022-07-23 00:32:36.955 error An error happened which is most likely from one of your scripts, but the originating script could not be detected.
javascript.0
2022-07-23 00:32:31.948 info script.js.Mi_Home_Note-Home_TEST: Retrieving your in de registered MiHome Devices
javascript.0
2022-07-23 00:32:31.947 info script.js.Mi_Home_Note-Home_TEST: You are already logged in, login canceled
javascript.0
2022-07-23 00:32:31.947 info script.js.Mi_Home_Note-Home_TEST: registered 0 subscriptions and 0 schedules
javascript.0
2022-07-23 00:32:31.944 info script.js.Mi_Home_Note-Home_TEST: Reaching init
javascript.0
2022-07-23 00:32:31.943 info script.js.Mi_Home_Note-Home_TEST: Starting AllMyMi V.0.2.23das kann ich probieren.... aber bis es heute nicht ging, hatte ich die app nicht mal mehr auf dem smartphone...
EDIT: Ausloggen hat nichts gebracht. Pi auch nochmals neu gestartet.....
-
Konstellationsmöglichkeiten gibt es natürlich wahnsinnig viele.
Ich kann nur von dem ausgehen, was bei mir funktioniert.
Node 14.20.
Skript 0.2.23
Javascript 5.7.0In der App MiHome eingeloggt
-
@haselchen said in [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.:
Konstellationsmöglichkeiten gibt es natürlich wahnsinnig viele.
Danke für deine Mühe.... auch wenns leider nichts gebracht hat....
Mal schauen, ob noch jemand drauf kommt.für heute: Gute Nacht
-
auch wenn es schon ein Issue gibt, können wir versuchen den Entwickler hier mit ins Boot zu holen
-
@haselchen Da mein Skript nix aufregendes nutzt, und aufgrund der fetch Fehlermeldung, geh ich davon aus, wenn tatsächlich ein allgemeines Problem vorliegt, liegts an der node-mihome. Um daran was zu ändern/fixen bin ich zu doof und der Dev. reagiert auf nix. Soll heissen....is wies is.