Skip to content

Shelly device teacher for Domoticz MQTT Autodiscovery hardware

License

Notifications You must be signed in to change notification settings

svde/shellyteacher4domo

 
 

Repository files navigation

Release downloads Code size Last commit

ShellyTeacher 4 Domoticz

Shelly device teacher for Domoticz MQTT Autodiscovery hardware

You need to understand before installation:

  • this is not compatible with the old ShellyMQTT plugin, its based on a different hardware, which will create new devices
  • its not a plugin, nor a service, it doesn't need to run all the time - only once (Domoticz MQTT Autodiscovery is the Domoticz integrated hardware)
  • only the Shelly device types listed in the "Implemented devices" will be recognised, but you can change/enhance templates.txt file to add more devices

If you got a message "template not found" when teaching, than either your database is outdated/corrupted or your device is not supported. Please try to download latest *.txt files from github, before reporting issues.

How it works

When this program started it connects to the MQTT server and awaits for Shelly device announcements. Domoticz MQTT Autodiscovery hardware has to be enabled and Shelly devices has to connect to the same MQTT broker, as the Domoticz and this program.

How to install

A. Please use the precompiled windows binary if you are not familiar with Linux: https://github.com/enesbcs/shellyteacher4domo/releases

The Teacher can be run on ANY machine on the network, which accessing the MQTT IP addres, does not need to run on the Domoticz server directly!!!

B. For Linux users for any platform capable of running python3:

-Install git (Debian/Ubuntu if user has root right)

apt install git

-OR install git (Debian/Ubuntu if user has sudo right)

sudo apt install git

-Download application with git

git clone https://github.com/enesbcs/shellyteacher4domo.git

-Run the installation script first, and only once (which will deal python venv)

cd shellyteacher4domo
./preinstall.sh

-If installation was succesful, ShellyTeacher now can be run from the venv named 'paho' with this command:

./run.sh

In case you want to save the configurations after rebooting, please make sure that MQTT broker persistence settings configured correctly!

If you are unable to install or run the program, please download the windows binary! ˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇˇ

Windows and Linux x64 binary builds published and can be downloaded from releases: https://github.com/enesbcs/shellyteacher4domo/releases

A GUI is also available when TKInter works, this is the default now, Console mode can be requested by specifying -c parameter at the command line!

Youtube tutorial

HINT: If you have to add multiple Shelly devices to MQTT, you can use Shelly Scanner app to set MQTT on them.

How to update the program

First: backup your templates.txt files if you modified it, than:

git pull

How to use

  1. Edit settings.py file with a plain text editor, and set MQTT server IP address. If discovery prefix is leaved as default 'homeassistant' on the Domoticz MQTT AD hardware, than other settings will fine.
  2. Make sure that the Shelly device connects to the same MQTT broker IP address.
  3. Start Teacher
cd shellyteacher4domo
./run.sh
  1. Power Shelly device or restart it
  2. If Teacher finds the device ID in the mqtt_templates.txt, those will be automatically forwarded for the Discovery topic, and as the default publish method is 'RETAIN', it will survive reboot, and Teacher application is not needed to run, until you wants a new Shelly device to be installed

(In case of Gen2/Gen3 device, the device has to be started before the Teacher, and make sure to enable "Generic status update over MQTT" at MQTT settings page)

Windows and Linux x64 binary builds published and can be downloaded from releases: https://github.com/enesbcs/shellyteacher4domo/releases

A GUI is also available when TKInter works, this is the default now, Console mode can be requested by specifying -c parameter at the command line!

Implemented devices

Gen1:

  • Shelly 1 / 1PM / 1L
  • Shelly 2/Shelly 2.5 relay and roller mode
  • Shelly Plug / Plug S
  • Shelly 4 Pro
  • Shelly H&T
  • Shelly Motion 1/2
  • Shelly Door Window 1/2
  • Shelly Button
  • Shelly i3
  • Shelly Duo
  • Shelly Dimmer 1/2
  • Shelly Vintage
  • Shelly UNI
  • Shelly EM
  • Shelly 3EM
  • Shelly Smoke
  • Shelly Flood
  • Shelly Gas
  • Shelly2LED
  • Shelly RGBW2 (*only with 4 channel white mode)
  • Shelly TRV (needs Domoticz 2023 beta 15515 or later)

Gen2:

Gen3: (Experimental! needs feedback!)

  • Shelly 1 Mini G3 / 1PM Mini G3
  • Shelly PM Mini G3
  • Shelly HT G3

Known problems with devices

  • Every Gen1 RGB devices will not work (see enesbcs#7)

About

Shelly device teacher for Domoticz MQTT Autodiscovery hardware

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 88.7%
  • Shell 11.3%