Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. Anstehende Adapter-Aktualisierung abfragen/ Strukturierung

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    10
    1
    118

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.3k

Anstehende Adapter-Aktualisierung abfragen/ Strukturierung

Geplant Angeheftet Gesperrt Verschoben Blockly
blockly
14 Beiträge 3 Kommentatoren 1.4k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • AlexAtHomeA 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!

    AlexAtHomeA Offline
    AlexAtHomeA Offline
    AlexAtHome
    schrieb am zuletzt editiert von
    #4

    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 Antwort Letzte Antwort
    0
    • AlexAtHomeA AlexAtHome

      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 Offline
      C Offline
      Coffeelover
      schrieb am zuletzt editiert von
      #5

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

      AlexAtHomeA 1 Antwort Letzte Antwort
      1
      • C Coffeelover

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

        AlexAtHomeA Offline
        AlexAtHomeA Offline
        AlexAtHome
        schrieb am zuletzt editiert von AlexAtHome
        #6

        @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 Antwort Letzte Antwort
        0
        • AlexAtHomeA 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 Offline
          C Offline
          Coffeelover
          schrieb am zuletzt editiert von Coffeelover
          #7

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

          AlexAtHomeA 1 Antwort Letzte Antwort
          1
          • C 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. :)

            AlexAtHomeA Offline
            AlexAtHomeA Offline
            AlexAtHome
            schrieb am zuletzt editiert von
            #8

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

            paul53P 1 Antwort Letzte Antwort
            0
            • AlexAtHomeA AlexAtHome

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

              paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von paul53
              #9

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

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              AlexAtHomeA 1 Antwort Letzte Antwort
              1
              • paul53P 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.
                }
                
                AlexAtHomeA Offline
                AlexAtHomeA Offline
                AlexAtHome
                schrieb am zuletzt editiert von
                #10

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

                paul53P 1 Antwort Letzte Antwort
                0
                • AlexAtHomeA AlexAtHome

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

                  paul53P Offline
                  paul53P Offline
                  paul53
                  schrieb am zuletzt editiert von paul53
                  #11

                  @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];
                      }
                  });
                  

                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                  AlexAtHomeA 1 Antwort Letzte Antwort
                  1
                  • paul53P 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];
                        }
                    });
                    
                    AlexAtHomeA Offline
                    AlexAtHomeA Offline
                    AlexAtHome
                    schrieb am zuletzt editiert von
                    #12

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

                    paul53P 1 Antwort Letzte Antwort
                    0
                    • AlexAtHomeA AlexAtHome

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

                      paul53P Offline
                      paul53P Offline
                      paul53
                      schrieb am zuletzt editiert von
                      #13

                      @AlexAtHome

                              let inst = obj.installedVersion;
                              let av = obj.availableVersion;
                              log(adapter + ' installiert: ' + inst + ' neu: ' + av);
                      

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      AlexAtHomeA 1 Antwort Letzte Antwort
                      1
                      • paul53P paul53

                        @AlexAtHome

                                let inst = obj.installedVersion;
                                let av = obj.availableVersion;
                                log(adapter + ' installiert: ' + inst + ' neu: ' + av);
                        
                        AlexAtHomeA Offline
                        AlexAtHomeA Offline
                        AlexAtHome
                        schrieb am zuletzt editiert von
                        #14

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

                        Vielen lieben Dank, damit funktioniert es!!

                        1 Antwort Letzte Antwort
                        0
                        Antworten
                        • In einem neuen Thema antworten
                        Anmelden zum Antworten
                        • Älteste zuerst
                        • Neuste zuerst
                        • Meiste Stimmen


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        630

                        Online

                        32.5k

                        Benutzer

                        81.7k

                        Themen

                        1.3m

                        Beiträge
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                        ioBroker Community 2014-2025
                        logo
                        • Anmelden

                        • Du hast noch kein Konto? Registrieren

                        • Anmelden oder registrieren, um zu suchen
                        • Erster Beitrag
                          Letzter Beitrag
                        0
                        • Home
                        • Aktuell
                        • Tags
                        • Ungelesen 0
                        • Kategorien
                        • Unreplied
                        • Beliebt
                        • GitHub
                        • Docu
                        • Hilfe