hass-core/homeassistant/components/zwave_js
Raman Gupta 4a058503ca
Change behavior of Z-Wave JS services (#52941)
* Change behavior of Z-Wave JS services

* pop parameters in for loop

* Update logger message
2021-07-13 01:02:36 -04:00
..
docs
translations [ci skip] Translation update 2021-07-13 00:13:03 +00:00
__init__.py Create zwave_js node status sensor when the node is added (#51850) 2021-06-14 19:31:44 +02:00
addon.py Add zwave_js options flow to reconfigure server (#51840) 2021-06-24 13:15:42 +02:00
api.py Handle FailedCommand exceptions in zwave_js WS API (#52461) 2021-07-13 00:13:43 -04:00
binary_sensor.py Switch to using entity class attributes where possible in zwave_js (#51207) 2021-06-01 10:26:22 +02:00
climate.py Don't raise when setting HVAC mode without a mode ZwaveValue (#52444) 2021-07-06 16:33:07 +02:00
config_flow.py Add zwave_js options flow to reconfigure server (#51840) 2021-06-24 13:15:42 +02:00
const.py Initial support for zwave_js device conditions (#52003) 2021-07-11 21:22:33 -07:00
cover.py Switch to using entity class attributes where possible in zwave_js (#51207) 2021-06-01 10:26:22 +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 Define AddEntitiesCallback type (#49812) 2021-04-29 12:28:14 +02:00
helpers.py Change behavior of Z-Wave JS services (#52941) 2021-07-13 01:02:36 -04:00
light.py Add transition support to zwave_js lights (#52160) 2021-07-09 12:15:20 -04:00
lock.py Migrate to async_get_current_platform everywhere (#50034) 2021-05-03 09:34:28 -07: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 Allow None value return type for Number entity state value (#52302) 2021-06-29 15:07:31 +02:00
README.md
sensor.py Switch to using entity class attributes where possible in zwave_js (#51207) 2021-06-01 10:26:22 +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 entity class attributes where possible in zwave_js (#51207) 2021-06-01 10:26:22 +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.