ShellyPro1 goes Homematic - mit der Originalfirmware


  • ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

    Entwickelt und getestet auf ShellyPro1-Firmware:

    0.9.1 und 0.9.2


    Hallo liebe Homematic-Freunde. :)

    Heute geht es um die Einbindung des ShellyPro1.


    Mein Dank an SparkyMaster , der mich mit Skripttests und Screenshots unterstützt hat. Danke Axel. :thumbup:


    Das Ganze funktioniert natürlich wie immer ohne Fremdfirmware. ;)

    Die Kopplung hat folgende Möglichkeiten:

    • Ein- und Ausschalten des Schaltkanals inkl. Rückmeldung, wenn über die App oder per Schalter geschaltet wird
    • Überwachung des Onlinestatus, kein CUxD-Ping-Device nötig, optional
    • Alle notwendigen Systemvariablen werden automatisiert erstellt und dem passenden Schaltkanal zugeordnet, daher sehr leicht einzurichten
    • Aktualsierung direkt nach Übergang von OFFLINE --> ONLINE (Aktualisierung des Schaltzustandes, falls umgeschaltet wurde, während die CCU den Shelly als Offline erkannte)


    Das Ganze sieht dann im maximalen Endausbau so aus:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.


    techn. Voraussetzungen:

    • kompatibel mit den Homematic-Systemen CCU2, CCU3, Charly, sowie allen Ablegern wie RaspberryMatic und piVCCU.

    • installiertes Addon CUxD in aktueller Version

      (Das Wissen um den Umgang CUxD, wie z.B. Geräte anlegen, setze ich an dieser Stelle voraus, sonst "explodiert" diese Anleitung. Danke für's Verständnis.)

    Ich möchte Euch an dieser Stelle empfehlen, vor der Umsetzung mal einen Blick in diesen Thread zu werfen:

    (Auch die übrigen angepinnten Themen sind übrigens zum Lesen empfohlen, gerade auch für Neueinsteiger ;))

    Und nun geht's los. :)

    __________________________________________________________________________________

    ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

  • ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!


    Falls noch nicht vorhanden, bitte ein Gerät (28) System Exec anlegen! Darüber werden die Befehle abgesetzt.

    Hier gibt es bei Bedarf eine Anleitung zum Anlegen des CUxD-Exec-Gerätes.

    (Im CUxD-Exec selbst werden keine Eintragungen gemacht!)

    Für den ShellyPro1 benötigen wir 1 Kanal eines ggf. vorhandenen oder neu anzulegenden

    CUxD Gerätetyps (40) 16 Kanal Universalsteuerung als Schalter:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.


    (Den Namen könnt Ihr natürlich frei vergeben und anpassen. ;) )

    Damit können 16 ShellyPro1 abgebildet werden.


    Ein- und Ausschalten des Kanals:


    Um den Shelly mit dem CUxD-Device zu schalten muß nun noch der egnutzte Kanal der CUxD-Device eingestellt werden:

    1.) Haken setzen bei "SWITCH|CMD_EXEC"

    2.) Eintrag für "SWITCHCMD_SHORT":

    IP-Adresse des Shelly anpassen!

    Code
    wget -q -T2 -t2 -O - 'http://192.168.2.141/rpc/Switch.Set?id~3d0~26on~3dfalse'


    3.) Eintrag für "SWITCHCMD_LONG":

    IP-Adresse des Shelly anpassen!

    Code
    wget -q -T2 -t2 -O - 'http://192.168.2.141/rpc/Switch.Set?id~3d0~26on~3dtrue'

    Das Ganze sollte also jetzt so aussehen:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.

    Damit funktioniert schon mal das EIN- und AUS-Schalten des ShellyPro1 . :)


    __________________________________________________________________________________

    ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

  • ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!


    Rückmeldung des Schaltzustandes:

    Damit der Status der Schaltkanäle auch stimmt, wenn am Shelly oder per App oder Web-UI geschaltet wird, bedienen wir uns der Webhooks des Shelly (ehem. ACTIONS).

    Diese müssen (am Besten über das Web-UI) im Shelly eingerichtet werden:

    2 Webhooks sind mit "Add Webhook" anzulegen.

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.


    Webhook für Ausgang eingeschaltet:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.

    Request-Code:

    Code
    http://192.168.2.141:8181/66er.exe?Antwort=dom.GetObject(%22CUxD.CUX4000001:1.SET_STATE%22).State(1)


    Webhook für Ausgang ausgeschaltet:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.


    Request-Code:

    Code
    http://192.168.2.141:8181/66er.exe?Antwort=dom.GetObject(%22CUxD.CUX4000001:1.SET_STATE%22).State(0)

    IP-Adresse und CUxD-Adresse / CUxD-Kanal anpassen!


    Nun wird auch schon der Schalt-Status der ShellyPro1 aktualisiert, wenn von außerhalb der CCU geschaltet wird. :)


    __________________________________________________________________________________

    ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

  • ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

    Zustands-Aktualisierung:


    1. Programm


    Vorab:

    Bis hierhin funktioniert ja eigentlich schon alles.

    Wozu also noch ein Aktualisierungsprogramm? :/

    1. ermöglicht das Skript die ONLINE-Überwachung des Shelly. (Alternativ könnte man das auch über ein CUxD-PING-Device erreichen, siehe 1. Kopplungen Shelly 1.Gen.)
    2. aktualisiert und ggf. korrigiert das Skript den Zustand der Schaltkanäle wenn der Shelly aus Sicht der Homematic OFFLINE war, zwischendurch geschaltet wurde und wieder ONLINE geht .

    Das Programm:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.


    Ob man im WENN die interne Zeitsteuerung nutzt oder einen CUxD-Timerkanal als Trigger nutzt, kann man dabei frei entscheiden.

    (In meinem Beispiel wurde das interne Zeitmodul genutzt.)


    Einstellungen im Zeitmodul:

    Der Inhalt kann nicht angezeigt werden, da Sie keine Berechtigung haben, diesen Inhalt zu sehen.

    Das Aktualisierungsintervall kann natürlich angepasst werden, wobei zu beachten ist:

    Je kürzer das Intervall desto höher die Systembelastung für die Homematic-Zentrale. Hier muß / kann man testen. Ab wann die Performance leidet hängt natürlich zum Einen von der eingesetzten Hardware und zum Anderen vom Umfang der Installation ab.

    __________________________________________________________________________________

    ©2021 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

  • ©2021-2024 Stefan K. (alias 66er) - ausführlicher Hinweis dazu am Ende der Anleitung

    Alle Rechte vorbehalten!

    2. Das Skript

    Bitte den Bereich "Setup" anpassen und Hinweise beachten!

    Ausserhalb des Setup sind keine Änderungen oder Eintragungen nötig!


    Bitte außerdem beachten:

    Im Skript ist RestrictLogin schon enthalten. Wie sich erst später herausstellte, wird das aber aktuell in der Firmware/vom Gerät nicht unterstützt!

    Daher bitte im Setup nicht aktivieren!



    Im eingestellten Intervall werden nun entsprechend den aktivierten Feature Schaltkanal und Onlinestatus aktualisiert. :)


    Changelog:

    15.12.2021 V 1.0.1 (Versionsdatum 15.12.2021)

    Erstveröffentlichung


    ____________________________________________________________

    Die Anleitung inkl. der Skripte und Bilder unterliegt dem Urheberrecht. Wer gegen das Urheberrecht verstößt (z.B. Bilder oder Texte unerlaubt kopiert und auf anderen Webseiten publiziert), macht sich gem. §§ 106 ff UrhG strafbar, kann zudem kostenpflichtig abgemahnt werden und muss Schadensersatz leisten (§ 97 UrhG).

    © 2021 Stefan K. (alias 66er)

    Alle Rechte vorbehalten

    ____________________________________________________________