Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Stiebel-ISG - Modbus

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Stiebel-ISG - Modbus

    This topic has been deleted. Only users with topic management privileges can see it.
    • N
      NetFritz @Android51 last edited by

      @android51
      Danke
      Das sieht bei mir genau so aus.
      Gruß NetFritz

      N 1 Reply Last reply Reply Quote 0
      • N
        NetFritz @NetFritz last edited by NetFritz

        @netfritz
        Hallo
        Da ich mit dem Modbus Adapter die Holdingregister z.Z. nicht beschreiben kann,
        vor allem SG Ready 1 und 2.
        Habe ich es Heute mit ioBroker Node Red versucht.
        Nach ein paar fehl Versuchen habe ich es hinbekommen SG Ready 1 und 2 anzusteuern.
        Habe den node-red-contrib-modbus und node-red-contrib-modbus-flex-server installiert.
        Dann den Flex.Server Knoten und Modbus-Red und Modbus-Write in das Flow gezogen
        und Konfiguriert.
        NR_Modb_Servever.png

        Hier noch der Flow zum Importieren.
        Gruß NetFritz

        [
            {
                "id": "e30b3d7c8e9c13ae",
                "type": "tab",
                "label": "Modbus",
                "disabled": false,
                "info": "",
                "env": []
            },
            {
                "id": "1c58a83f7b099c2c",
                "type": "modbus-flex-server",
                "z": "e30b3d7c8e9c13ae",
                "name": "",
                "logEnabled": false,
                "serverAddress": "localhost",
                "serverPort": "502",
                "responseDelay": 100,
                "unitId": 1,
                "delayUnit": "ms",
                "coilsBufferSize": 20000,
                "registersBufferSize": 20000,
                "minAddress": 0,
                "splitAddress": 10000,
                "funcGetCoil": "function getFlexCoil(addr, unitID) {\n\tif (unitID === node.unitId && \n\t\taddr >= node.minAddress && \n\t\taddr <= node.splitAddress) { \n\n\t\treturn node.coils.readUInt8(addr * node.bufferFactor) \n\t}  \n}",
                "funcGetDiscreteInput": "function getFlexDiscreteInput(addr, unitID) {\n\taddr += node.splitAddress\n\tif (unitID === node.unitId && \n\t\taddr >= node.splitAddress && \n\t\taddr <= node.splitAddress * 2) { \n\n\t\treturn node.coils.readUInt8(addr * node.bufferFactor) \n\t}  \n}",
                "funcGetInputRegister": "function getFlexInputRegister(addr, unitID) { \n\tif (unitID === node.unitId && \n\t\taddr >= node.minAddress && \n\t\taddr <= node.splitAddress) { \n\n\t\treturn node.registers.readUInt16BE(addr * node.bufferFactor)  \n\t} \n}",
                "funcGetHoldingRegister": "function getFlexHoldingRegsiter(addr, unitID) { \n\taddr += node.splitAddress\n\tif (unitID === node.unitId && \n\t\taddr >= node.splitAddress && \n\t\taddr <= node.splitAddress * 2) { \n\n\t\treturn node.registers.readUInt16BE(addr * node.bufferFactor)  \n\t} \n}",
                "funcSetCoil": "function setFlexCoil(addr, value, unitID) { \n\tif (unitID === node.unitId && \n\t\taddr >= node.minAddress && \n\t\taddr <= node.splitAddress) { \n\n\t\tnode.coils.writeUInt8(value, addr * node.bufferFactor)  \n\t} \n}",
                "funcSetRegister": "function setFlexRegister(addr, value, unitID) { \n\taddr += node.splitAddress\n\tif (unitID === node.unitId && \n\t\taddr >= node.splitAddress && \n\t\taddr <= node.splitAddress * 2) { \n\n\t\tnode.registers.writeUInt16BE(value, addr * node.bufferFactor)  \n\t} \n}",
                "showErrors": false,
                "x": 280,
                "y": 60,
                "wires": [
                    [
                        "d47aa0d1fa728da8"
                    ],
                    [
                        "d47aa0d1fa728da8"
                    ],
                    [
                        "d47aa0d1fa728da8"
                    ],
                    [
                        "d47aa0d1fa728da8"
                    ],
                    [
                        "d47aa0d1fa728da8"
                    ]
                ]
            },
            {
                "id": "d47aa0d1fa728da8",
                "type": "debug",
                "z": "e30b3d7c8e9c13ae",
                "name": "debug 231",
                "active": false,
                "tosidebar": true,
                "console": false,
                "tostatus": false,
                "complete": "false",
                "statusVal": "",
                "statusType": "auto",
                "x": 510,
                "y": 60,
                "wires": []
            },
            {
                "id": "e5d4b02e39142509",
                "type": "inject",
                "z": "e30b3d7c8e9c13ae",
                "name": "",
                "props": [
                    {
                        "p": "payload"
                    },
                    {
                        "p": "topic",
                        "vt": "str"
                    }
                ],
                "repeat": "",
                "crontab": "",
                "once": false,
                "onceDelay": 0.1,
                "topic": "",
                "payload": "",
                "payloadType": "str",
                "x": 90,
                "y": 60,
                "wires": [
                    [
                        "1c58a83f7b099c2c"
                    ]
                ]
            },
            {
                "id": "802c615c03960bb5",
                "type": "modbus-read",
                "z": "e30b3d7c8e9c13ae",
                "name": "Read",
                "topic": "",
                "showStatusActivities": false,
                "logIOActivities": false,
                "showErrors": false,
                "showWarnings": true,
                "unitid": "1",
                "dataType": "HoldingRegister",
                "adr": "1500",
                "quantity": "20",
                "rate": "5",
                "rateUnit": "s",
                "delayOnStart": false,
                "startDelayTime": "",
                "server": "0b269ba065891482",
                "useIOFile": false,
                "ioFile": "",
                "useIOForPayload": false,
                "emptyMsgOnFail": false,
                "x": 270,
                "y": 140,
                "wires": [
                    [
                        "850acb94b17b4b94"
                    ],
                    [
                        "850acb94b17b4b94"
                    ]
                ]
            },
            {
                "id": "850acb94b17b4b94",
                "type": "debug",
                "z": "e30b3d7c8e9c13ae",
                "name": "debug 232",
                "active": true,
                "tosidebar": true,
                "console": false,
                "tostatus": false,
                "complete": "false",
                "statusVal": "",
                "statusType": "auto",
                "x": 510,
                "y": 140,
                "wires": []
            },
            {
                "id": "cf41e8a95857a041",
                "type": "modbus-write",
                "z": "e30b3d7c8e9c13ae",
                "name": "Write",
                "showStatusActivities": false,
                "showErrors": false,
                "showWarnings": true,
                "unitid": "1",
                "dataType": "MHoldingRegisters",
                "adr": "4001",
                "quantity": "2",
                "server": "0b269ba065891482",
                "emptyMsgOnFail": false,
                "keepMsgProperties": false,
                "delayOnStart": false,
                "startDelayTime": "",
                "x": 250,
                "y": 200,
                "wires": [
                    [
                        "36fc03fafb4bfac3"
                    ],
                    [
                        "36fc03fafb4bfac3"
                    ]
                ]
            },
            {
                "id": "36fc03fafb4bfac3",
                "type": "debug",
                "z": "e30b3d7c8e9c13ae",
                "name": "debug 233",
                "active": true,
                "tosidebar": true,
                "console": false,
                "tostatus": false,
                "complete": "false",
                "statusVal": "",
                "statusType": "auto",
                "x": 510,
                "y": 200,
                "wires": []
            },
            {
                "id": "6188c6b9a087442e",
                "type": "inject",
                "z": "e30b3d7c8e9c13ae",
                "name": "SG 2",
                "props": [
                    {
                        "p": "payload"
                    },
                    {
                        "p": "topic",
                        "vt": "str"
                    }
                ],
                "repeat": "",
                "crontab": "",
                "once": false,
                "onceDelay": 0.1,
                "topic": "",
                "payload": "[0,0]",
                "payloadType": "json",
                "x": 90,
                "y": 180,
                "wires": [
                    [
                        "cf41e8a95857a041"
                    ]
                ]
            },
            {
                "id": "361c3ea15c934a33",
                "type": "inject",
                "z": "e30b3d7c8e9c13ae",
                "name": "SG 3",
                "props": [
                    {
                        "p": "payload"
                    },
                    {
                        "p": "topic",
                        "vt": "str"
                    }
                ],
                "repeat": "",
                "crontab": "",
                "once": false,
                "onceDelay": 0.1,
                "topic": "",
                "payload": "[1,0]",
                "payloadType": "json",
                "x": 90,
                "y": 220,
                "wires": [
                    [
                        "cf41e8a95857a041"
                    ]
                ]
            },
            {
                "id": "0b269ba065891482",
                "type": "modbus-client",
                "name": "",
                "clienttype": "tcp",
                "bufferCommands": true,
                "stateLogEnabled": false,
                "queueLogEnabled": false,
                "failureLogEnabled": true,
                "tcpHost": "192.168.2.103",
                "tcpPort": "502",
                "tcpType": "DEFAULT",
                "serialPort": "/dev/ttyUSB",
                "serialType": "RTU-BUFFERD",
                "serialBaudrate": "9600",
                "serialDatabits": "8",
                "serialStopbits": "1",
                "serialParity": "none",
                "serialConnectionDelay": "100",
                "serialAsciiResponseStartDelimiter": "0x3A",
                "unit_id": "1",
                "commandDelay": "1",
                "clientTimeout": "1000",
                "reconnectOnTimeout": true,
                "reconnectTimeout": "2000",
                "parallelUnitIdsAllowed": true,
                "showErrors": false,
                "showWarnings": true,
                "showLogs": true
            }
        ]
        
        1 Reply Last reply Reply Quote 0
        • A
          Android51 last edited by Android51

          welche Holding-Adresse (SGready) versuchst du denn zu schalten? bzw. zu schreiben?
          Ich mache das über 44002 und dann über meine VIS... das funktioniert gut.
          937b36d2-7c12-4295-b68b-88d0771d2e4a-image.png

          N 1 Reply Last reply Reply Quote 0
          • N
            NetFritz @Android51 last edited by

            @android51
            Hallo
            Beim mir will der IOB Modbusadpter keine Holding Register beschreiben.
            Beim User QLink geht es auch nicht.

            In Node Red Modbus wir die Adresse -1 angegeben.
            Also wenn Du Die Adresse 4002 = SG Ready 1 schalten willst muss Du die 4001 eingeben.

            Beim ioBroker Modbus Adapter wird noch eine 4 vorrangestellt.
            Um es genau zu sagen die Adresse setzt sich zusammen 40000 + 4002 = 44002.
            Ich habe die 4001 angegeben.

            Bei Quantity habe ich eine 2 Eingegeben, es werden 2 Adressen beschrieben die 4002 und die 4003.
            Einmal mit der 1 SG Ready1 und die 0 SG Ready2.
            Und zurück beidemal 0 0.
            Gruß NetFritz

            A 1 Reply Last reply Reply Quote 0
            • A
              Android51 @NetFritz last edited by

              @netfritz
              Wenn ich mich recht erinnere, konnte ich die 4001 damals auch nicht schalten, die 4002 hingegen schon.

              N 1 Reply Last reply Reply Quote 0
              • N
                NetFritz @Android51 last edited by

                @android51
                Hallo
                Bei den Modbus Adressen für SG Ready 4001 - 4003 steht r/w in der Beschreibung.
                Das muss eigentlich gehen.
                Gruß NetFritz

                1 Reply Last reply Reply Quote 0
                • unltdnetworx
                  unltdnetworx Developer last edited by

                  Da schon öfter mal die Frage aufkam, ob per Modbus auch die Aufnahmeleistung des Wärmetauschers ausgelesen werden kann.

                  In meiner Anleitung hat der Nutzer David in den Kommentaren gelistet, dass er die Werte dafür herausgefunden hat.

                  Vielen Dank dafür.

                  1 Reply Last reply Reply Quote 0
                  • A
                    Android51 last edited by

                    Danke für die Info. Ich habe die Modbus 33680 mal eingebunden und werde beobachten, wie sie sich heute über Tag verhält.
                    Ich finde allerdings ein wenig merkwürdig, dass die Adresse verfügbar ist, aber offiziell vom Stiebel Support (hatte Mailkontakt) noch nicht bekannt gegeben wird.
                    Zudem habe ich irgendwo gelesen, dass der Wert ziemlich "geschönt" ist und nicht der tatsächlichen Stromaufnahme entspricht.

                    T Funkymaddox 2 Replies Last reply Reply Quote 1
                    • T
                      tippy88 @Android51 last edited by

                      @android51 said in Stiebel-ISG - Modbus:

                      Zudem habe ich irgendwo gelesen, dass der Wert ziemlich "geschönt" ist und nicht der tatsächlichen Stromaufnahme entspricht.

                      Das Problem ist auch die Rundung, der Wert wird nur mit einer Stelle nach dem Komma angegeben. 0,999 wird halt 0,9 im Modbus
                      Ich habe bei mir ein Offset von +100W angelegt. Das kommt ganz gut hin wenn ich Nachts den Ruheverbrauch + Heizung zusammenrechne passt das.

                      1 Reply Last reply Reply Quote 0
                      • Funkymaddox
                        Funkymaddox @Android51 last edited by

                        @android51
                        Kam bei dem Registerauslesetest was heraus?
                        Wir haben eine WPL15AS und einen WPM3 + ISG Web.
                        Für die SG-Ready Steuerung nutzen wir EVCC, was prima funktioniert, bis auf den fehlenden Wert der Stromaufnahme des Inverters bei uns. Betriebszustand 2 zu 3 und umgekehrt klappt, aber es wird immer 0kW Leistung angezeigt. (EVCC hat im Modbus template Register 680 stehen, welches scheinbar bei manchen Nutzern die aktuellen Verbrauch ausgibt (WPM G?))

                        Wir haben WPM3 Software 6 (ISG 12/2/3/260) und komischerweise weder Prozessdaten in der Servicewelt, noch wirft das Register einen Wert aus.
                        Weißt du, ob man die Prozessdaten irgendwie in die Servicewelt bekommt, und auch wenn nicht, ob man die Inverterleitung doch irgendwie bekommen kann?

                        A 1 Reply Last reply Reply Quote 0
                        • A
                          Android51 @Funkymaddox last edited by Android51

                          @funkymaddox
                          bei mir lässt sich die Aufnahmeleistung ohne Probleme per Modbus auslesen. Ich traue nur den Wert nicht zu 100 %. Habe inzwischen einen shelly pro 3em, mit dem ich die Stromaufnahme der Wärmepumpe tracke. Der misst die einzelnen Phasen der Wärmepumpe. Der Wert ist grundsätzlich höher. Je höher die Aufnahmeleistung der Wärmepumpe, desto größer die Abweichung.
                          Was kannst du denn mit EVCC steuern? Ich dachte, dass wäre nur für Wallboxen. Kannste mal ein Screenshot von der Oberfläche posten und ein wenig beschreiben, wie du das nutzt?

                          Homoran 1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators @Android51 last edited by

                            @android51 sagte in Stiebel-ISG - Modbus:

                            Je höher die Aufnahmeleistung der Wärmepumpe, desto größer die Abweichung.

                            kann es sein, dass am Gerät nur die "wirklich" für die Wärmeerzeugung genutzte Energie/Leistung angezeigt wird.
                            Nicht der Verbrauch von irgendwelchen Zusatzaggregaten?

                            Hab so einen Effekt beim e-Auto.
                            Da zeigt das Auto anscheinend nur den reinen Verbrauch des Antriebs an, kein Licht, Heizung, Klima usw.

                            Funkymaddox 1 Reply Last reply Reply Quote 0
                            • Funkymaddox
                              Funkymaddox @Homoran last edited by

                              @homoran
                              Ja, habe anderswo gelesen, dass dies genau so ist. Der Lüfter/Rotor und co zählen nicht zu der Inverteraufnahme in kW. Hatte auch gelesen, dass jemand anhand der Hz des Lüfters und co errechnen konnte, wie groß die Abweichung ist. Darauf könnte man eine Formel erstellen. Aber selbst ohne wäre ein geschätzter/gerundeter Wert schon besser als 0 🙂

                              Homoran 1 Reply Last reply Reply Quote 0
                              • Homoran
                                Homoran Global Moderator Administrators @Funkymaddox last edited by

                                @funkymaddox sagte in Stiebel-ISG - Modbus:

                                selbst ohne wäre ein geschätzter/gerundeter Wert schon besser als 0

                                meine Antwort bezog sich auf

                                @android51 sagte in Stiebel-ISG - Modbus:

                                Der Wert ist grundsätzlich höher. Je höher die Aufnahmeleistung der Wärmepumpe, desto größer die Abweichung.

                                da scheinen ja Werte >0 zu existieren

                                Funkymaddox 1 Reply Last reply Reply Quote 0
                                • Funkymaddox
                                  Funkymaddox @Homoran last edited by

                                  @homoran
                                  Missverständnis. Du hast Recht. Bei mir und anderen WPM3/ISGweb Besitzern gibt die Anlage aber nicht mal die gerundeten/InverterOnly Werte aus, bei anderen Besitzern schon. Mein letzter Satz im Vorpost bezog sich auf mein Problem 🙂

                                  A 1 Reply Last reply Reply Quote 0
                                  • A
                                    Android51 @Funkymaddox last edited by

                                    Mag sein, dass es nur die reine Inverter-Aufnahmeleistung ist. Mich hat aber immer die gesamte Aufnahmeleistung der Wärmepumpe interessiert. Ich sehe das als Gesamtanlage und möchte dann auch wissen, wie hoch die Gesamtaufnahme ist. Zur Berechnung des Jahresarbeitszahl (JAZ) der Wärmepumpe rechne ich auch die Gesamtaufnahme und nicht nur einen Teil der Stromaufnahme mein ein. Wenn man dann nur die Inverteraufnahmeleistung berücksichtigt, ist die Stromaufnahme geringer und die JAZ (fälschlicherweise) besser.
                                    Aber... das war hier ja gar nicht Thema.

                                    Homoran Funkymaddox 2 Replies Last reply Reply Quote 1
                                    • Funkymaddox
                                      Funkymaddox last edited by Funkymaddox

                                      @android51
                                      Klar. Kurz: EVCC hat Wärmepumpen-Integration als "Beta" nun integriert.
                                      https://docs.evcc.io/docs/devices/heating

                                      Stiebel war als eine der ersten mit dabei. Es gibt zwei Templates für Stiebel (WPM und LWA/LWZ).
                                      EVCC nutzt Modbus und steuert die SG-Ready Funktionalität. Wobei hier nur Betriebstufe 2 und 3 (auch 4) genutzt werden.
                                      Settings sind noch nicht zu 100% auf WP zugeschnitten und klingen teils noch für Kfz:

                                      431989009-80e92ba0-9e64-4054-9137-a908e369cf99.png 431988994-687a16d5-743b-44d1-8027-eef0b89a9b80.png Bildschirmfoto 2025-04-10 um 17.13.48.png 431989007-aa3d3bf0-1f0e-4ec5-9fb0-764b401ebbdf.png

                                      So sieht das ganze bei mir aus:
                                      (Aus = EVCC Steuerung inaktiv, PV = bei Überschuss Stufe 3, Schnell = Stufe 4)
                                      Der Slider (60°c) ist nur Optik aktuell und wird auch überarbeitet.
                                      Unsere WP schafft auch nur bis 55°c InverterOnly (Notheizstab geht bei bei SG-Ready nicht mit an)
                                      Man hat die Auswahl der aktuellen WW Temp. oder der Puffer Temp..
                                      Priorisierung des Überschuss arbeitet prima mit Wallboxen und co.

                                      Bildschirmfoto 2025-04-13 um 11.17.14.png

                                      Bei uns steht leider nur bei Leistung immer 0kW. Dies sollte eigentlich behoben sein und EVCC nutzt Register 680 dafür. Bei uns klappt dies aber aus unbekannten Gründen nicht. Bei anderen sieht es so aus:

                                      430730749-14d9afed-f313-443b-a88d-81c543db3d40.png
                                      Screenshot zeigt ein andere Problem, aber die 12w zeigen, dass an sich Werte ausgegeben werden. Ohne Leistung kein Geladen und keine Statistiken.

                                      PS: Shellys können als Leistungsaufnahme Meter integriert werden, womit zumindest (für mich als Laie umständlich) das Problem gelöst werden kann und du auch die Gesamtleistungsaufnahme der WP angezeigt bekommst, anstelle des "falschen" Modbusregister Readouts

                                      1 Reply Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @Android51 last edited by

                                        @android51 Genau deswegen sieht es bei mir im Zählerschrank jetzt so aus
                                        20250325_154454.jpg

                                        Der Schrank wurde extra mit der WP erweitert/ersetzt

                                        1 Reply Last reply Reply Quote 0
                                        • Funkymaddox
                                          Funkymaddox @Android51 last edited by

                                          @android51
                                          Kannst du mir denn Tipps geben zur Nutzung Shelly? Macht ein 3 EM Sinn, also hast du nützliche Werte über die 2 Phasen der Notheizung, oder reicht auch ein 1 EM für die eine Phase des Inverters?
                                          Was für ein Stiebel System hast du denn, dass du zumindest die Inverter Stromaufnahme Daten bekommst?
                                          Wir haben eine WPL15AS, WPM3 (390-06), ISGWeg (12/2/3/260) und in der Servicewelt keinerlei Prozessdaten angezeigt. Ich wüsste gerne, woran es liegt, dass bei Nutzern wie mir keine Werte ausgelesen werden können via Modbus Register .. am WPM, am ISG, an der WP, an einer Software?

                                          A 1 Reply Last reply Reply Quote 0
                                          • A
                                            Android51 @Funkymaddox last edited by Android51

                                            @funkymaddox
                                            Ich habe mir den shelly pro 3em geholt, weil den den Stromverbrauch der Wärmepumpe ermitteln möchte. Der shelly hat 3 Klemmen, die du um jede einzelne Phase klemmen kannst. Je nachdem, was du erfassen möchtest.
                                            Verdichter, dann machst du die Klemmen und die drei Phasen des Verdichers. Gleiches könnte man mit dem Heizstab (Zusatzheizung) machen.
                                            Ich habe die Klemmen allerdings vor die Hutschiene (WP) gesetzt und um die 3 Phasen geklemmt, die zur Wärmepumpenverteilung gehen, damit ich den gesamten Strom erfasse. Also Verdichter und auch Heizstab, wenn der mal angehen sollte oder z. B. die Steuerung.
                                            Der shelly ermittelt auch einen fortlaufenden Zählerstand.

                                            Ich habe als Wärmepumpemmanager "wpm-system". Im Frontend werden die Prozessdaten bei mir unter Info - Wärmepumpe angezeigt. Geführt werden sie dort in der Rubrik "Prozessdaten".

                                            Kontaktiere mal den support, die sind recht zügig mit dem Antworten... servicewelt@...

                                            Das mit den EVCC werde ich mir mal genauer ansehen... ich mach das bislang immer noch händisch bei Gelegenheit, dass ich über einen virtuellen Schalter die SG-Ready Schnittstelle von 2 auf 3 schalte und wieder zurück.
                                            Wie sind denn deine Erfahrungen mit EVCC? Was macht EVCC besser als die aktuellen Überschuss abzufragen? Berücksichtigt EVCC die Wetterprognose? Ich möchte natürlich nicht, dass die WP ständig den Status ändert und immer wieder anspringt.

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

                                            Support us

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

                                            932
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            modbus stiebel-isg
                                            35
                                            486
                                            76070
                                            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