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

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    JavaScript 7.9.0 - Neue Objekt- und HTTP-Bausteine

    This topic has been deleted. Only users with topic management privileges can see it.
    • DJMarc75
      DJMarc75 @rtwl last edited by

      @rtwl Wird sich @haus-automatisierung bestimmt ansehen 🙂

      rtwl 1 Reply Last reply Reply Quote 0
      • rtwl
        rtwl @DJMarc75 last edited by rtwl

        @djmarc75
        Ich habs.
        Man muss statt "result" jetzt "response" verwenden.
        Doch nicht 😥

        haus-automatisierung 1 Reply Last reply Reply Quote 0
        • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            549
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

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