In every installation methods, the plugin requires DomoticZ version 2021.1 or greater and Python version 3.8 or higher. Make sure that you have python3-dev package installed. More informations on DomoticZ Python page.
In this first step, there are severals installation methods depending on your Operating System :
- 1 - Manual Installation running on Linux
- 2 - Python Plugin Manager installation running on Linux
- 3 - Installation running on Synology NAS
- 4 - Installation running on Docker
- 5 - Installation running on Windows 10
- 6 - PiZigate Installation on RPi3B+ running on Raspbian (Linux)
- 7 - PiZigate Installation on RPi3B+ running on Fedora 29 (Linux)
- 8 - Installation running on OpenWRT
This method is only valid for Linux : Raspberry, Debian, Ubuntu, etc. It will be necessary to modify the command lines according to your system..
Important : This installation method is not valid for an installation of the PiZigate (check the PiZigate installations process).
- DomoticZ version above 2021.1 (voir Wiki DomoticZ)
- Python version above 3.8 (voir DomoticZ Python)
- Git packet installed
- Pip packet installed
- On Raspeberry Pi OS, it is not recommended to use the Lite version because many packages are missing.
Open the terminal
- Go in your DomoticZ directory and inside the plugins folder. The command is usually :
cd domoticz/plugins/
- Run the command :
git clone https://github.com/zigbeefordomoticz/Domoticz-Zigbee.git
The folder Domoticz-Zigbee will be created in the plugins folder.
- Go to the Domoticz-Zigbee folder. The command is usually :
cd Domoticz-Zigbee/
- Install the needed Python packet with the command :
sudo pip3 install -r requirements.txt
Note : With Debian 12 Bookworm, you have to add --break-system-packages at the end of the previous command line. Be careful to take the two dash at the beginning.
- Execute the command by adapting pi:pi if necessary to the user:group used. Be careful to take the point at the end.
sudo chown -R pi:pi .
- Run the command :
git config --add submodule.recurse true
- Install the missing Python libraries with the command :
git submodule update --init --recursive
- Make the plugin.py file executable with the command :
sudo chmod +x plugin.py
- Restart DomoticZ. The command is usually :
sudo service domoticz.sh restart
The ZigBee for DomoticZ plugin should appear in the hardware list (at the very bottom of the Type listbox). Move on to step 2 Plugin settings.
This procedure is not yet updated to be compatible with version 6 of the plugin.
- If you have pp-manager installed on your system
- Just search for "Zigbee for domoticz Plugin" entry and add it.
This procedure is not yet updated to be compatible with version 6 of the plugin.
The purpose of this document is to help you in the installation of the Zigate plugin on a Synlology platform
- First of all, please go through the Domoticz Python page
- The Domoticz for Synology package to be installed is the version 'with Python'. You can download it from Jahdal. At this moment it is v4.10717 with Python 3.5.1.
- Python Module from the Package manager must be installed. Python Module
- The GitHub server Synology package must be installed . Install Git Server package via Diskstation. We don't need the 'Server' part of the GitHub Server package, just the 'git command', so no specific configurations are required.
- it is assumed that you have 'root'/'admin' right access with the use of 'sudo' command
Attention:
- You need git-server package
- Domoticz with python
- USB drivers for ZiGate can be found on jadahl.com
Start a Putty session and login
Navigate to plugin folder domoticz:
cd /volume1/@appstore/domoticz/var/plugins
GIT clone Zigbee for Domoticz plugin to new folder Zigbee:
sudo git clone https://github.com/zigbeefordomoticz/Domoticz-Zigbee Zigbee
Stop and start domoticz from package manager.
In domoticz navigate to Settings -> Hardware
Pick Zigate Plugin from the list, name it and set the wright USB port.
At the first boot you have to set “Erase Persistent Data” to True to build a new network.
Set Permit Join to value 255 to search for a unlimited time for new devices
Click Add and check the log. When the USB TTL is in Permit Join mode the blue and red LEDs are flickering. Now you can add devices the usual way. For example press and hold 3 secs the button at the Aqara sensor.
When you are done adding devices set the permit join value to something lower than 255.
There is a known issue on Syno which makes Domoticz to crash when starting the plugin. You need to disable the feature to check for plugin and firmware update availability.
You have to edit the file Domoticz-ZigbeeConf/PluginConf-xx.json and add the following line
"internetAccess": 0,
the best is to add it in the middle of the file, so you don't break the all file syntax
This procedure is not yet updated to be compatible with version 6 of the plugin.
How to install Zigbee4Domoticz on a docker based setup
This procedure is not yet updated to be compatible with version 6 of the plugin.
-
Make sure you have all the latest software and pyhon-dev is installed:
sudo apt-get update sudo apt-get upgrade sudo apt-get install python3-dev
-
Test if wiringpi is installed:
gpio -v gpio readall
-
If not, install it :
sudo apt-get install wiringpi
if it doesn't work you can download the wiringpi package from here
-
Set the gpio pins for production mode in rc.local so that this will happen on every reboot:
sudo nano /etc/rc.local gpio mode 0 out gpio mode 2 out gpio write 2 1 gpio write 0 0 gpio write 0 1
Put these 5 lines just before the exit 0 line, save and exit
-
If you have a RPi3B+, shutdown Bluetooth permanently by editing config.txt:
sudo nano /boot/config.txt
Put this on the end of the file:
dtoverlay = pi3-disable-bt
Save and exit.
-
Open the cmdline.txt:
sudo nano /boot/cmdline.txt
Delete the text console = serial0,115200 Save and exit
-
Type the following commands (if pi is the username you are log in):
sudo systemctl disable hciuart sudo usermod -ag gpio pi sudo shutdown
-
Power off the RPi, plug the Pizigate card in the gpio slot and power up.
-
Set the accessability of the serial adapter to 'No' using raspi-config option P6 (Interfacing options / serial):
sudo raspi-config
-
Use at latest version (>4.10) of Domoticz. If you're still on stable version 4.9700, first update:
cd /home/pi/domoticz ./updatebeta
-
Get the latest Zigate plugin and make the plugin.py executable:
cd /home/pi/domoticz/plugins git clone https://github.com/zigbeefordomoticz/Domoticz-Zigbee chmod +x Domoticz-Zigbee/plugin.py
-
If already installed, update to the newest version:
cd /home/pi/domoticz/plugins/Domoticz-Zigbee git pull sudo reboot
-
Startup the Pizigate:
Tools/pi-zigate.sh run
-
Go to the hardware tab of Domoticz and Add the new hardware: Name: Zigbee (or something similar) Type: Zigbee for domoticz plugin Click Add
Next, click on Zigate in the hardware list to edit settings: Model: PI Serial Port: /dev/serial0 Permit join time: 255 (=permanently) Erase Persistent Data: True (has to be done once on initialization) Click Update
If everything went okay, the blue LED wil flash brightly and you can pair Zigbee devices by resetting them.
If you ever have to enter flash mode to update the Pizigate firmware, first type:
0 gpio way out
2 gpio way out
gpio write 2 0
gpio write 0 0
gpio write 0 1
After flashing the firmware, a sudo reboot will reload defaults from rc.local
Fedora is my development platform, and I was a bit frustrated when the PiZigate came and was only running on Raspbian. Finally after few trials and changes, I have been able to get a Fedora 29 , Domoticz , PiZigate stack fully operational
Platform: RPI3 B+
-
Enable UART
-
Edit file
/boot/efi/config.txt
- Make sure that the following lines are uncommented
enable_uart=1
dtoverlay = pi3-disable-bt
- reboot
- Make sure that the following lines are uncommented
-
Disable any Getty on /dev/ttyS1
systemctl stop [email protected]
systemctl disable [email protected]
-
Check that there is no more process attached to /dev/ttyS1
lsof /dev/ttyS1
orps -ef | grep ttyS1
-
-
Check /dev/ttyS1 access rights
-
ls -l /dev/ttyS1
-
edit /etc/group and make sure that the user running domoticz belongs to the tty group
sudo usermod -aG tty domoticz
-
make sure that /dev/ttyS1 is read/write access
sudo chmod 666 /dev/ttyS1
-
-
Enable GPIO
-
Install libgpiod and python3 RPi.GPIO
- sudo dnf install python3-RPi.GPIO libgpiod-utils
-
Kernel must run withthe iomem=relaxed option
- Edit /etc/exlinux.conf and add iomem=relaxed in the append statement
Here is an exemple of what you should have
label Fedora (5.4.17-200.fc31.armv7hl) 31 (Thirty One)
kernel /vmlinuz-5.4.17-200.fc31.armv7hl append ro root=UUID=2161061e-8612-4e18-a4e1-0e95aca6d2ff LANG=en_US.UTF-8 selinux=0 audit=0 rd.driver.blacklist=nouveau iomem=relaxed fdtdir /dtb-5.4.17-200.fc31.armv7hl/ initrd /initramfs-5.4.17-200.fc31.armv7hl.img
* You can use the pi-zigate-fedora.py tool provided under Tools/Fedora to switch the PiZigate to RUN or FLASH mode. For now you must be root when executing this module * `sudo python3 Tools/Fedora/pi-zigate-fedora.py run`
-
-
Sanity check
-
A tool is provided under Tools/Fedora to test the communication with the PiZigate. The tools is based on the PiZiGate_test tool provided with Zigate and is limited to the pure communication test.
-
recompile the tool
gcc -o PiZiGate_test-fedora PiZiGate_test-fedora.c
-
excute it
./PiZiGate_test-fedora /dev/ttyS1
[domoticz@rasp Fedora]$ ./PiZiGate_test-fedora /dev/ttyS1 Opening : /dev/ttyS1 ... + /dev/ttyS1 opened --> OK + Packet 01 02 10 10 02 10 02 10 10 03 sent --> OK + Packet received --> OK size : 37 01 80 00 00 05 95 00 00 00 10 00 03 01 80 10 00 05 8f 00 03 03 1a 00 03
-
If you reach this step, you can start domoticz and configure the Zigate plugin on the PiZigate
- OpenWRT provides a number of prebuilt python packages via opkg that must be installed instead of the normal dependencies :
opkg install kmod-usb-serial kmod-usb-serial-cp210x shadow-usermod python3 python3-pip python3-voluptuous python3-cryptodome python3-attrs python3-aiohttp python3-jsonschema domoticz curl
pip install aiosqlite crccheck pyusb pyserial-asyncio coloredlogs
- The domoticz package provided by opkg has slightly different installation paths:
cd /etc/domoticz/plugins
git clone --recurse-submodules --depth 1 -b beta6 https://github.com/zigbeefordomoticz/Domoticz-Zigbee.git
chmod +x Domoticz-Zigbee/plugin.py
- Domoticz is automatically configured to run under the 'domoticz' user and group, permissions must be granted to any resources it needs:
chown -R domoticz:domoticz /etc/domoticz/plugins/Domoticz-Zigbee
usermod -a -G dialout domoticz
- Finally, restart domoticz to apply all changes:
service domoticz restart
- You can verify that your Zigbee USB dongle was detected via:
lsusb
dmesg | grep ttyUSB