Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Anstehende Adapter-Aktualisierung abfragen/ Strukturierung

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Anstehende Adapter-Aktualisierung abfragen/ Strukturierung

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

      @AlexAtHome sagte:

      in einem Script mehrere Trigger, da sie inhaltlich zusammenpassen oder gleiche Funktionen nutzen.

      So halte ich es auch.

      @AlexAtHome sagte in Anstehende Adapter-Aktualisierung abfragen/ Strukturierung:

      es liegen Aktualisierungen für meine installierten Adapter vor) per Script abfragen?

      Wie ausführlich soll die Information sein ? Es gibt 2 Datenpunkte: admin.0.info.updatesList (nur Adapter-Namen) und admin.0.info.updatesJson (mit Versionsangabe).

      AlexAtHome 1 Reply Last reply Reply Quote 1
      • AlexAtHome
        AlexAtHome @paul53 last edited by AlexAtHome

        @paul53 Danke für Deine Antworten!
        Bzgl. der Datenpunkte: sehr cool, schau ich gleich mal!

        EDIT:
        Aus den Datenpunkten kann ich auf jedenfall etwas bauen, sehr gut!

        AlexAtHome 1 Reply Last reply Reply Quote 0
        • AlexAtHome
          AlexAtHome @AlexAtHome last edited by

          Nun steht endlich eine Aktualisierung an, so dass ich weiter daran arbeiten kann 🙂

          Ich möchte gerne die anstehenden Aktualisierungen (admin.0.info.updatesJson) im VIS anzeigen. Darin steht zB.:

          {"javascript":{"availableVersion":"4.6.17","installedVersion":"4.5.1"}}
          

          Ich habe dafür das "JSON Table Widget" verwendet. Nun habe ich aber das Problem, dass der Adaptername ohne Attributname angegeben ist. Kann mir jemand weiterhelfen, wie ich das gelöst bekomme? Bin diesbzgl. leider Anfängerin.

          Danke 🙂

          C 1 Reply Last reply Reply Quote 0
          • C
            Coffeelover @AlexAtHome last edited by

            @AlexAtHome Nutze die "Basic Table", lade als DP das JSON. Dann die Anzahl der Spalten soweit erhöhen, dass du alles siehst. Wenn du die Angaben aus der Tabelle bei JSON Header einträgst, kannst du die Reihenfolge und Benennung der Spalten anpassen.

            AlexAtHome 1 Reply Last reply Reply Quote 1
            • AlexAtHome
              AlexAtHome @Coffeelover last edited by AlexAtHome

              @Coffeelover Vielen Dank für Deine Antwort!

              Ich finde kein anderes Tabellen Widget als das "json Table", also vermute ich mal, Du meinst das?
              Dieses habe ich verwendet. Wenn ich nix tue, außer den DP anzugeben unter "Table Object ID", und die Anzahl Spalten erhöhe, wird leider kein Inhalt angezeigt.

              Ich habe mal einen Screenshot erstellt:

              AdapterAktualisierungJSON.jpg

              Bei einem anderen JSON habe ich das Widget bereits erfolgreich eingesetzt, da sind aber auch alle Werte mit Attributnamen versehen....

              C 1 Reply Last reply Reply Quote 0
              • C
                Coffeelover @AlexAtHome last edited by Coffeelover

                @AlexAtHome Genau - und wenn du jetzt das Zeug bei Static JSON rausschmeißt, sollte er IMHO die Spalten aus dem JSON anzeigen... Kann leider gerade keinen Screenshot machen / nicht testen, da ich kein Adapterupdate habe. 🙂

                AlexAtHome 1 Reply Last reply Reply Quote 1
                • AlexAtHome
                  AlexAtHome @Coffeelover last edited by

                  @Coffeelover Leider bleibt es dennoch leer....

                  Ich schätze, das liegt an der Art, wie das JSON aufgebaut ist:

                  {"javascript":{"availableVersion":"4.6.17","installedVersion":"4.5.1"}}
                  

                  Ich komme nicht an den Namen des Adapters ran bzw. weiss nicht, wie ich die Verschachtelung auflösen kann.

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

                    @AlexAtHome sagte:

                    Ich komme nicht an den Namen des Adapters ran

                    let arr = JSON.parse(dp.state.val);
                    for(let i = 0; i < arr.length; i++) {
                       let obj = arr[i];
                       let adapter = Object.keys(obj)[0];
                       // usw.
                    }
                    
                    AlexAtHome 1 Reply Last reply Reply Quote 1
                    • AlexAtHome
                      AlexAtHome @paul53 last edited by

                      @paul53
                      Vielen Dank für Deine Antwort!

                      Leider durchläuft er die Schleife gar nicht, die Länge des Arrays wird mit (garnix) angegeben.

                      Mit Deiner ersten Version (die ich zufällig direkt gesehen hatte 🙂 )

                      let obj = JSON.parse(dp.state.val);
                      let adapter = Object.keys(obj)[0];
                      

                      kann ich den Adapternamen auslesen, komme aber nicht an die Versionsnummern ran - Object.keys(obj)[1] funktioniert jedenfalls nicht, auch der Versuch, Object.keys(obj)[1] ebenfalls zu parsen bringt kein Ergebnis.

                      Sorry, bin leider Anfängerin in JavaScript und auch JSON.... 😐

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

                        @AlexAtHome sagte:

                        die Länge des Arrays wird mit (garnix) angegeben.

                        Habe gesehen, dass es kein Array ist und deshalb getestet. So sollte es funktionieren:

                        on('admin.0.info.updatesJson', function(dp) {
                            let list = JSON.parse(dp.state.val);
                            let adapters = Object.keys(list);
                            for(let i = 0; i < adapters.length; i++) {
                                let adapter = adapters[i];
                                let obj = list[adapter];
                            }
                        });
                        
                        AlexAtHome 1 Reply Last reply Reply Quote 1
                        • AlexAtHome
                          AlexAtHome @paul53 last edited by

                          @paul53
                          Danke Dir!

                          Ich habe nun alles möglich probiert, um die Versionsangaben rauszuextrahieren, aber bekomme es einfach nicht hin 😞 Könntest Du mir da nochmal kurz auf die Sprünge helfen?

                          Mir ist nach wie vor nicht klar, wie die Inhalte zu den jeweiligen Zeitpunkten aussehen 😞 Mit der Ausgabe über die Konsole erhalte ich keine sinnstiftenden Infos, zB. für list kommt dann nur "[object Object]", liegt wahrscheinlich dran, dass das eben nicht einfach so ausgebbar ist.

                          Ich habe immerhin mit der Zeile

                          let versions = Object.keys(obj);
                          

                          folgende Ausgabe erzielt: Versions=availableVersion,installedVersion
                          aber wo finde ich nun die Versionsnummern (jedenfalls nicht mit versions[y]) ? Also irgendwas hab ich da noch nicht verstanden...

                          Ich werde mich wohl mal tiefer mit JS befassen müssen....

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

                            @AlexAtHome

                                    let inst = obj.installedVersion;
                                    let av = obj.availableVersion;
                                    log(adapter + ' installiert: ' + inst + ' neu: ' + av);
                            
                            AlexAtHome 1 Reply Last reply Reply Quote 1
                            • AlexAtHome
                              AlexAtHome @paul53 last edited by

                              @paul53 Sorry, hatte bisher keine Zeit mehr dafür.

                              Vielen lieben Dank, damit funktioniert es!!

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

                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              622
                              Online

                              31.6k
                              Users

                              79.6k
                              Topics

                              1.3m
                              Posts

                              blockly
                              3
                              14
                              873
                              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