hass-core/homeassistant/components/zwave_js
2021-07-13 10:31:49 +02:00
..
docs Add zwave_js dev docs readme (#47621) 2021-03-15 15:08:45 +01:00
translations [ci skip] Translation update 2021-07-13 00:13:03 +00:00
__init__.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
addon.py Add zwave_js options flow to reconfigure server (#51840) 2021-06-24 13:15:42 +02:00
api.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
binary_sensor.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
climate.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
config_flow.py Add zwave_js options flow to reconfigure server (#51840) 2021-06-24 13:15:42 +02:00
const.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
cover.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
device_condition.py Initial support for zwave_js device conditions (#52003) 2021-07-11 21:22:33 -07:00
discovery.py Set zwave_js cover device_class for shutters and blinds (#50643) 2021-05-16 08:26:16 +02:00
discovery_data_template.py Fix no value error for heatit climate entities (#51392) 2021-06-02 21:07:47 -07:00
entity.py Mark entities for dead zwave_js nodes as unavailable (#48017) 2021-07-03 22:06:07 -04:00
fan.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
helpers.py Change behavior of Z-Wave JS services (#52941) 2021-07-13 01:02:36 -04:00
light.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
lock.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
manifest.json Bump zwave-js-server-python to 0.27.1 (#52885) 2021-07-11 16:27:46 -04:00
migrate.py Fix zwave_js migration logic (#52070) 2021-06-21 16:45:47 -04:00
number.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
README.md Add zwave_js dev docs readme (#47621) 2021-03-15 15:08:45 +01:00
sensor.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00
services.py Change behavior of Z-Wave JS services (#52941) 2021-07-13 01:02:36 -04:00
services.yaml Add zwave_js ping node service (#51435) 2021-06-14 16:38:35 -04:00
strings.json Initial support for zwave_js device conditions (#52003) 2021-07-11 21:22:33 -07:00
switch.py Switch to using entry.async_on_remove (#52952) 2021-07-13 10:31:49 +02:00

Z-Wave JS Architecture

This document describes the architecture of Z-Wave JS in Home Assistant and how the integration is connected all the way to the Z-Wave USB stick controller.

Architecture

Connection diagram

alt text

Z-Wave USB stick

Communicates with devices via the Z-Wave radio and stores device pairing.

Z-Wave JS

Represents the USB stick serial protocol as devices.

Z-Wave JS Server

Forward the state of Z-Wave JS over a WebSocket connection.

Z-Wave JS Server Python

Consumes the WebSocket connection and makes the Z-Wave JS state available in Python.

Z-Wave JS integration

Represents Z-Wave devices in Home Assistant and allows control.

Home Assistant

Best home automation platform in the world.

Running Z-Wave JS Server

alt text

Z-Wave JS Server can be run as a standalone Node app.

It can also run as part of Z-Wave JS 2 MQTT, which is also a standalone Node app.

Both apps are available as Home Assistant add-ons. There are also Docker containers etc.