Expose your Zigbee devices to HomeKit with ease, by integrating π zigbee2mqtt with π Homebridge (via an MQTT message broker).
Please note that this is just an idea I had, that I'm still working on. Also keep in mind that I don't have a lot of TypeScript experience (my day time job as a software engineer mostly revolves around C and C#). π
I'm open to contributions, but please be nice and follow the etiquette.
If you have any suggestions, feedback, noticed a bug or improvement, let me know via the issues section.
Please do a search in open issues and PRs to see if the issue or feature request has already been filed.
If you find your issue already exists, make relevant comments and add your reaction. Use a reaction, instead of a "+1" / comment, like this:
π - upvote
π - downvote
If you cannot find an existing issue that describes your bug or feature, feel free to submit an new issue. Please try to provide enough (background) information.
After a bug fix or new feature is pushed to GitHub, you can already try it even before it is released. There's two ways to install the latest stuff from GitHub on your machine:
- Use the install command:
npm i -g itavero/homebridge-z2m#master
(in whichmaster
is the name of the branch) - Checkout the repository locally, and run the following commands:
cd path/to/git/repository npm i npm run build npm link
β οΈ This plugin is still under active development. Things might break/change between releases.
First of all, make sure you have zigbee2mqtt setup correctly. Without a working zigbee2mqtt installation, this plugin won't be able to do much for you.
The easiest way to install this plugin and configure this plugin, is by using Homebridge Config UI X. On the Plugins tab, look for z2m
or zigbee2mqtt
and hit the Install button. After that you can configure the plugin settings via the same page.
An alternative way is to manually call npm i -g homebridge-z2m
and add the configuration to the platforms
array of your Homebridge config.json
.
A (rather minimal) configuration looks like this:
{
"platform": "zigbee2mqtt",
"mqtt": {
"base_topic": "zigbee2mqtt",
"server": "mqtt://localhost:1883"
},
"devices": [
{
"id": "0x1234567890abcdef",
"exclude": true
},
{
"id": "0xabcdef1234567890",
"excluded_keys": [
"battery"
]
}
]
}
Within the mqtt
object, you can add pretty much all the configuration options that zigbee2mqtt also has, with the same keys as in the zigbee2mqtt configuration YAML file:
base_topic
server
ca
key
cert
user
password
client_id
reject_unauthorized
keepalive
version
Please refer to the zigbee2mqtt documentation for more information on the MQTT options.
β οΈ IMPORTANT: Thedevices
part of the configuration changed in v0.0.7
Within devices
, you can set options for specific devices, based on their IEEE addresses or the friendly_name
.
Currently the following options are available:
exclude
: if set totrue
this device will not be exposed via HomeKit.excluded_keys
: an array of keys that should be ignored/excluded from the status message published by zigbee2mqtt.
The plugin listens to the MQTT messages published by zigbee2mqtt.
It detects the devices using the zigbee2mqtt/bridge/config/devices
topic.
Whenever it receives a message for a device (on zigbee2mqtt/[FRIENDLY_NAME]
topics), it tries to deduct the available HomeKit services from the elements in that message and publishes/updates these. The following elements are currently handled:
JSON key | HomeKit Service |
---|---|
state / state_left / state_right / state_center / state_top_left / state_center_left / state_bottom_left / state_top_right / state_center_right / state_bottom_right |
Switch (or Lightbulb, or LockMechanism) |
state / lock_state |
LockMechanism |
brightness , color_temp , color |
Lightbulb (requires state to be present too) |
temperature |
TemperatureSensor |
humidity |
HumiditySensor |
contact |
ContactSensor |
illuminance_lux |
LightSensor |
occupancy |
OccupancySensor |
smoke |
SmokeSensor |
water_leak |
LeakSensor |
position |
WindowCovering |
battery |
BatteryService (currently StatusLowBattery is set to Low when the reported battery level is less than 30%) |
carbon_monoxide |
CarbonMonoxideSensor |
pressure |
Air Pressure Sensor (using same service and characteristic as Elgato Eve Weather) |
This way this homebridge plugin does not have to know the different devices. In other words, if a new device gets added to zigbee2mqtt, you probably only have to update zigbee2mqtt and not this plugin.
Unfortunately, a downside is that the device must have published its data before the plugin knows how HomeKit could use it. All devices except the Coordinator will be exposed to HomeKit, even before any services are discovered. So, you could already put your new device in the right room in the Home app, even though you might not be able to use it already.
(TBD: How to handle when a lights state contains both color_temp
and color
? Which one to follow? Maybe monitor for changes or monitor zigbee2mqtt/[FRIENDLY_NAME]/set
?)
Below is a list of ideas I still have for this plugin. Of course, right now my priority is to be able to monitor and control my Zigbee devices first.
- "virtual" switch to enable/disable
permit_join
(and also have it automatically turn off when a timer elapses or a device is paired). - When
update_available
is set totrue
, provide a switch service to start the FW update via HomeKit (and maybe see if it is possible to provide feedback on the progress somehow). I might add this to each device individually, or maybe generate one virtual device that acts as a binary sensor (so that you can also get some kind of notification when an update is available) and add multiple switches to that. - Support for push buttons (including double click and hold, if possible).
- If available, use the information for the Home Assistant MQTT discovery, to figure out available services even before the data is published.