hass-core/homeassistant/components/zwave_js
2021-10-28 21:28:02 -07:00
..
docs
translations [ci skip] Translation update 2021-10-24 00:12:57 +00:00
triggers Clean up unused loggers (#57662) 2021-10-14 10:03:38 -07:00
__init__.py Adjust DeviceInfo registration on zwave_js (#58391) 2021-10-25 12:05:45 +02:00
addon.py Manage s2 keys in zwave_js (#56783) 2021-09-29 15:04:24 -07:00
api.py Add additional properties to node_status WS cmd (#56927) 2021-10-05 11:23:44 -04:00
binary_sensor.py Add zwave_js binary sensor descriptions (#58641) 2021-10-28 21:28:02 -07:00
climate.py Use assignment expressions 28 (#58189) 2021-10-22 14:06:04 +02:00
config_flow.py Fix zwave_js config flow import step (#56808) 2021-09-30 01:15:05 +02:00
const.py Manage s2 keys in zwave_js (#56783) 2021-09-29 15:04:24 -07:00
cover.py Open and close tilt for Fibaro devices in zwave_js (#58435) 2021-10-28 22:30:34 +02:00
device_action.py Add support for zwave_js device actions (#53038) 2021-09-28 09:06:02 +02:00
device_automation_helpers.py Add support for zwave_js device actions (#53038) 2021-09-28 09:06:02 +02:00
device_condition.py Add support for zwave_js device actions (#53038) 2021-09-28 09:06:02 +02:00
device_trigger.py Use assignment expressions 28 (#58189) 2021-10-22 14:06:04 +02:00
discovery.py Open and close tilt for Fibaro devices in zwave_js (#58435) 2021-10-28 22:30:34 +02:00
discovery_data_template.py Open and close tilt for Fibaro devices in zwave_js (#58435) 2021-10-28 22:30:34 +02:00
entity.py Use DeviceInfo in zwave-js (#58649) 2021-10-28 19:00:12 -05:00
fan.py Switch to using constants wherever possible in zwave_js (#56518) 2021-09-30 02:21:53 +02:00
helpers.py Use assignment expressions 28 (#58189) 2021-10-22 14:06:04 +02:00
light.py Switch to using constants wherever possible in zwave_js (#56518) 2021-09-30 02:21:53 +02:00
lock.py Add support for zwave_js device actions (#53038) 2021-09-28 09:06:02 +02:00
manifest.json Bump zwave-js-server-python to 0.31.3 (#57143) 2021-10-05 22:33:23 +02:00
migrate.py Use assignment expressions 28 (#58189) 2021-10-22 14:06:04 +02:00
number.py Switch to using constants wherever possible in zwave_js (#56518) 2021-09-30 02:21:53 +02:00
README.md
select.py Switch to using constants wherever possible in zwave_js (#56518) 2021-09-30 02:21:53 +02:00
sensor.py Use DeviceInfo in zwave-js (#58649) 2021-10-28 19:00:12 -05:00
services.py Convert val to str when needed while calling zwave_js.set_value (#57216) 2021-10-07 13:22:33 -07:00
services.yaml Add zwave_js.reset_meter service (#53390) 2021-07-28 23:15:27 +02:00
siren.py Bump zwave-js-server-python to 0.29.1 (#55460) 2021-08-30 09:40:56 -07:00
strings.json Add strings for new zwave_js config flow keys (#56844) 2021-09-30 22:32:17 +02:00
switch.py Switch to using constants wherever possible in zwave_js (#56518) 2021-09-30 02:21:53 +02:00
trigger.py Automation trigger info type hint improvements (#55402) 2021-09-04 02:25:51 +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.