Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. JSON Table erstellen

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    7
    1
    71

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

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

JSON Table erstellen

Scheduled Pinned Locked Moved ioBroker Allgemein
json string
45 Posts 8 Posters 12.1k Views 11 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • bergjetB bergjet

    @oliverio
    Habe es auf Label geändert:

    var dps =[
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.00-01",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.01-02",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.02-03",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.03-04",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.04-05",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.05-06",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.07-08",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.08-09",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.09-10",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.10-11",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.11-12",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.12-13",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.13-14",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.14-15",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.15-16",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.16-17",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.17-18",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.18-19",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.19-20",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.21-22",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.22-23",
    "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.23-00"
    ];
     
    on({id: dps, change: 'ne'}, function (dp) {
        var data = [];
        dps.forEach( function(item) {
            var value = getState(item);
            data.push({'label' : item,'value' : value.val})
        });
        setState('0_userdata.0.EnergyMeter.Kosten_pro_Stunde.test', JSON.stringify(data), true);
    });
    
    

    Das json zeigt:

    [
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.00-01",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.01-02",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.02-03",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.03-04",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.04-05",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.05-06",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.07-08",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.08-09",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.09-10",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.10-11",
        "value": 5
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.11-12",
        "value": 7
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.12-13",
        "value": 8
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.13-14",
        "value": 6
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.14-15",
        "value": 6
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.15-16",
        "value": 6
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.16-17",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.17-18",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.18-19",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.19-20",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.21-22",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.22-23",
        "value": 0
      },
      {
        "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.23-00",
        "value": 0
      }
    ]
    
    paul53P Offline
    paul53P Offline
    paul53
    wrote on last edited by paul53
    #32

    @bergjet sagte: Das json zeigt:

    ... und was soll es zeigen?
    Fall als "label" nur "00-01" usw., dann ändere die Schleife:

        dps.forEach(function(id) {
            data.push({label: id.split('.')[4], value: getState(id).val});
        });
    

    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

    bergjetB 1 Reply Last reply
    0
    • paul53P paul53

      @bergjet sagte: Das json zeigt:

      ... und was soll es zeigen?
      Fall als "label" nur "00-01" usw., dann ändere die Schleife:

          dps.forEach(function(id) {
              data.push({label: id.split('.')[4], value: getState(id).val});
          });
      
      bergjetB Offline
      bergjetB Offline
      bergjet
      wrote on last edited by
      #33

      @paul53 sagte in JSON Table erstellen:

      @bergjet sagte: Das json zeigt:

      ... und was soll es zeigen?
      Fall als "label" nur "00-01" usw., dann ändere die Schleife:

          dps.forEach(function(id) {
              data.push({label: id.split('.')[4], value: getState(id).val});
          });
      

      Danke, jetzt wird mir nur noch 00-01 angezeigt.

      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

      1 Reply Last reply
      0
      • paul53P paul53

        @michihorn sagte:

        Spalte 1 der DP und Spalte 2 der Wert stehen.

        Versuche es mal so:

        const idTable = '...'; // ID JSON-Tabelle
        const ids = ['hm-rega.0.39564','hm-rega.0.37206','hm-rega.0.31888','hm-rega.0.37157','javascript.0.ccu.cpuFrequency']; 
         
        var table = [];
        for(let i = 0; i < ids.length; i++) {
            table[i] = {};
            table[i].Name = getObject(ids[i]).common.name;
            table[i].Wert = getState(ids[i]).val;
        }
        setState(idTable, JSON.stringify(table), true);
         
        on(ids, function(dp) {
            let idx = ids.indexOf(dp.id);
            table[idx].Wert = dp.state.val;
            setState(idTable, JSON.stringify(table), true);
        });
        
        bergjetB Offline
        bergjetB Offline
        bergjet
        wrote on last edited by
        #34

        @paul53
        Meine ursprüngliche Anwendung habe ich mit eurer Anleitung hinbekommen.
        Ich braucht nun einen Tipp für folgendes:
        Ich bräuchte folgende Datenpunkte pro Datensatz (5 Datensätze gibt es):
        Platz_1 Ort_1 Preis1 offen_1
        Platz_2 Ort_2 Preis2 offen_2
        Platz_3 Ort_3 Preis3 offen_3

        Bildschirm­foto 2022-11-10 um 14.26.01.png

        homee, ioBroker, iMac, iPhone, Sonos, Alaxa

        paul53P 1 Reply Last reply
        0
        • bergjetB bergjet

          @paul53
          Meine ursprüngliche Anwendung habe ich mit eurer Anleitung hinbekommen.
          Ich braucht nun einen Tipp für folgendes:
          Ich bräuchte folgende Datenpunkte pro Datensatz (5 Datensätze gibt es):
          Platz_1 Ort_1 Preis1 offen_1
          Platz_2 Ort_2 Preis2 offen_2
          Platz_3 Ort_3 Preis3 offen_3

          Bildschirm­foto 2022-11-10 um 14.26.01.png

          paul53P Offline
          paul53P Offline
          paul53
          wrote on last edited by paul53
          #35

          @bergjet sagte: 5 Datensätze gibt es

          Ansatz:

          // IDs anpassen!
          const idTable = '0_userdata.0.Spritpreise.Tabelle';
          const inst = 'adaptername.0.Sprit_AT.Treffer_';
          const ids = [
              inst + '1.Preis_1',
              inst + '2.Preis_2',
              inst + '3.Preis_3',
              inst + '4.Preis_4',
              inst + '5.Preis_5'
          ];
          
          var table = [];
          var timer = null;
          
          function setTable() {
              for(let i = 0; i < ids.length; i++) {
                  table[i] = {};
                  table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
                  table[i].Preis = getState(ids[i]).val;
                  table[i].offen = getState(ids[i].replace('Preis', 'offen')).val ? 'Ja' : 'Nein';
              }
              setState(idTable, JSON.stringify(table), true);
          }
          
          setTable(); // Skriptstart
          
          on(ids, function() {
              clearTimeout(timer);
              timer = setTimeout(setTable, 200);
          });
          

          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

          bergjetB 1 Reply Last reply
          0
          • paul53P paul53

            @bergjet sagte: 5 Datensätze gibt es

            Ansatz:

            // IDs anpassen!
            const idTable = '0_userdata.0.Spritpreise.Tabelle';
            const inst = 'adaptername.0.Sprit_AT.Treffer_';
            const ids = [
                inst + '1.Preis_1',
                inst + '2.Preis_2',
                inst + '3.Preis_3',
                inst + '4.Preis_4',
                inst + '5.Preis_5'
            ];
            
            var table = [];
            var timer = null;
            
            function setTable() {
                for(let i = 0; i < ids.length; i++) {
                    table[i] = {};
                    table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
                    table[i].Preis = getState(ids[i]).val;
                    table[i].offen = getState(ids[i].replace('Preis', 'offen')).val ? 'Ja' : 'Nein';
                }
                setState(idTable, JSON.stringify(table), true);
            }
            
            setTable(); // Skriptstart
            
            on(ids, function() {
                clearTimeout(timer);
                timer = setTimeout(setTable, 200);
            });
            
            bergjetB Offline
            bergjetB Offline
            bergjet
            wrote on last edited by
            #36

            @paul53
            Danke vielmals, funktioniert.
            Noch eine Frage?

            on(ids, function() {
                clearTimeout(timer);
                timer = setTimeout(setTable, 200);
            });
            

            Ist es richtig, diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert? Und was hat der Timer Wert 200 auf sich?

            Mich würde noch interessieren, wie man z.B. den Wert

            table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
            

            kürzen kann?
            Fragen über Fragen.
            Danke schon mal für die Mühe.

            homee, ioBroker, iMac, iPhone, Sonos, Alaxa

            paul53P 1 Reply Last reply
            0
            • bergjetB bergjet

              @paul53
              Danke vielmals, funktioniert.
              Noch eine Frage?

              on(ids, function() {
                  clearTimeout(timer);
                  timer = setTimeout(setTable, 200);
              });
              

              Ist es richtig, diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert? Und was hat der Timer Wert 200 auf sich?

              Mich würde noch interessieren, wie man z.B. den Wert

              table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
              

              kürzen kann?
              Fragen über Fragen.
              Danke schon mal für die Mühe.

              paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by
              #37

              @bergjet sagte: diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert?

              Sie aktualisiert die Tabelle, wenn sich ein Preis ändert.

              @bergjet sagte in JSON Table erstellen:

              was hat der Timer Wert 200 auf sich?

              Der Adapter aktualisiert etliche Datenpunkte direkt hintereinander. Der Timeout sorgt dafür, dass die Tabelle erst aufgebaut wird, wenn der Adapter damit fertig ist.

              @bergjet sagte in JSON Table erstellen:

              kürzen kann?

              Was kürzen?

              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

              bergjetB 1 Reply Last reply
              0
              • paul53P paul53

                @bergjet sagte: diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert?

                Sie aktualisiert die Tabelle, wenn sich ein Preis ändert.

                @bergjet sagte in JSON Table erstellen:

                was hat der Timer Wert 200 auf sich?

                Der Adapter aktualisiert etliche Datenpunkte direkt hintereinander. Der Timeout sorgt dafür, dass die Tabelle erst aufgebaut wird, wenn der Adapter damit fertig ist.

                @bergjet sagte in JSON Table erstellen:

                kürzen kann?

                Was kürzen?

                bergjetB Offline
                bergjetB Offline
                bergjet
                wrote on last edited by
                #38

                @paul53 sagte in JSON Table erstellen:

                Was kürzen?

                Das: table[i].Name = getState(ids[i].replace('Preis', 'Name')).val;
                liefert mir: AVIA XPress (unser Service: Luft und Wasser)

                Es würde genügen wenn AVIA XPress angezeigt wird.

                homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                paul53P 1 Reply Last reply
                0
                • bergjetB bergjet

                  @paul53 sagte in JSON Table erstellen:

                  Was kürzen?

                  Das: table[i].Name = getState(ids[i].replace('Preis', 'Name')).val;
                  liefert mir: AVIA XPress (unser Service: Luft und Wasser)

                  Es würde genügen wenn AVIA XPress angezeigt wird.

                  paul53P Offline
                  paul53P Offline
                  paul53
                  wrote on last edited by paul53
                  #39

                  @bergjet sagte: AVIA XPress (unser Service: Luft und Wasser)

                  Das ist doch bei jedem Tankstellennamen anders. Wo soll gekürzt werden?
                  Wenn nur bei diesem, dann versuche mal

                  table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace('AVIA XPress (unser Service: Luft und Wasser)', 'AVIA XPress');
                  

                  oder

                  table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace(' (unser Service: Luft und Wasser)', '');
                  

                  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

                  bergjetB 1 Reply Last reply
                  0
                  • paul53P paul53

                    @bergjet sagte: AVIA XPress (unser Service: Luft und Wasser)

                    Das ist doch bei jedem Tankstellennamen anders. Wo soll gekürzt werden?
                    Wenn nur bei diesem, dann versuche mal

                    table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace('AVIA XPress (unser Service: Luft und Wasser)', 'AVIA XPress');
                    

                    oder

                    table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace(' (unser Service: Luft und Wasser)', '');
                    
                    bergjetB Offline
                    bergjetB Offline
                    bergjet
                    wrote on last edited by
                    #40

                    @paul53
                    Ich möchte allgemein wissen wie man kürzt.
                    Also z.B. sollen bei table[i].Name = getState(ids[i].replace('Preis', 'Name')).val; nur die ersten 10 Zeichen angezeigt werden.

                    homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                    paul53P 1 Reply Last reply
                    0
                    • bergjetB bergjet

                      @paul53
                      Ich möchte allgemein wissen wie man kürzt.
                      Also z.B. sollen bei table[i].Name = getState(ids[i].replace('Preis', 'Name')).val; nur die ersten 10 Zeichen angezeigt werden.

                      paul53P Offline
                      paul53P Offline
                      paul53
                      wrote on last edited by paul53
                      #41

                      @bergjet sagte: nur die ersten 10 Zeichen

                      table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.substr(0, 10);
                      

                      Siehe Methoden.

                      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

                      1 Reply Last reply
                      1
                      • MIC1981M Offline
                        MIC1981M Offline
                        MIC1981
                        wrote on last edited by
                        #42

                        Vielleicht kann mir jemand helfen. Habe folgendes Skript erstellt/kopiert.

                        var dps = [
                        '0_userdata.0.Strom.BATEntladung'
                        ];
                        on({id: dps, change: 'ne'}, function (dp) {
                            var data = [];
                            dps.forEach( function(item) {
                                var value = getState(item);
                                data.push({'pv' : {'power' : value.val}})
                            });
                            setState('0_userdata.0.Strom.SenecVictron', JSON.stringify(data), true);
                        });
                        

                        Dies funktioniert soweit auch. Nur die Formatierung passt noch nicht zur Weiterverwendung.
                        Der Datenpunkt schaut jetzt so aus:

                        [
                          {
                            "pv": {
                              "power": 372.53
                            }
                          }
                        ]
                        

                        Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

                        mickymM 1 Reply Last reply
                        0
                        • MIC1981M MIC1981

                          Vielleicht kann mir jemand helfen. Habe folgendes Skript erstellt/kopiert.

                          var dps = [
                          '0_userdata.0.Strom.BATEntladung'
                          ];
                          on({id: dps, change: 'ne'}, function (dp) {
                              var data = [];
                              dps.forEach( function(item) {
                                  var value = getState(item);
                                  data.push({'pv' : {'power' : value.val}})
                              });
                              setState('0_userdata.0.Strom.SenecVictron', JSON.stringify(data), true);
                          });
                          

                          Dies funktioniert soweit auch. Nur die Formatierung passt noch nicht zur Weiterverwendung.
                          Der Datenpunkt schaut jetzt so aus:

                          [
                            {
                              "pv": {
                                "power": 372.53
                              }
                            }
                          ]
                          

                          Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

                          mickymM Offline
                          mickymM Offline
                          mickym
                          Most Active
                          wrote on last edited by mickym
                          #43

                          gelöscht

                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                          MIC1981M 1 Reply Last reply
                          0
                          • mickymM mickym

                            gelöscht

                            MIC1981M Offline
                            MIC1981M Offline
                            MIC1981
                            wrote on last edited by
                            #44

                            @mickym Danke für deine schnelle Unterstützung. Ich glaube auch, dass ich gerade mit Kanonen auf Spatzen schieße. Eigentlich möchte ich nur einen einzelnen Datenpunkt als JSON in einen anderen kopieren um diesen per MQTT zu publishen. Dieses kurze Skript hat mich meinem Ziel am weitesten gebracht, was die Formatierung angeht. Es sollen noch weitere Datenpunkte zum JSON hinzukommen, aber erstmal ist dies für mich ausreichend.

                            1 Reply Last reply
                            0
                            • C Offline
                              C Offline
                              Coffeelover
                              wrote on last edited by
                              #45

                              Hallo,
                              ich habe das Script hier aufgegriffen, weil ich damit PV Ertragswerte schreiben möchte. Mein Problem/Ziel: Ich möchte täglich den Max.Wert fortschreiben, also später eine Historie der Werte haben. Mein Wechselrichter gibt diesen Wert auch aus und nullt ihn täglich um Mitternacht. Wie muss ich das Script anpassen, um die Werte fortzuschreiben?

                              Danke.

                              '{"time":{"start":"00:00","end":"23:59","mode":"minutes","interval":1},"period":{"days":1}}'
                              
                              const idTable = '0_userdata.0.PV.PV_Tagesertrag_AC'; // ID JSON-Tabelle
                              const ids = ['opendtu.0.116000006952.ac.phase_1.yieldday']; 
                               
                              var table = [];
                              const tomorrow = Date.now();
                              for(let i = 0; i < ids.length; i++) {
                                  table[i] = {};
                                  table[i].Name = getObject(ids[i]).common.name;
                                  table[i].Date = formatDate(new Date(), 'TT/MM/YYYY')
                                  table[i].Wert = getState(ids[i]).val;
                                  
                              }
                              setState(idTable, JSON.stringify(table), true);
                               
                              on(ids, function(dp) {
                                  let idx = ids.indexOf(dp.id);
                                  table[idx].Wert = dp.state.val;
                                  setState(idTable, JSON.stringify(table), true);
                              });
                              
                              1 Reply Last reply
                              0
                              Reply
                              • Reply as topic
                              Log in to reply
                              • Oldest to Newest
                              • Newest to Oldest
                              • Most Votes


                              Support us

                              ioBroker
                              Community Adapters
                              Donate
                              FAQ Cloud / IOT
                              HowTo: Node.js-Update
                              HowTo: Backup/Restore
                              Downloads
                              BLOG

                              573

                              Online

                              32.5k

                              Users

                              81.7k

                              Topics

                              1.3m

                              Posts
                              Community
                              Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                              ioBroker Community 2014-2025
                              logo
                              • Login

                              • Don't have an account? Register

                              • Login or register to search.
                              • First post
                                Last post
                              0
                              • Home
                              • Recent
                              • Tags
                              • Unread 0
                              • Categories
                              • Unreplied
                              • Popular
                              • GitHub
                              • Docu
                              • Hilfe