mirror of
https://github.com/balkian/balkian.github.com.git
synced 2024-12-27 18:48:13 +00:00
105 lines
3.8 KiB
Markdown
105 lines
3.8 KiB
Markdown
---
|
||
title: Controlling Zigbee devices with MQTT
|
||
date: 2019-01-06 10:00:00
|
||
tags:
|
||
- mqtt
|
||
- iot
|
||
- zigbee
|
||
---
|
||
|
||
This is a short tutorial on connecting a zigbee device (an Aqara cube)
|
||
to an MQTT server, so you can control your zigbee devices from the
|
||
network.
|
||
|
||
If you're anything like me, you're probably a sucker for IoT devices.
|
||
For a long time, I've been using WiFi-enabled lights, and Amazon dash
|
||
buttons to control them. To keep these (cheap Chinese) internet enabled
|
||
devices away from your network and their respective cloud services,
|
||
you'll probably want to set up a dedicated network in your router (more
|
||
on this on a future post, maybe). Another disadvantage of WiFi devices
|
||
is that they're relatively power hungry.
|
||
|
||
A popular alternative is using ZigBee for communication. It is a
|
||
dedicated protocol similar to bluetooth (BLE), with lower power
|
||
requirements and bitrate.
|
||
|
||
Take the (super cute) aqara cube as an example. It is a small cube that
|
||
detects rotation on all of its axes, and tapping events. Here's a
|
||
video:
|
||
|
||
{{< youtube 5YtqG1wEnng >}}
|
||
|
||
To connect to zigbee devices you will need a zigbee enabled gateway
|
||
(a.k.a. hub), which connects to your WiFi network and your zigbee
|
||
devices. Once again, this means adding an internet-enabled device to
|
||
your home, and probably a couple of cloud services.
|
||
|
||
As an alternative, you can set up your own zigbee gateway, and control
|
||
it to your home automation platform of choice (e.g. home assistant). We
|
||
will cover how to set up a zigbee2mqtt gateway that is also connected to
|
||
an MQTT server, so you can use MQTT to control your devices and get
|
||
notifications.
|
||
|
||
What you need:
|
||
|
||
- [Aqara
|
||
cube](https://www.aliexpress.com/item/Original-Xiaomi-Mi-Aqara-Cube-Smart-Home-Controller-6-Action-Operation-Fr-Home-Device-Zigbee-Version/32892947622.html?spm=a2g0s.9042311.0.0.3da24c4dXV8sBI).
|
||
- [CC2531 zigbee
|
||
sniffer](https://www.aliexpress.com/item/Wireless-Zigbee-CC2531-CC2540-Zigbee-Sniffer-Bluetooth-BLE-4-0-Dongle-Capture-Module-USB-Programmer-Downloader/32907587711.html?spm=a2g0s.9042311.0.0.3da24c4dXV8sBI).
|
||
- [CC-debugger](https://www.aliexpress.com/item/CFSUNBIRD-CC-DEBUGGER-Debugger-and-Programmer-for-RF-System-on-Chips-TI-ORIGINAL-Fast-hipping/32813122315.html?spm=a2g0s.9042311.0.0.3da24c4dXV8sBI).
|
||
|
||
You will need to flash your sniffer. For that, you only need to follow
|
||
the instructions from the [zigbee2mqtt
|
||
documentation](https://koenkk.github.io/zigbee2mqtt/).
|
||
|
||
Once you're done flashing, you're ready to set up the zigbee2mqtt
|
||
server. For convenience, I wrote a simple docker-compose to deploy a
|
||
zigbee2mqtt server and a test mosquitto server:
|
||
|
||
```yaml
|
||
version: '2.1'
|
||
services:
|
||
zigbee2mqtt:
|
||
image: koenkk/zigbee2mqtt
|
||
container_name: zigbee2mqtt
|
||
restart: always
|
||
volumes:
|
||
- ./z2m-data/:/app/data/
|
||
devices:
|
||
- "/dev/ttyACM0"
|
||
networks:
|
||
- hass
|
||
mqtt:
|
||
image: eclipse-mosquitto
|
||
ports:
|
||
- 1883:1883
|
||
- 9001:9001
|
||
networks:
|
||
- hass
|
||
volumes:
|
||
- ./mosquitto.conf:/mosquitto/config/mosquitto.conf
|
||
networks:
|
||
hass:
|
||
driver: overlay
|
||
```
|
||
|
||
You can test your installation with:
|
||
|
||
{{<highlight shell "linenos=" >}}
|
||
❯ mosquitto_sub -h localhost -p 1883 -t 'zigbee2mqtt/#'
|
||
online
|
||
{"battery":17,"voltage":2925,"linkquality":149,"action":"rotate_right","angle":12.8}
|
||
{"battery":17,"voltage":2925,"linkquality":141,"action":"slide","side":2}
|
||
{"battery":17,"voltage":2925,"linkquality":120}
|
||
{"battery":17,"voltage":2925,"linkquality":141,"action":"wakeup"}
|
||
{{< / highlight >}}
|
||
|
||
zigbee2mqtt supports the following events for the aqara cube: shake,
|
||
wakeup, fall, tap, slide, flip180, flip90, rotate_left and
|
||
rotate_right. Every event has additional information, such as the sides
|
||
involved, or the degrees turned.
|
||
|
||
Now you are ready to set up home assistant support in zigbee2mqtt
|
||
following [this
|
||
guide](https://koenkk.github.io/zigbee2mqtt/integration/home_assistant.html).
|