Home-Assistant implementation for the Xiaomi (Aqara) gateway Supported sensors:
- Temperature / Humidity - reports if temperature change reaches 0.5 ° C or the humidity change reaches 6%.
- Magnet (Door / Window)
- Motion
- Button Switch(Each switch was shown as three individual virtual switches: ONE_CLICK, DOUBLE_CLICK and LONG_PRESS. Those virtual switches should be better used as automation triggers only)
- Power Plug
- Aqara Wall Switch
- Install Home-Assistant,
- Enable the developer mode of the gateway.
- Please follow the steps in the wiki: https://github.com/fooxy/homeassistant-aqara/wiki/Enable-dev-mode
-
Download and place aqara.py files in the home-assistant folder like this:
- .homeassistant/custom_components/aqara.py
- .homeassistant/custom_components/sensor/aqara.py
- .homeassistant/custom_components/binary_sensor/aqara.py
-
Add the new platform in the configuration.yaml: lowercase is important, multiple gateways is not supported by now.
aqara: gateway_password: yourgatewaypassword
-
restart the home assistant service, note that it may take several minutes to install the pyCrypto dependency during the first start.
Since until now there is no way to retrieve the configured names from the gateway, Home-Assistant will display each sensor like that:
- sensor.temperature_SENSORID
- sensor.humidity_SENSORID
- binary_sensor.magnet_SENSORID
- binary_sensor.motion_SENSORID
- etc.
To make it readable again, create a customize.yaml file in the home-assistant folder. You can use step 7 https://goo.gl/gEVIrn to identify the sensors.
-
Example
sensor.temperature_158d0000fa3793: friendly_name: Living-Room T sensor.humidity_158d0000fa3793: friendly_name: Living-Room H icon: mdi:water-percent sensor.temperature_158d000108164f: friendly_name: Bedroom 1 T sensor.humidity_158d000108164f: friendly_name: Bedroom 1 H icon: mdi:water-percent ... etc.
-
Add a line in the configuration.yaml:
homeassistant:
name: Home ... time_zone: Europe/Paris customize: !include customize.yaml ```
- Example configuration.yaml
binary_sensor:
- platform: template
sensors:
door:
friendly_name: Frontdoor
value_template: "{{ states.binary_sensor.magnet_158d0001179ae9.state == 'open' }}"
sensor_class: opening
entity_id:
- binary_sensor.magnet_158d0001179ae9
automation:
- alias: FrontDoorClosed
trigger:
platform: state
entity_id: binary_sensor.door
to: 'off'
action:
service: notify.TelegramNotifier
data:
message: Door closed
- alias: FrontDoorOpened
trigger:
platform: state
entity_id: binary_sensor.door
to: 'on'
action:
service: notify.TelegramNotifier
data:
message: Door opened
- multiple gateway support
- include some options in the configuration file : IP, refresh frequency, etc.
- generate a yaml file with discovered devices
- integrate wireless switch, cube, gateway itself (turn on light / radio / etc.)