Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine

    This topic has been deleted. Only users with topic management privileges can see it.
    • haus-automatisierung
      haus-automatisierung Developer Most Active @rtwl last edited by

      @rtwl sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

      Man muss statt "result" jetzt "response" verwenden.

      Mh, stimmt, in Blockly nicht so intuitiv. Man müsste response verwenden, aber davon das Attribut data. Werde mal eine Zeile einfügen, dass man auch direkt result nutzen kann (wie vorher).

      Codierknecht 1 Reply Last reply Reply Quote 1
      • Codierknecht
        Codierknecht Developer Most Active @haus-automatisierung last edited by

        @haus-automatisierung
        Kannst Du dann auch vielleicht gleich die Variable anlegen?
        Für unbedarfte ist es auch nicht unbedingt intuitiv, die nötige Variable noch "von Hand" anlegen zu müssen.
        Die stolpern da immer wieder drüber.

        haus-automatisierung paul53 2 Replies Last reply Reply Quote 1
        • haus-automatisierung
          haus-automatisierung Developer Most Active @Codierknecht last edited by

          @codierknecht sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

          Kannst Du dann auch vielleicht gleich die Variable anlegen?

          Ja - steht noch auf ToDo dass ich mir anschaue wie das in Blockly funktioniert.

          Diginix 1 Reply Last reply Reply Quote 0
          • Diginix
            Diginix @haus-automatisierung last edited by

            @haus-automatisierung Gut dass ich noch auf 7.8 bin. Habe sehr viele request Blöcke bei denen die Weiterverarbeitung über result läuft. Wäre echt gut, wenn sowohl der Variablenname als auch der Inhalt bei den neuen Blöcken identisch bliebe. response.data schaue ich mir gerne mal an, aber damit alle produktiven Skripte weiter funktionieren, wäre diese Anpassung in 7.9.2 echt super.

            haus-automatisierung paul53 2 Replies Last reply Reply Quote 1
            • haus-automatisierung
              haus-automatisierung Developer Most Active @Diginix last edited by

              @diginix sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

              Gut dass ich noch auf 7.8 bin.

              Total egal, den Request-Block gibts in den neueren Versionen ja auch noch. Funktioniert weiterhin.

              Diginix 1 Reply Last reply Reply Quote 0
              • paul53
                paul53 @Diginix last edited by paul53

                @diginix sagt: viele request Blöcke bei denen die Weiterverarbeitung über result läuft.

                Das ist auch bei Version 7.9.0 so.
                Die Erweiterung um result soll bei den neuen HTTP-Blöcken erfolgen.

                1 Reply Last reply Reply Quote 0
                • Diginix
                  Diginix @haus-automatisierung last edited by Diginix

                  @haus-automatisierung Ja, aber ich will ja alle request Blöcke auf die neuen umstellen ohne den Teil der Weiterverarbeitung von result auf response.data umstellen zu müssen. Außer du sagst es bleibt so.
                  Aber du hast ja schon angedeutet, dass result parallel in den neuen Blöcken kommt.
                  Ich kann auch alles auf request lassen, aber dachte die liefern schon eine obsolete Logmeldung?

                  1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 @Codierknecht last edited by paul53

                    @codierknecht sagte: gleich die Variable anlegen?

                    @haus-automatisierung
                    Möglichst so, dass sie optisch als lokale Variablen erkennbar sind - so wie die Trigger-Variablen - und nicht unter den globalen Variablen auftauchen. Und bitte nicht übersetzen.

                    1 Reply Last reply Reply Quote 1
                    • G
                      Gtal last edited by

                      @haus-automatisierung VielenDank für Dein Engagement und die Weiterentwicklung!

                      Ich stand ehrlich gesagt (Laie) am Anfang auf dem Schlauch - die nachfolgenden Erklärungen haben mir nun geholfen!

                      Folgendes Blockly müsste dan das Gleiche auswerfen, wie "request / result"

                      0ddcbc5f-572e-4e78-98c4-635f5ae67b43-grafik.png

                      haus-automatisierung 1 Reply Last reply Reply Quote -1
                      • haus-automatisierung
                        haus-automatisierung Developer Most Active @Gtal last edited by

                        @gtal sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

                        Folgendes Blockly müsste dan das Gleiche auswerfen, wie "request / result"

                        Richtig, wird mit der nächsten Version dann aber so nicht mehr nötig sein.

                        PS: Wenn Du noch ganz am Anfang stehst, würde ich auf den stable-Versionen bleiben.

                        haus-automatisierung 1 Reply Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @haus-automatisierung last edited by haus-automatisierung

                          Hab es jetzt so wie von @paul53 empfohlen umgesetzt (ohne "richtige" Variable) unter Variablen - wie bei Triggern:

                          Screenshot 2024-03-18 at 12.17.28.png

                          Über den neuen Baustein kann man dann ggf. auch HTTP-Header (z.B. Cookies), Response-Code, usw. auswerten.

                          Screenshot 2024-03-18 at 12.26.34.png

                          Diginix 1 Reply Last reply Reply Quote 9
                          • Diginix
                            Diginix @haus-automatisierung last edited by Diginix

                            @haus-automatisierung Wie kann ich denn nun Basic Auth mit http://user:pw@ip im http GET verwenden?
                            Bekomme nur ein unauthorized. Dummerweise liefert seit dem Speichern des Skriptes der alte Block nun bei jedem Run eine deprecated Logzeile. Manche http GET laufen bei mir mehrfach minütlich was das Log nun unschön voll spamt. Muss ich wohl das Loglevel bis zur Lösung auf error setzen. Dann sehe ich aber eigene info und warn Logmeldungen aus anderen Skripten nicht mehr.

                            Achja, für digest hätte ich auch Interesse. Das habe ich bisher mit curl exec genutzt, da es der alte request Block nicht konnte.

                            1 Reply Last reply Reply Quote 0
                            • J
                              jwerlsdf last edited by jwerlsdf

                              Ausgehend von diesem Thread

                              https://forum.iobroker.net/topic/73554/umstellung-request-auf-http-get
                              

                              möchte ich hier noch einmal nachfragen, wie ich genau den http get block benutzen muss, damit ich keinen

                              timeout of 2000ms exceeded
                              

                              Fehler erhalte.
                              Bild1.png

                              Bild2.png

                              Könnte mir bitte jemand helfen?

                              haus-automatisierung 1 Reply Last reply Reply Quote 0
                              • haus-automatisierung
                                haus-automatisierung Developer Most Active @jwerlsdf last edited by

                                @jwerlsdf sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

                                wie ich genau den http get block benutzen muss, damit ich keinen timeout Fehler erhalte.

                                Aktuell ist der Timeout fix auf 2000ms gestellt. Warum dauert es denn so lange bis zum Response? Das ist ja eine halbe Ewigkeit. In der nächsten Version mach ich den Timeout konfigurierbar.

                                @diginix sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

                                Wie kann ich denn nun Basic Auth mit http://user:pw@ip im http GET verwenden?

                                Wie im Ausgangspost beschrieben, kann der Blockly-Baustein das aktuell nicht. Nur per JavaScript. Siehe Doku

                                https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#httpget

                                Ich muss mal schauen wie ich das alles anbieten kann, ohne den Baustein komplett zu überfrachten.

                                Diginix J Ralla66 4 Replies Last reply Reply Quote 0
                                • Diginix
                                  Diginix @haus-automatisierung last edited by

                                  @haus-automatisierung Vllt wäre es gut vorerst die nervigen Logmeldung beim alten Block wegzulassen.
                                  Der Block selbst trägt "deprecated" im Namen. Das sollte ja reichen. Aber solange der neue den alten nicht vollständig ersetzen kann, brauche ihn ja. Wenn ich nun aber auf 7.8.0 zurück gehe, muss ich vorher die Skripte, in denen ich schon http GET nutze, wieder auf request umstellen.

                                  haus-automatisierung David G. 2 Replies Last reply Reply Quote 0
                                  • haus-automatisierung
                                    haus-automatisierung Developer Most Active @Diginix last edited by

                                    @diginix sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

                                    Aber solange der neue den alten nicht vollständig ersetzen kann, brauche ihn ja.

                                    Was kann der alte Request-Block denn, was der neue nicht kann?

                                    Diginix 1 Reply Last reply Reply Quote 0
                                    • Diginix
                                      Diginix @haus-automatisierung last edited by Diginix

                                      @haus-automatisierung Basic Auth 😄
                                      Beim request Block funktionieren URLs mit user:pw@ip. Beim neuen funktioniert das nicht.
                                      K.a. was du meinst, dass das mit JS gemacht werden muss. Demnach ist es aber komplizierter mit dem neuen Block.

                                      haus-automatisierung 1 Reply Last reply Reply Quote 0
                                      • haus-automatisierung
                                        haus-automatisierung Developer Most Active @Diginix last edited by haus-automatisierung

                                        @diginix sagte in JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine:

                                        Beim request Block funktionieren URLs mit user:pw@ip.

                                        Ah, stimmt die request lib kann das sogar. Hab ich so noch nie verwendet. https://www.npmjs.com/package/request#http-authentication

                                        Das Problem ist, dass das request-Paket seit Jahren deprecated ist (letztes Update vor 4 Jahren!) und eigentlich endlich mal einen sauberen cut haben möchte. Die Leute beschweren sich ja auch ständig über die deprecated-Warnings bei der Adapter-Installation.

                                        Sonst bleib erstmal auf der stable-Version bis basicAuth im Blockly verfügbar ist.

                                        As of Feb 11th 2020, request is fully deprecated. No new changes are expected land. In fact, none have landed for some time.

                                        Diginix 1 Reply Last reply Reply Quote 0
                                        • Diginix
                                          Diginix @haus-automatisierung last edited by Diginix

                                          @haus-automatisierung Habe bei mir einfach mal *** auskommentiert. 😉

                                          haus-automatisierung 1 Reply Last reply Reply Quote 0
                                          • haus-automatisierung
                                            haus-automatisierung Developer Most Active @Diginix last edited by

                                            @diginix Bitte schreib solche "Tipps" nicht öffentlich ins Forum. Das machen Leute nachher noch nach 😉

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            652
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            24
                                            148
                                            15584
                                            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