Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Vorlage] Xiaomi Airpurifier 3H u.a. inkl. Token auslesen.

    This topic has been deleted. Only users with topic management privileges can see it.
    • ?
      A Former User @Pittini last edited by A Former User

      @pittini

      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.

      ? 1 Reply Last reply Reply Quote 0
      • ?
        A Former User @Guest last edited by

        @hannnes

        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 ?

        P 1 Reply Last reply Reply Quote 0
        • P
          Pittini Developer @Guest last edited by

          @hannnes Solang nicht klar ist was da eigentlich passiert und vorallem warum, werd ich da nix ändern/einbaun.

          Mike77 1 Reply Last reply Reply Quote 1
          • Mike77
            Mike77 @Pittini last edited by Mike77

            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_list

            javascript.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 Devices

            Gruß
            Mike

            Lö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

            haselchen Thomas Braun 2 Replies Last reply Reply Quote 0
            • haselchen
              haselchen Most Active @Mike77 last edited by

              @michael-mauer

              Welche Javascript Version hast Du ?

              Mike77 1 Reply Last reply Reply Quote 0
              • Thomas Braun
                Thomas Braun Most Active @Mike77 last edited by

                @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:

                https://github.com/Pittini/iobroker-nodemihome/issues/61

                Grothesk242 created this issue in Pittini/iobroker-nodemihome

                open Error: network timeout at: https://api.io.mi.com/app/home/device_list #61

                haselchen Mike77 2 Replies Last reply Reply Quote 0
                • haselchen
                  haselchen Most Active @Thomas Braun last edited by

                  @thomas-braun

                  Dann müssen wir eure Gemeinsamkeiten finden.
                  Ich habe das Problem nicht.

                  Skript Version 0.2.23
                  Javascript Version 5.7.0

                  Da 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.

                  Thomas Braun 1 Reply Last reply Reply Quote 0
                  • Thomas Braun
                    Thomas Braun Most Active @haselchen last edited by Thomas Braun

                    @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.

                    1 Reply Last reply Reply Quote 0
                    • Mike77
                      Mike77 @haselchen last edited by Mike77

                      @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.29

                      Edit: Keine Änderung mit Node.js v16.16.0

                      haselchen 1 Reply Last reply Reply Quote 0
                      • haselchen
                        haselchen Most Active @Mike77 last edited by

                        @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?!

                        Mike77 1 Reply Last reply Reply Quote 0
                        • Mike77
                          Mike77 @haselchen last edited by

                          @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....

                          haselchen 1 Reply Last reply Reply Quote 0
                          • haselchen
                            haselchen Most Active @Mike77 last edited by

                            @michael-mauer

                            Und immer genau der gleiche Fehler im Log?

                            Aus der App mal ausgeloggt und dann das Skript gestartet?

                            Mike77 1 Reply Last reply Reply Quote 0
                            • Mike77
                              Mike77 @haselchen last edited by Mike77

                              @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.23

                              das 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.....

                              haselchen 1 Reply Last reply Reply Quote 0
                              • haselchen
                                haselchen Most Active @Mike77 last edited by haselchen

                                @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.0

                                In der App MiHome eingeloggt

                                Mike77 1 Reply Last reply Reply Quote 0
                                • Mike77
                                  Mike77 @haselchen last edited by

                                  @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

                                  haselchen 1 Reply Last reply Reply Quote 0
                                  • haselchen
                                    haselchen Most Active @Mike77 last edited by

                                    @michael-mauer

                                    auch wenn es schon ein Issue gibt, können wir versuchen den Entwickler hier mit ins Boot zu holen

                                    @Pittini

                                    P 1 Reply Last reply Reply Quote 0
                                    • P
                                      Pittini Developer @haselchen last edited by

                                      @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.

                                      Thomas Braun 1 Reply Last reply Reply Quote 0
                                      • Thomas Braun
                                        Thomas Braun Most Active @Pittini last edited by

                                        @pittini @Michael-Mauer

                                        Da kommt wohl nix mehr vom Developer:

                                        https://github.com/maxinminax/node-mihome/issues/44

                                        Gukerl created this issue in maxinminax/node-mihome

                                        open Not working anymore #44

                                        W 1 Reply Last reply Reply Quote 0
                                        • W
                                          Wildbill @Thomas Braun last edited by

                                          @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

                                          1 Reply Last reply Reply Quote 0
                                          • T
                                            Tableautin last edited by

                                            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 lasse

                                            11: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".
                                            6cfbdae1-c09c-4713-baa8-a98e87765835-image.png
                                            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.

                                            P 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            953
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            50
                                            454
                                            65148
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo