Z-Wave
The Z-Wave integrationIntegrations connect and integrate Home Assistant with your devices, services, and more. [Learn more] allows you to control a Z-Wave network from Home Assistant via the Z-Wave JS
Device compatibility
You do not need a Z-Wave controller that is specifically designed for the Z-Wave integration in Home Assistant. The Z-Wave integration in Home Assistant can be operated with any Z-Wave network with other Z-Wave certified devices from other manufacturers. All mains operated nodes within the network will act as repeaters regardless of vendor to increase reliability of the network.
Getting started
This sections shows you how to set up a Z-Wave JS server and how to add your first Z-Wave device to Home Assistant. It also introduces you to some of the basic terminology.
Z-Wave terminology and Home Assistant
Throughout this documentation, Home Assistant terminology is used. For some of the concepts, the terminology does not correspond to the terminology used in Z-Wave documentation. The table below provides equivalents for some of those terms.
Z-Wave functionality | Home Assistant | Definition |
---|---|---|
inclusion | add | The process of adding a node to the Z-Wave network |
exclusion | remove | The process of removing a node from the Z-Wave network |
replication | copy (not supported in Home Assistant) | The process of copying network information from one controller to another. Not supported in Home Assistant. |
barrier operator | cover | |
window covering | cover | |
multilevel switch | represented by different entity types: light, fan etc. |
Classic inclusion versus SmartStart
Home Assistant supports both classic inclusion and SmartStart. Classic inclusion means you set both the hub and the device to be included into the corresponding mode. The alternative is SmartStart, where the hub is constantly listening for inclusion requests from devices that want to join the network.
Related topics
For more Z-Wave term definitions, refer to the terminology section.
Prerequisites
To run a Z-Wave network, you need the following elements:
- A supported Z-Wave controller. First-time user? For recommendations on what to buy, go here.
- A running Z-Wave JS server.
- An installed Z-Wave integration in Home Assistant.
Setting up a Z-Wave JS server
If you are running Home Assistant Operating SystemHome Assistant OS, the Home Assistant Operating System, is an embedded, minimalistic, operating system designed to run the Home Assistant ecosystem. It is the recommended installation method for most users. [Learn more] or Home Assistant SupervisedHome Assistant Supervised is the full Home Assistant ecosystem, without the Home Assistant Operating System. [Learn more], the easiest way to get started is by using the built-in Z-Wave JS add-on in Home Assistant.
For other ways to setup a Z-Wave server, refer to the advanced installation instructions.
Follow these steps:
- Open the Home Assistant user interface.
- Plug the Z-Wave dongle into the device running Home Assistant.
- Most likely, your dongle will be recognized automatically. On the user interface, you will be asked if you want to set up this device with the Z-Wave JS add-on. Select Submit.
- If your dongle is not recognized, follow these steps:
Manual setup steps
- Browse to your Home Assistant instance.
- Go to Settings > Devices & services.
- In the bottom right, select the
Add Integration button. - From the list, select Z-Wave.
- Follow the instructions on screen to complete the setup.
- Wait for the installation to complete.
- You are prompted for network security keys.
- If you are using Z-Wave for the first time, leave all the fields empty and select Submit. The system will generate network security keys for you.
- If this Z-Wave dongle has already been paired with secure devices, you need to enter the previously used network key as the S0 network key. S2 security keys will be automatically generated for you.
- Make sure that you keep a backup of these keys in a safe place in case you need to move your Z-Wave dongle to another device. Copy and paste them somewhere safe.
- Wait for the Z-Wave JS add-on to start up.
- Once the installation is complete, the Device info of the Z-Wave controller is shown.
- You successfully installed the Z-Wave integration and the Z-Wave JS add-on.
- You can now add devices to the Z-Wave network.
While your Z-Wave mesh is permanently stored on your dongle, the additional metadata is not. When the Z-Wave integration starts up the first time, it will interview your entire Z-Wave network. Depending on the number of devices paired with the Z-Wave dongle, this can take a while. You can speed up this process by manually waking up your battery-powered devices. Most of the time, this is a button press on those devices (see their manual). It is not necessary to exclude and re-include devices from the mesh.
Adding a new device to the Z-Wave network
- In Home Assistant, go to Settings > Devices & services.
- Select the Z-Wave integration. Then select Configure.
- Select Add device.
- The Z-Wave controller is now in inclusion mode.
- Check, if your device supports SmartStart:
- On the packaging, check for the SmartStart label.
- Find the QR code. It can be on the packaging or on the device itself.
- Depending on whether your device supports SmartStart, follow the steps in either option 1 or 2:
-
Option 1: your device supports SmartStart:
- Select Scan QR code and scan the QR code on your device.
- If scanning does not work (for example due to missing HTTPS), paste the QR code content as text from a different QR reader and select Submit.
- Turn the device on. If it was already on, you might need to power-cycle it.
-
Option 2: your device does not support SmartStart:
- Set the device in inclusion mode. Refer to the device manual to see how this is done.
- If your device is included using S2 security, you may be prompted to enter a PIN number provided with your device. Often, this PIN is provided with the documentation and is also printed on the device itself. For more information on secure inclusion, refer to this section.
-
Option 1: your device supports SmartStart:
- The UI should confirm that the device was added. After a short while (seconds to minutes), the entities should also be created.
-
Troubleshooting: If the controller fails to add/find your device, cancel the inclusion process.
- In some cases, it might help to first remove a device (exclusion) before you add it, even when the device has not been added to this Z-Wave network yet.
- Another approach would be to factory reset the device. Refer to the device manual to see how this is done.
Important:
- Do not move your Z-Wave stick to include devices. Moving the controller is no longer necessary and leads to broken routes.
- Do not initiate device inclusion from the Z-Wave stick itself. This is no longer supported.
Removing a device from the Z-Wave network
- In Home Assistant, go to Settings > Devices & services.
- Select the Z-Wave integration. Then, select Configure.
- Select Remove device, then Start exclusion.
- The Z-Wave controller is now in exclusion mode.
- Put the device you want to remove in exclusion mode. Refer to its manual how this is done.
- The UI should confirm that the device was removed and the device and entities will be removed from Home Assistant.
Special Z-Wave entities
The Z-Wave integration provides several special entities, some of which are available for every Z-Wave device, and some of which are conditional based on the device.
Entities available for every Z-Wave device
-
Node status sensor: This sensor shows the node status for a given Z-Wave device. The sensor is disabled by default. The available node statuses are explained in the Z-Wave JS documentation
. They can be used in state change automations. For example to ping a device when it is dead, or refresh values when it wakes up. -
Ping button: This button can be pressed to ping a device. It is an alternative to the
zwave_js.ping
action. -
Controller/node statistics sensors: Z-Wave JS collects statistics about communications between nodes
and the controller . The statistics can be used to troubleshoot RF issues in your environment. These statistics are available in the network configuration and device info panels. But they are also available as sensors which are disabled by default.
Conditional entities
- Button to manually idle notifications: Any Notification Command Class (CC) values on a device that have an idle state will get a corresponding button entity. This button entity can be used to manually idle a notification when it doesn’t automatically clear on its own. A device can have multiple Notification CC values. For example one for detecting smoke and one for detecting carbon monoxide.
Using advanced features (UI only)
While the integration aims to provide as much functionality as possible through existing Home Assistant constructs (entities, states, automations, actions, etc.), there are some features that are only available through the UI.
All of these features can be accessed either in the Z-Wave integration configuration panel or in a Z-Wave device’s device panel.
Integration configuration panel
The following features can be accessed from the integration configuration panel:
- Add device: Allows you to pre-provision a SmartStart device or start the inclusion process for adding a new device to your network.
- Remove device: Starts the exclusion process for removing a device from your network.
- Rebuild network routes: Forces your network to rediscover routes to the controller from each device. This is useful when devices or the controller have moved to a new location, or if you are having significant problems with your network, but it also generates a lot of network traffic and should be used sparingly.
-
Controller statistics
: Provides statistics about communication between the controller and other devices, allowing you to troubleshoot your network’s RF quality. - Third-party data opt-in/out: Allows you to opt-in or out of telemetry that the Z-Wave JS project collects to help inform development decisions, influence manufacturers, etc. This telemetry is disabled by default and has to be opted in to be activated.
Integration menu
Some features can be accessed from the menu of integration itself. As they are not specific to Z-Wave, they are not described here in detail.
- Download diagnostics: Exports a JSON file describing the entities of all devices registered with this integration.
Device panel
Controller
The following features can be accessed from the device panel of a Z-Wave controller:
- Factory reset: Exercise extreme caution when using this action! Once initiated, your controller will be reset to factory settings, it will forget all devices it is paired with, it will establish a new network ID that will prevent any recovery of your old network, and all Z-Wave devices for this network will be removed from Home Assistant. If there are any devices still paired with the controller when it is reset, they will have to go through the exclusion process before they can be re-paired.
Screenshot showing the device panel of a Z-Wave controller.
Network devices
The following features can be accessed from the device panel of any Z-Wave device on your network aside from the controller:
- Configure: Provides an easy way to look up and update configuration parameters for the device. While there is an existing action for setting configuration parameter values, this UI may sometimes be quicker to use for one-off changes.
- Re-interview: Forces the device to go through the interview process again so that Z-Wave-JS can discover all of its capabilities. Can be helpful if you don’t see all the expected entities for your device.
- Rebuild routes: Forces the device to rediscover its optimal route back to the controller. Use this if you think you are experiencing unexpected delays or RF issues with your device. Your device may be less responsive during this process.
- Remove failed: Forces the controller to remove the device from the controller. Can be used when a device has failed and it can’t go through the normal exclusion process.
-
Statistics
: Provides statistics about communication between this device and the controller, allowing you to troubleshoot RF issues with the device. - Update: Updates a device’s firmware using a manually uploaded firmware file. Only some devices support this feature (controllers and devices with the Firmware Update Metadata Command Class).
- Download diagnostics: Exports a JSON file describing the entities of this specific device.
Actions
Action zwave_js.set_config_parameter
This action will update a configuration parameter. To update multiple partial parameters in a single call, use the zwave_js.bulk_set_partial_config_parameters
action.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to set the configuration parameter on. At least one entity_id , device_id , or area_id must be provided. |
device_id |
no | Device ID (or list of device IDs) to set the configuration parameter on. At least one entity_id , device_id , or area_id must be provided. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to set the configuration parameter on. At least one entity_id , device_id , or area_id must be provided. |
parameter |
yes | The parameter number or the name of the property. The name of the property is case sensitive. |
bitmask |
no | The bitmask for a partial parameter in hex (0xff) or decimal (255) format. If the name of the parameter is provided, this is not needed. Cannot be combined with value_size or value_format. |
value |
yes | The target value for the parameter as the integer value or the state label. The state label is case sensitive. |
value_size |
no | The size of the target parameter value, either 1, 2, or 4. Used in combination with value_format when a config parameter is not defined in your device’s configuration file. Cannot be combined with bitmask. |
value_format |
no | The format of the target parameter value, 0 for signed integer, 1 for unsigned integer, 2 for enumerated, 3 for bitfield. Used in combination with value_size when a config parameter is not defined in your device’s configuration file. Cannot be combined with bitmask. |
Examples of setting a single parameter value
Let’s use parameter 31 for this deviceLED 1 Blink Status (bottom)
partial parameter can be set. Note that in places where we are using different values for the same key, the different values are interchangeable across the examples. We can, for instance, use 1
or Blink
interchangeably for the value
in all of the examples.
Example 1:
Example 2:
Example 3:
Action zwave_js.bulk_set_partial_config_parameters
This action will bulk set multiple partial configuration parameters. Be warned that correctly using this action requires advanced knowledge of Z-Wave.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to bulk set partial configuration parameters on. At least one entity_id , device_id , or area_id must be provided. |
device_id |
no | Device ID (or list of device IDs) to bulk set partial configuration parameters on. At least one entity_id , device_id , or area_id must be provided. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to bulk set partial configuration parameters on. At least one entity_id , device_id , or area_id must be provided. |
parameter |
yes | The parameter number of the property. The name of the property is case sensitive. |
value |
yes | Either the raw integer value that you want to set for the entire parameter, or a dictionary where the keys are either the bitmasks (in integer or hex form) or the partial parameter name and the values are the value you want to set on each partial (either the integer value or a named state when applicable). Note that when using a dictionary, and bitmasks that are not provided will be set to their currently cached values. |
Examples of bulk setting partial parameter values
Let’s use parameter 21 for this device0xff
to 127
, 0x7f00
to 10
, and 0x8000
to 1
(or the raw value of 4735
).
When using the dictionary format to map the partial parameter to values, the cached values for the missing partial parameters will be used. So in examples 2, 3, 4, and 5, the action would use the cached value for partial parameters 0xff0000
, 0x3f000000
, and 0x40000000
because new values haven’t been specified. If you send the raw integer value, it is assumed that you have calculated the full value, so in example 1, partial parameters 0xff0000
, 0x3f000000
, and 0x40000000
would all be set to 0
.
Example 1:
Example 2:
Example 3:
Example 4:
Example 5:
Action zwave_js.refresh_value
This action will refresh the value(s) for an entity. This action will generate extra traffic on your Z-Wave network and should be used sparingly. Updates from devices on battery may take some time to be received.
Data attribute | Required | Description |
---|---|---|
entity_id |
yes | Entity or list of entities to refresh values for. |
refresh_all_values |
no | Whether all values should be refreshed. If false , only the primary value will be refreshed. If true , all watched values will be refreshed. |
Action zwave_js.set_value
This action will set a value on a Z-Wave device. It is for advanced use cases where you need to modify the state of a node and can’t do it using native Home Assistant entity functionality. Be warned that correctly using this action requires advanced knowledge of Z-Wave. The action provides minimal validation and blindly calls the Z-Wave JS API, so if you are having trouble using it, it is likely because you are providing an incorrect value somewhere. To set a config parameter, you should use the zwave_js.set_config_parameter
or zwave_js.bulk_set_partial_config_parameters
action instead of this one.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to set the value on. At least one entity_id , device_id , or area_id must be provided. |
device_id |
no | Device ID (or list of device IDs) to set the value on. At least one entity_id , device_id , or area_id must be provided. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to set the value on. At least one entity_id , device_id , or area_id must be provided. |
command_class |
yes | ID of Command Class that you want to set the value for. |
property |
yes | ID of Property that you want to set the value for. |
property_key |
no | ID of Property Key that you want to set the value for. |
endpoint |
no | ID of Endpoint that you want to set the value for. |
value |
yes | The new value that you want to set. |
options |
no | Set value options map. Refer to the Z-Wave JS documentation for more information on what options can be set. |
wait_for_result |
no | Boolean that indicates whether or not to wait for a response from the node. If not included in the payload, the integration will decide whether to wait or not. If set to true , note that the action can take a while if setting a value on an asleep battery device. |
Action zwave_js.multicast_set_value
This action will set a value on multiple Z-Wave devices using multicast. It is for advanced use cases where you need to set the same value on multiple nodes simultaneously. Be warned that correctly using this action requires advanced knowledge of Z-Wave. The action provides minimal validation beyond what is necessary to properly call the Z-Wave JS API, so if you are having trouble using it, it is likely because you are providing an incorrect value somewhere.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to set the value on via multicast. At least two entity_id or device_id must be resolved if not broadcasting the command. |
device_id |
no | Device ID (or list of device IDs) to set the value on via multicast. At least two entity_id or device_id must be resolved if not broadcasting the command. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to set the value on via multicast. At least two entity_id or device_id must be resolved if not broadcasting the command. |
broadcast |
no | Boolean that indicates whether you want the message to be broadcast to all nodes on the network. If you have only one Z-Wave network configured, you do not need to provide a device_id or entity_id when this is set to true. When you have multiple Z-Wave networks configured, you MUST provide at least one device_id or entity_id so the action knows which network to target. |
command_class |
yes | ID of Command Class that you want to set the value for. |
property |
yes | ID of Property that you want to set the value for. |
property_key |
no | ID of Property Key that you want to set the value for. |
endpoint |
no | ID of Endpoint that you want to set the value for. |
value |
yes | The new value that you want to set. |
options |
no | Set value options map. Refer to the Z-Wave JS documentation for more information on what options can be set. |
Action zwave_js.invoke_cc_api
Leverage this action to use the Command Class API directly. In most cases, the zwave_js.set_value
action will accomplish what you need to, but some Command Classes have API commands that can’t be accessed via that action. Refer to the Z-Wave JS Command Class documentation
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to ping. At least one entity_id , device_id , or area_id must be provided. If endpoint is specified, that endpoint will be used to make the CC API call for all devices, otherwise the primary value endpoint will be used for each entity. |
device_id |
no | Device ID (or list of device IDs) to ping. At least one entity_id , device_id , or area_id must be provided. If endpoint is specified, that endpoint will be used to make the CC API call for all devices, otherwise the root endpoint (0) will be used for each device. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to ping. At least one entity_id , device_id , or area_id must be provided. If endpoint is specified, that endpoint will be used to make the CC API call for all devices, otherwise the root endpoint (0) will be used for each zwave_js device in the area. |
command_class |
yes | ID of Command Class that you want to set the value for. |
endpoint |
no | The endpoint to call the CC API against. |
method_name |
yes | The name of the method that is being called from the CC API. |
parameters |
yes | A list of parameters to pass to the CC API method. |
Action zwave_js.refresh_notifications
This action will refresh the notifications of a given type on a device that supports the Notification Command Class.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Entity (or list of entities) to refresh notifications for. At least one entity_id , device_id , or area_id must be provided. |
device_id |
no | Device ID (or list of device IDs) to refresh notifications for. At least one entity_id , device_id , or area_id must be provided. |
area_id |
no | Area ID (or list of area IDs) for devices/entities to refresh notifications for. At least one entity_id , device_id , or area_id must be provided. |
notification_type |
yes | The type of notification to refresh. |
notification_event |
no | The notification event to refresh. |
Action zwave_js.reset_meter
This action will reset the meters on a device that supports the Meter Command Class.
Data attribute | Required | Description |
---|---|---|
entity_id |
yes | Entity (or list of entities) for the meters you want to reset. |
meter_type |
no | If supported by the device, indicates the type of meter to reset. Not all devices support this option. |
value |
no | If supported by the device, indicates the value to reset the meter to. Not all devices support this option. |
Action zwave_js.set_lock_configuration
This action will set the configuration of a lock.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Lock entity or list of entities to set the usercode. |
operation_type |
yes | Lock operation type, one of timed or constant . |
lock_timeout |
no | Seconds until lock mode times out. Should only be used if operation type is timed . |
auto_relock_time |
no | Duration in seconds until lock returns to secure state. Only enforced when operation type is constant . |
hold_and_release_time |
no | Duration in seconds the latch stays retracted. |
twist_assist |
no | Enable Twist Assist. |
block_to_block |
no | Enable block-to-block functionality. |
Action zwave_js.set_lock_usercode
This action will set the usercode of a lock to X at code slot Y. Valid usercodes are at least 4 digits.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Lock entity or list of entities to set the usercode. |
code_slot |
yes | The code slot to set the usercode into. |
usercode |
yes | The code to set in the slot. |
Action zwave_js.clear_lock_usercode
This action will clear the usercode of a lock in code slot X. Valid code slots are between 1-254.
Data attribute | Required | Description |
---|---|---|
entity_id |
no | Lock entity or list of entities to clear the usercode. |
code_slot |
yes | The code slot to clear the usercode from. |
Events
There are two types of events that are fired, notification events and value notification events. You can test what events come in using the event developer tools in Home Assistant and subscribing to the zwave_js_notification
or zwave_js_value_notification
events respectively. Once you know what the event data looks like, you can use this to create automations.
Node events (Notification)
Check the Z-Wave JS notification event documentationzwave_js_notification
event type.
Notification event data can be used to trigger automations, both in the automation UI and in YAML, using the event platform. Check the details of an event by subscribing to the zwave_js_notification event in the Developers Tools.
Notification Command Class
These are notification events fired by devices using the Notification Command Class. The parameters
attribute in the example below is optional, and when it is included, the keys in the attribute will vary depending on the event.
Multilevel Switch Command Class
These are notification events fired by devices using the Multilevel Switch Command Class. There are events for start level change and stop level change. These would typically be used in a device like the Aeotec Nano Dimmer with an external switch to respond to long button presses.
Start level change
Stop level change
Entry Control Command Class
These are notification events fired by devices using the Entry Control Command Class.
Scene events (Value Notification)
Value Notifications are used for stateless values, like Central Scenes
and Scene Activation
. These events fire with the zwave_js_value_notification
event type.
Value Notification example:
Value updated events
Due to some devices not following the Z-Wave Specification, there are scenarios where a device will send a value update but a state change won’t be detected in Home Assistant. To address the gap, the zwave_js_value_updated
event can be listened to to capture any value updates that are received by an affected entity. This event is enabled on a per device and per entity domain basis, and the entities will have assumed_state
set to true
. This change will affect how the UI for these entities look; if you’d like the UI to match other entities of the same type where assumed_state
is not set to true
, you can override the setting via entity customization.
The following devices currently support this event:
Make | Model | Entity Domain |
---|---|---|
Vision Security | ZL7432 In Wall Dual Relay Switch | switch |
Value Updated example:
This event can be used to trigger a refresh of values when the new state needs to be retrieved. Here’s an example automation:
Automations
The Z-Wave
integration provides its own trigger platforms which can be used in automations.
zwave_js.value_updated
This trigger platform can be used to trigger automations on any Z-Wave JS value update, including Z-Wave JS values that aren’t supported in Home Assistant via entities. While they can’t be authored from the automation UI, they can be authored in YAML directly in your configuration.yaml
.
Example automation trigger configuration
Available trigger data
In addition to the standard automation trigger data, the zwave_js.value_updated
trigger platform has additional trigger data available for use.
Template variable | Data |
---|---|
trigger.device_id |
Device ID for the device in the device registry. |
trigger.node_id |
Z-Wave node ID. |
trigger.command_class |
Command Class ID. |
trigger.command_class_name |
Command Class name. |
trigger.property |
Z-Wave Value’s property. |
trigger.property_name |
Z-Wave Value’s property name. |
trigger.property_key |
Z-Wave Value’s property key. |
trigger.property_key_name |
Z-Wave Value’s property key name. |
trigger.endpoint |
Z-Wave Value’s endpoint. |
trigger.previous_value |
The previous value for this Z-Wave value (translated to a state name when possible). |
trigger.previous_value_raw |
The raw previous value for this Z-Wave value (the key of the state when a state is named). |
trigger.current_value |
The current value for this Z-Wave value (translated to a state name when possible). |
trigger.current_value_raw |
The raw current value for this Z-Wave value (the key of the state when a state is named). |
zwave_js.event
This trigger platform can be used to trigger automations on any Z-Wave JS controller, driver, or node event, including events that may not be handled by Home Assistant automatically. Refer to the linked Z-Wave JS documentation
There is strict validation in place based on all known event types, so if you come across an event type that isn’t supported, please open a GitHub issue in the home-assistant/core
repository.
Example automation trigger configuration
Available trigger data
In addition to the standard automation trigger data, the zwave_js.event
trigger platform has additional trigger data available for use.
Template variable | Data |
---|---|
trigger.device_id |
Device ID for the device in the device registry (only included for node events). |
trigger.node_id |
Z-Wave node ID (only included for node events). |
trigger.event_source |
Source of event (node, controller, or driver). |
trigger.event |
Name of event. |
trigger.event_data |
Any data included in the event. |
Advanced installation instructions
If you are using Home Assistant Container, Home Assistant Core, or you don’t want to use the built-in Z-Wave JS Server add-on, you will need to run the Z-Wave JS server yourself, to which the Z-Wave integration will connect.
Running Z-Wave JS Server
This application provides the connection between your Z-Wave USB stick and Home Assistant. The Home Assistant Z-Wave integration connects to this server via a WebSocket connection. You need to run this Z-Wave JS server before you can use the integration.
There are multiple ways to run this server: The chart below illustrates Options 1 and 2, which are available for Home Assistant OS only.
Option 1: The official Z-Wave JS add-on, as described above
This option is only available for Home Assistant Operating SystemHome Assistant OS, the Home Assistant Operating System, is an embedded, minimalistic, operating system designed to run the Home Assistant ecosystem. It is the recommended installation method for most users. [Learn more] (the recommended installation type) and Home Assistant SupervisedHome Assistant Supervised is the full Home Assistant ecosystem, without the Home Assistant Operating System. [Learn more] installations.
This add-on can only be configured via the built-in Z-Wave control panel in Home Assistant. If you followed the standard installation procedure, this is how you are running the Z-Wave JS server.
Option 2: The Z-Wave JS UI add-on installed from the community add-on store
This option is only available for Home Assistant Operating SystemHome Assistant OS, the Home Assistant Operating System, is an embedded, minimalistic, operating system designed to run the Home Assistant ecosystem. It is the recommended installation method for most users. [Learn more] (the recommended installation type) and Home Assistant SupervisedHome Assistant Supervised is the full Home Assistant ecosystem, without the Home Assistant Operating System. [Learn more] installations.
This add-on includes the Z-Wave JS Server as part of the Z-Wave JS UI application. The Z-Wave network can be configured via the built-in Z-Wave control panel in Home Assistant and alternatively via the Z-Wave control panel built into Z-Wave JS UI. It provides you with a full-fledged, attractive, and feature-complete UI to manage your Z-Wave nodes and settings, which may support more advanced use cases as development continues on the Z-Wave control panel.
Option 3: The Z-Wave JS UI Docker container
This is the recommended approach if you’re running Home Assistant Container. See the Z-Wave JS UI documentation
This method provides the same server application and UI as the Z-Wave JS UI add-on. After installing the Docker image, make sure you enable the WS Server in the Home Assistant section of Settings page.
Option 4: Run the Z-Wave JS server yourself
This is considered a very advanced use case. In this case you run the Z-Wave JS Server or Z-Wave JS UI NodeJS application directly. Installation and maintaining this is out of scope for this document. See the Z-Wave JS server
Supported Z-Wave dongle. The Z-Wave controller dongle should be connected to the same host as where the Z-Wave JS server is running. In the configuration for the Z-Wave JS server, you need to provide the path to this stick. It’s recommended to use the /dev/serial-by-id/yourdevice
version of the path to your stick, to make sure the path doesn’t change over reboots. The most common known path is /dev/serial/by-id/usb-0658_0200-if00
.
Network keys are used to connect securely to compatible devices. The network keys consist of 32 hexadecimal characters, for example, 2232666D100F795E5BB17F0A1BB7A146
(do not use this one, pick a random one). Without network keys security enabled devices cannot be added securely and will not function correctly. You must provide these network keys in the configuration part of the Z-Wave JS Server.
For new installations, unique default keys will be auto-generated for you by the Z-Wave JS add-on. You can also generate those network keys in the Settings section of Z-Wave JS UI.
Make sure that you keep a backup of these keys in a safe place. You will need to enter the same keys to be able to access securely paired devices.
Installing and configuring the Z-Wave integration in Home Assistant
Once you have the Z-Wave JS server up and running, you need to install and configure the integration in Home Assistant (as described above).
If you’re running full Home Assistant with supervisor, you will be presented with a dialog that asks if you want to use the Z-Wave JS Supervisor add-on. You must uncheck this box if you are running the Z-Wave JS server in any manner other than the official Z-Wave JS add-on, including using Z-Wave JS UI add-on.
If you’re not running the supervisor or you’ve unchecked the above-mentioned box, you will be asked to enter a WebSocket URL (defaults to ws://localhost:3000). It is very important that you fill in the correct (Docker) IP/hostname here. For example for the Z-Wave JS UI add-on this is ws://a0d7b954-zwavejs2mqtt:3000
.
FAQ: Supported devices and Command Classes
For a list of supported devices, refer to the Z-Wave JS device database
While there is support for the most common devices, some Command Classes are not yet (fully) implemented in Z-Wave JS. You can track the status here
You can also check the list of Z-Wave Command Classes Home Assistant responds to when queried towards the end of this page.
You can also keep track of the road map for the Z-Wave integration here
FAQ: Installation and configuration
Which Z-Wave controller should I buy?
Z-Wave supports all known 500 and 700 series Z-Wave controllers. If you are just starting out, we recommend that you purchase a 700 series controller (with firmware updated to >=7.17.2).
For more information, see Supported Z-Wave dongles
Why was I (not) automatically prompted to install Z-Wave?
Some Z-Wave USB sticks can be auto-discovered, which can simplify the Z-Wave setup process. The following devices have been tested with discovery, and offer a quick setup experience; however, these are not all of the devices supported by Z-Wave:
Device | Identifier | Vendor |
---|---|---|
Aeotec Z-Stick Gen5+ | 0658:0200 | https://aeotec.com/products/aeotec-z-stick-gen5/ |
Nortek HUSBZB-1 | 10C4:8A2A | https://www.nortekcontrol.com/products/2gig/husbzb-1-gocontrol-quickstick-combo/ |
Zooz ZST10 | 10C4:EA60 | https://www.getzooz.com/zooz-zst10-s2-stick/ |
Z-WaveMe UZB | 0658:0200 | https://z-wave.me/products/uzb/ |
Additional devices may be discoverable, however only devices that have been confirmed discoverable are listed above.
What happened to Zwavejs2Mqtt or the Z-Wave JS to MQTT add-on?
Zwavejs2Mqtt was renamed Z-Wave JS UI in September 2022. They are synonymous with no difference between their capabilities.
Can I switch between Z-Wave JS and Z-Wave JS UI?
You can switch between the official Z-Wave JS add-on and the Z-Wave JS UI add-on. However, but you cannot run them both at the same time. Only one of them can be active at the same time.
How to switch between Z-Wave JS and Z-Wave JS UI?
To switch between the official Z-Wave JS add-on and the Z-Wave JS UI add-on, follow these steps:
Switching does not require renaming your devices.
-
Disable the Z-Wave integration. Do not remove the Z-Wave integration or you will lose all device and entity naming. This will automatically stop the official Z-Wave JS add-on.
-
Note your network security keys from the official add-on.
-
Install and start the Z-Wave JS UI add-on.
-
Configure the Z-Wave JS UI add-on with the added control panel, including setting the location of your Z-Wave device and the network security keys.
-
Add the Z-Wave integration again (even though it is still installed), and uncheck the “Use the Z-Wave JS Supervisor add-on”. Enter the correct address for the community add-on in the URL field in the next step.
-
Uninstall the official Z-Wave JS add-on.
-
Enable the Z-Wave integration.
What’s the benefit of using Z-Wave JS UI add-on?
You might wonder what the benefit is of using the Z-Wave JS UI add-on instead of the official add-on. The official add-on provides the Z-Wave Server in its bare minimum variant, just enough to serve the Home Assistant integration.
The Z-Wave JS UI project includes the Z-Wave JS Server for convenience but also provides a Z-Wave control panel and the ability to serve your Z-Wave network to MQTT. This allows you to use the control panel, and if you so choose, to also use MQTT at the same time. For example, some users may use MQTT to interact with Z-Wave from other devices, while the Home Assistant integration still works (as long as you keep the WS Server enabled in Z-Wave JS UI).
Z-Wave JS UI provides discovery of HA devices on its own too, now I’m confused
Correct, the Z-Wave JS UI project existed before Home Assistant had plans to move to the Z-Wave JS Driver. You should use the integration for device discovery and not the MQTT discovery provided by Z-Wave JS UI.
Can I run Z-Wave JS UI only for the control panel and nothing else?
Sure, in the settings of Z-Wave JS UI, make sure to enable “WS Server” and disable “Gateway”.
Should I name my devices in Home Assistant, or in Z-Wave JS UI?
Ultimately, this is a personal decision. If you provide a name or location for a device in the Z-Wave JS UI, that name will be imported into Home Assistant when the integration is reloaded or Home Assistant is restarted. Any entity names, however, will not change if the device has already been set up by Home Assistant. Names set in Z-Wave JS UI will not overwrite changes that have already been made in Home Assistant.
Names set in Home Assistant will not import into Z-Wave JS UI.
Should I use Secure Inclusion?
That depends. There are two generations of Z-Wave encryption, Security S0, and Security S2. Both provide encryption and allow detecting packet corruption.
Security S0 imposes significant additional traffic on your mesh and is recommended only for older devices that do not support Security S2 but require encryption to work, such as door locks.
Security S2 does not impose additional network traffic and provides additional benefits. For example, end devices using S2 require the hub to report whether it has received and understood their reports.
By default, Z-Wave prefers Security S2, if supported. Security S0 is used only when absolutely necessary.
Where can I see the security keys in the Z-Wave JS add-on?
After the initial setup of the Z-Wave controller, you can view the security keys in the Z-Wave JS add-on. Go to Settings > Add-ons > Z-Wave JS and open the Configuration tab. You can now see the three S2 keys and the S0 key. The network security key is a legacy configuration setting, identical to the S0 key.
FAQ: Troubleshooting topics
I’m having a problem, what to do first?
Many reported issues result from RF interference caused by the system’s USB ports. This can manifest in many ways, including devices that won’t include at all, devices that won’t include securely, sensors with erroneous values (packets corrupted), delayed control of devices, or no ability to control devices.
All users are encouraged to use a USB extension cable to prevent such interference. Please try such a cable before opening an issue or requesting support on Discord. It will nearly always be the first troubleshooting step that we ask you to take anyway.
After ensuring you are using an extension cable, rebuild network routes.
The combination of these two steps corrects a large number of reported difficulties.
I have an Aeotec Gen5 controller, and it isn’t detected on my Raspberry Pi 4?
The first-generation Gen5 controller has a known bug when plugged into a Pi 4 and possibly other systems. Aeotec released the Gen5+ stick to correct this bug. Gen5 users can plug their sticks into a USB 2.0 hub in order to overcome the issue.
I do not see any entities created for my device in Home Assistant
Entities will be created only after the node is ready (the interview is completed). Also, note that some devices (like button remotes) do not create any entities but will only provide events when a button is pressed. See the events section on how to handle those events in your automations.
If you are certain that your device should have entities and you do not see them (even after a restart of Home Assistant Core), create an issue about your problem on the GitHub issue tracker.
My device doesn’t automatically update its status in HA if I control it manually
Your device might not send automatic status updates to the controller. While the best advice would be to update to recent Z-Wave Plus devices, there is a workaround with active polling (request the status).
Z-Wave does not automatically poll devices on a regular basis. Polling can quickly lead to network congestion and should be used very sparingly and only where necessary.
-
We provide a
zwave_js.refresh_value
action to allow you to manually poll a value, for example from an automation that only polls a device when there is motion in that same room. If you really need polling, you can enable this in Z-Wave JS UI but not in the official add-on. -
Z-Wave JS UI allows you to configure scheduled polling on a per-value basis, which you can use to keep certain values updated. It also allows you to poll individual values on-demand from your automations, which should be preferred over blindly polling all the time if possible.
Polling should only be used as a last resort. You must use it with care and accept the negative impact on your network. Z-Wave is a very low speed network and poll requests can easily flood your network and slow down your commands.
My device is recognized as Unknown Manufacturer and/or some functions don’t work with the Z-Wave integration
When your device is not yet fully interviewed, this info will not yet be present. So make sure your device is interviewed at least once.
If the interview is complete, then the device does not yet have a device file for Z-Wave JS. Unlike other Z-Wave drivers, your device may very well work as intended even without such a file. If your device not fully supported, consider contributing the device configuration file
How do I get a dump of the current network state?
When trying to determine why something isn’t working as you expect, or when reporting an issue with the integration, it is helpful to know what Z-Wave JS sees as the current state of your Z-Wave network. To get a dump of your current network state, follow these steps:
- Go to Settings > Devices & services.
- Select the Z-Wave integration. Then, select the three dots.
- From the dropdown menu, select Download diagnostics.
How do I address interference issues?
Many users have reported issues with interference when the USB stick was directly connected to the machine (proximity). If you are having issues, try to use a short USB 2.0 A (male to female) extension cord.
How do I access the Z-Wave logs?
The easy way
Enable Z-Wave JS logging
- Go to the Z-Wave integration panel:
- Select
Enable debug logging
on the left-hand side of the screen.
The log level will be set to debug
for the integration, library, and optionally the driver (if the driver log level is not already set to verbose
, debug
, or silly
), and all Z-Wave JS logs will be added to the Home Assistant logs.
Disable Z-Wave JS logging
- Go to the Z-Wave integration panel:
- Select
Disable debug logging
on the left-hand side of the screen.
The log level will be reset to its previous value for the integration, library, and driver, and the Home Assistant frontend will automatically send you the Z-Wave logs generated during that time period for download.
The advanced way
Enable Z-Wave JS logging manually, or via an automation
Set the log level for zwave_js_server
to debug
. This can either be done in your configuration.yaml
in the logger
section, or using the logger.set_level
action. When the integration detects that the log level has been set to debug
, it will also set the Z-Wave JS logs to debug
if the level isn’t already verbose
, debug
, or silly
and will include those logs in the Home Assistant logs. The Z-Wave JS logs can be found under the logger name zwave_js_server.server
.
Disable Z-Wave JS logging manually, or via an automation
Set the log level for zwave_js_server
to a level higher than debug
. This can either be done in your configuration.yaml
in the logger
section, or using the logger.set_level
action. The Z-Wave JS logs will no longer be included in the Home Assistant logs, and if the log level of Z-Wave JS was changed by the integration, it will automatically change back to its original level.
Unsupported functionality
This sections lists functionality that is available in Z-Wave but that is not currently supported in Home Assistant.
Setting the controller into learn mode to receive network information
In Home Assistant, it is currently not possible to set the Z-Wave controller into learn mode to receive network information from another controller.
Including / excluding a controller in an existing network using classic inclusion
A Z-Wave controller that manages an empty network can also join a different network and act as a secondary controller there. However, with Home Assistant, this is not possible. Home Assistant does not allow the Z-Wave controller to join another network, because Home Assistant acts as the central hub.
Z-Wave association groups
In Home Assistant, a single association group is implemented:
- Group 1: This is an association group that includes only one device. It is used after a factory reset, to send a Device Reset Locally Notification.
This association group is used when Home Assistant resets the Z-Wave controller.
Under normal circumstances, it is not necessary to add a device to this group.
Z-Wave Command Classes Home Assistant responds to when queried
The following table lists the Command Classes together with the implemented version and required security class. These are the Command Classes that Home Assistant will respond to when queried by other devices.
Command Class | Version | Security Class |
---|---|---|
Association | 4 | Highest granted |
Association Group Information | 3 | Highest granted |
CRC-16 Encapsulation | 1 | None |
Device Reset Locally | 1 | Highest granted |
Firmware Update Meta Data | 8 | Highest granted |
Inclusion Controller | 1 | None |
Indicator | 4 | Highest granted |
Manufacturer Specific | 2 | Highest granted |
Multi Channel Association | 5 | Highest granted |
Multi Command | 1 | None |
Power Level | 1 | Highest granted |
Security | 1 | None |
Security 2 | 1 | None |
Supervision | 2 | None |
Transport Service | 2 | None |
Version | 3 | Highest granted |
Z-Wave Plus Info | 2 | None |
Home Assistant and Z-Wave JS will never return a “Working” or “Fail” status for a valid and supported command of the Supervision Command Class.
Z-Wave terminology
This section explains some Z-Wave terms and concepts you might find in Z-Wave product documentation.
Association group
An association in Z-Wave terminology is when two or more Z-Wave products communicate directly. This enables devices to communicate with each other without the need to communicate via a hub, or to send unsolicited reports to the central hub.
An association group in Z-Wave terminology is a group of devices that another one will send commands to in certain situations. Association groups and their functionality are specific to the device that sends the commands. Refer to the device manual for details.
SmartStart
SmartStart enabled products can be added into a Z-Wave network by scanning the Z-Wave QR Code present on the product with a controller providing SmartStart inclusion. No further action is required and the SmartStart product will be added automatically within 10 minutes of being switched on in the network vicinity. Not all devices support SmartStart. Some devices require classic inclusion. For documentation on adding a device to Home Assistant, refer to adding a new device to the Z-Wave network.
Terminology mapping table
For some of the concepts, the terminology used in Home Assistant does not correspond to the terminology used in Z-Wave documentation. Refer to the terminology mapping table for a list of term equivalents.