NEWS
[Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.
-
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
-
@michael-mauer
Welche Javascript Version hast Du ?
-
@michael-mauer
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.:
@michael-mauer
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
-
@michael-mauer
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.:
@michael-mauer
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....
-
@michael-mauer
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.:
@michael-mauer
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.....
-
@michael-mauer
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.:
@michael-mauer
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
-
@michael-mauer
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.
-
@pittini @Michael-Mauer
Da kommt wohl nix mehr vom Developer:
-
@Thomas-Braun Das war für mich auch der Grund, die Xiaomi-Luftreiniger von iobroker per Script dann (wieder) in FHEM umzuziehen und darüber zu steuern und auszulesen. FHEM läuft hier bei mir eh für diverse Dinge, die iobroker einfach nicht kann und damit laufen die air purifier einfach problemlos und auch nach einem Neustart, während bei iobroker spätestens dann wieder eine Kopier-Orgie starten musste, um die Geräte, die der node-mihome trotz Pull-request von @Pittini einfach nicht vom Developer beigebracht bekam, wieder manuell in die devices zu kopieren.
Wäre zwar schön, wenn alles in iobroker integriert wäre, aber andererseits ist es ja auch der große Vorteil von iobroker, dass man damit verschiedenste Smart-Home-Systeme unter einen Hut bekommt.Gruss, Jürgen
-
Hi. Ich hänge mich hier auch einmal dran, da ich leider mit dem Script einen Fehler habe, den ich nicht gelöst bekomme.
Ausgangslage:
Ich möchte einen Mi Smart Standing Fan 2 ("dmaker.fan.p18") in mein System einbinden. Dieser funktioniert auch über die App.
Leider habe ich einen Fehler jedes Mal wenn ich das Basis-Script laufen lasse11:19:49.859 error javascript.0 (830) script.js.Web.MiFan_Steuerung: TypeError: Cannot read property 'forEach' of undefined 11:19:49.860 error javascript.0 (830) at CreateDevices (script.js.Web.MiFan_Steuerung:922:17) 11:19:49.860 error javascript.0 (830) at main (script.js.Web.MiFan_Steuerung:840:5)
Die Datenpunkte werden korrekt angelegt (nur ein Device vorhanden), Anmeldung scheint zu funktionieren, nur die Steuereigenschaften haben den Wert "NULL".
Die entsprechende "Node-Mihome" Referenz in den Javascript Einstellungen habe ich auch gemacht
Bisher versuchte Lösungen
(nach jeder versuchten Lösung wurden alle Datenpunkte entfernt, das Script neu eingespielt, alle Referenzen entfernt und das "Node-MiHome" Verezichnis unter "/ioBroker/node_modules" gelöscht und der JavaScript Adapter bzw das System neu gestartet, um einen sauberen Ausgangspunkt zu haben)- "Node-Mihome" Referenz eingefügt - Restart JavaScript Adapter - Script einfügen (mit Verbindungsdaten) - Ausführen Script - Fehler
- "Node-Mihome" Referenz eingefügt - Restart System - Script einfügen (mit Verbindungsdaten) - Ausführen Script - Fehler
- "Node-Mihome" Referenz eingefügt - Restart JavaScript Adapter - Script einfügen (mit Verbindungsdaten) - Adapter Konfiguration für "dmaker.fan.p18" in das Geräte Verzeichnis kopiert - Ausführen Script - Fehler
- "Node-Mihome" Referenz eingefügt - Restart System - Script einfügen (mit Verbindungsdaten) - Adapter Konfiguration für "dmaker.fan.p18" in das Geräte Verzeichnis kopiert - Ausführen Script - Fehler
Beim Script handelt es sich auch jeweils um die letzte Version von Github.
Leider habe ich keine Idee mehr, woran es liegen kann. Da ich hier in der Diskussion gesehen habe, dass es vielleicht relevant sein kann: ds System hat einen normalen Internetzugang, der Login in den Account scheint zu funktionieren. Falls ich weitere Informationen liefern kann, gebt mir kurz Bescheid was benötigt wird. -
@tableautin Schau mal da rein, ähnliches Problem, evtl. hilft die dortige Lösung auch Dir: https://github.com/Pittini/iobroker-nodemihome/issues/59