Skip to content

luar123/zigbee_esphome

Repository files navigation

Important

If you get build errors try to delete the .esphome/build/<name>/ folder first. If the esp crashes try to delete completely with esptool.py erase_flash and flash again.

Important

Config validation is not complete. Always consult Zigbee Cluster Library for cluster definitions

ESPHome ZigBee external component

External ZigBee component for ESPHome.

Features

  • Definition of endpoints, clusters and attributes supported by esp-zigbee-sdk 1.5
  • Set attributes action
  • Manual report action
  • Reset zigbee action
  • Join trigger
  • Attribute received trigger
  • Wifi co-existence on ESP32-C6
  • Deep-sleep should work
  • Not tested: groups/scenes

Limitations

  • Only end devices
  • Attribute set action and OnValue trigger works only with integer types
  • Reporting can be enabled, but not configured
  • No control devices like switches
  • Needs esp-idf >=5.1.4

ToDo List (Short-Mid term)

  • Custom clusters/attributes (done)
  • Switch to esp-zigbee-sdk 1.5 (done)
  • Time component
  • Light effects (through identify cluster commands)
  • Router devices
  • Easier support for sensors

Not planed (feel free to submit a PR)

  • Coordinator devices
  • Binding config in yaml
  • Reporting config in yaml
  • Control device support (e.g. switches)

Notes

  • I don't have much free time to work on this right now, so feel free to fork/improve/create PRs/etc.
  • At the moment, the C++ implementation is rather simple and generic. I tried to keep as much logic as possible in the python part. However, endpoints/clusters/attributes could also be classes, this would simplify the yaml setup but requires more sophisticated C++ code.
  • There is also a project with more advanced C++ zigbee libraries for esp32 that could be used here as well: https://github.com/Muk911/esphome/tree/main/esp32c6/hello-zigbee
  • parse_zigbee_headers.py is used to create the python enums and C helper functions automatically from zigbee sdk headers.
  • Deprecated custom zigbee component

Usage

Include external component:

external_components:
  - source: github://luar123/zigbee_esphome
    components: [ zigbee ]

zigbee:
  ...

Configuration variables:

[Todo]

Example:

zigbee:
  id: "zb"
  endpoints:
    - num: 1
      device_type: COLOR_DIMMABLE_LIGHT
      clusters:
        - id: ON_OFF
          attributes:
            - id: 0
              type: bool
              on_value:
                then:
                  - light.control:
                      id: light_1
                      state: !lambda "return (bool)x;"
        - id: LEVEL_CONTROL
          attributes:
            - id: 0
              type: U8
              on_value:
                then:
                  - light.control:
                      id: light_1
                      brightness: !lambda "return ((float)x)/255;"
    - device_type: TEMPERATURE_SENSOR
      num: 2
      clusters:
        - id: REL_HUMIDITY_MEASUREMENT
          attributes:
            - id: 0
              type: U16
              report: true
              value: 200
        - id: TEMP_MEASUREMENT
          attributes:
            - id: 0x0
              type: S16
              report: true
              value: 100
  on_join:
    then:
      - logger.log: "Joined network"

Actions

  • zigbee.setAttr
    • id: "id of zigbee component"
    • endpoint: "endpoint number"
    • cluster: "cluster id"
    • attribute: "attribute id"
    • value: "value, can be a lambda"
      • only integer types
  • zigbee.report: "id of zigbee component"
    • Manually send reports
  • zigbee.reset: "id of zigbee component"
    • Reset Zigbee Network and Device. Leave the current network and tries to join open networks.

Examples:

    on_value:
      then:
        - zigbee.setAttr:
            id: zb
            endpoint: 2
            cluster: REL_HUMIDITY_MEASUREMENT
            attribute: 0x0
            value: !lambda "return x*100;"
    on_press:
      then:
        - zigbee.report: zb

Example Zigbee device

ESPHome Zigbee using only dev board or additionally AHT10 Temperature+Humidity Sensor.

Hardware Required

  • One development board with ESP32-H2 or ESP32-C6 SoC acting as Zigbee end-device (that you will load ESPHome with the example config to).
  • AHT10 Temperature+Humidity Sensor connected to I2C pins (SDA: 12, SCL: 22) for the aht10 example.
  • A USB cable for power supply and programming.
  • (Optional) A USB-C cable to get ESP32 logs from the UART USB port (UART0).

Build ESPHome Zigbee sensor

How to contribute

Please submit all PRs here and not to https://github.com/luar123/esphome/tree/zigbee

If looking to contribute to this project, then suggest follow steps in these guides + look at issues in Espressif's ESP Zigbee SDK repository:

External documentation and reference

Note! The official documentation and reference examples for the ESP Zigbee SDK can currently be obtained from Espressif:

About

External zigbee component

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published