- Generate Zwave Network Key Random Generator
- Generate Zwave Network Key Random Password
- Network Key Mac
Z-Wave Settings
It’s more an issue of /dev/random blocking until there’s sufficient entropy is built up to generate the secure key. @hardoverflow You could easily prove or disprove this by checking for the existence of the zwave network key. In HABmin, go to the Z-Wave Serial Controller thing. About Random Username Generator Tool. The network encryption key size is 128-bit which is essentially 16 decimal values between 0 and 255 or 16 hexadecimal values between 0x00and 0xFF. If you need to transform your decimals to hexadecimals (or vice versa) please use a converter.Example: 92 (decimal) would become 5C.
The purpose of this page is to give you access to all the z-wave settings that can be changed on the unit. The Z-Wave Settings page is composed of three sections :
- Options
- Repair
- Advanced
1 Options
This page allows you to see all the details about your z-wave chip and the changes that you can make.
The page will allow you to see the following information :
- Version : 3.20 L:1 - the current z-wave version installed on the unit- Locale - the frequency of the z-wave chip, which can be :
a. EU - 868.42 MHz b. US - 908.42 MHz c. AU - 921.42 MHz d. RU - 869.0 MHz e. IN - 865.2 MHz f. JP - 922-926 MHz
- HouseID/Node - will show you the current z-wave network id and the node shows if it’s a primary or secondary z-wave network.As an example : House: 49a6 Node 1 Suc 0
- Role - will show you the role of your z-wave network if it’s primary or a secondary controllera. the network is primary : 1. for version 3.20 : Master SIS:NO PRI:YES2. for version 2.78 : Master SIS:YES PRI:YESb. the network is secondary : Master SIS:NO PRI:NO
- Last update - last time the z-wave chip was updated
- Last Z-Wave network backup - last time the Z-Wave network was backed up.
- Port - the port the unit accesses the z-wave chip, and it can be : a. for internal chip : /dev/ttyS0 b. for USB Z-wave Dongle connected : /dev/ttyUSB0
The page will allow you to select the following options :
a. By default Vera should automatically configure devices - this option will allow the unit to automatically reconfigure your z-wave devices, when it runs a healing session.
b. Use Z-Wave version 3.20 instead of 2.78 - allows you the possibility to downgrade to Z-Wave version 2.78 which is compatible with older z-wave devices.
c. Use Vera routing instead of Z-Wave (requires 4.5) - allows the unit to use it’s own algorithm to route the z-wave network. This will overwrite the standard z-wave routing.
d. Limit neighbors to Z-Wave discovery (requires Vera routing) - is dependent on Vera routing and will make each nodes see the ones nearby and not rely on the ones that are further away.
e. Poll nodes - determines that the unit will poll all the z-wave nodes from the z-wave network.
The page will allow you to modify the polling interval for your unit :
1. Number of seconds to wait to start polling - how much time in seconds the unit will wait until it starts to poll the z-wave devices. By default it’s set to 20 seconds.
2. Only poll a node if the Z-Wave network is idle at least - when a node will be polled if the Z-Wave network is idle. By default it’s set to 10 seconds.
3. Unless specified otherwise, poll each node at most once every - how often the unit will poll a Z-Wave device at most in the specified interval. By default it’s set to 60 seconds.
4. Poll a node every - how often the unit will poll a Z-Wave device in the specified interval. By default it’s set to 30 seconds.
2 Repair
The purpose of this page is to allow the end-user to repair his z-wave network if he encounters trouble with the z-wave network. This can repair and diagnose the problem.The Z-Wave network repair will allow the following options to be set before it can be run :
a. How long Mios should wait for battery operated devices to wake up:During the first part of the heal network, Mios will attempt to locate all the devices on the network. Many battery operated devices, like sensors, will not respond except at periodic wakeup intervals. Indicate how long Mios should wait for any battery operated devices to wake up. 60 minutes is usually safe since most battery operated devices wakeup every 30-60 minutes by default.
b. You can tell the unit to reconfigure all the devices:If you leave it checked, the green status icons will turn blue as the unit re-configures the devices, but, when the test is completed, the icons should be green again.
c. Indicate how long the unit should run a stress test on the network :During this time the unit will constantly send data to all your Z-Wave nodes and measure the delay and accuracy of their responses. The unit will go through all the devices one by one and have each device broadcast signals, and all the other devices around record those signals, and, in turn, the map gets rebuilt. At the same time, the 'Device is Configured' flags are reset, meaning the unit will attempt to re-configure your devices again. The progress of the healing can be viewed on the tooltip.
Once the healing process is complete you will be able to see a heal report.The report will show you all your z-wave devices and a star rating for how strong the z-wave signal is for each device.The report will indicate for each device if it was configured or not.
When the heal report is first viewed you will see two options that will run a z-wave network heal with or without a stress-test to generate a report.
NOTE: Heal network can take hours to complete. So it's best to let it run overnight. Because this generates a lot of Z-Wave traffic, your Z-Wave devices may respond very slowly if you try to use them while the test is running. If you have battery-operated devices that are always listening for commands, called FLiRS, like the Schlage LiNK door lock, the testing will use up some of their battery.
3. Advanced
This page will allow you to do the following actions :
a. Reset Z-Wave network - this option will reset the Z-Wave chip of your unit, and it will change the Z-Wave network’s HouseID. This option should be used with caution as it will wipe the Z-Wave network and all the previously paired Z-Wave devices will be removed.
b. Copy Z-Wave network from a master controller - this option will allow the Vera unit to copy the z-wave network from a Master Z-wave controller, thus making the unit a Secondary Z-Wave controller.
c. Controller shift - this option will transfer the state of the unit from primary to secondary to a different z-wave controller.
d. Reset Z-Wave chip - this option will reset the z-wave chip of the unit.
e. Get network update from SUC/SIS - when the unit it’s set as a secondary z-wave controller, this option will update the Z-Wave network from the Master controller.
f. Backup Z-Wave network - this option will start the backup of the z-wave chip so it can be saved to restore the unit to the current state from the unit’s backup.
g. Hack to convert 2.78 to 3.20 - This option will migrate your unit to version 4.52 of the z-wave chip. When the z-wave chip is upgraded from version 2.78 to 3.20 you will have to use this option to update the Role of your z-wave chip.
This Z-Wave integration is deprecated and replaced with a new implementation based on Z-Wave JS; it’s currently in beta, and you can try it now.
Z-Wave can be configured using the Z-Wave Integration in the Configuration menu, or manually using an entry in configuration.yaml
Configuration
Configuration Variables
The port where your device is connected to your Home Assistant host. Z-Wave sticks will generally be /dev/ttyACM0
and GPIO hats will generally be /dev/ttyAMA0
.
The 16-byte network key in the form '0x01, 0x02...'
used in order to connect securely to compatible devices. It is recommended that a network key is configured as security enabled devices may not function correctly if they are not added securely.
The path to the Python OpenZWave configuration files.
Default:the ‘config’ that is installed by python-openzwave
The time period in milliseconds between polls of a nodes value. Be careful about using polling values below 30000 (30 seconds) as polling can flood the Z-Wave network and cause problems.
Print verbose Z-Wave info to log.
Allows enabling auto Z-Wave heal at midnight. Warning, this is inefficient and should not be used.
This attribute contains node-specific override values. NOTE: This needs to be specified if you are going to use any of the following options. See Customizing devices and services for the format.
Ignore this entity completely. It won’t be shown in the Web Interface and no events are generated for it.
Enables polling of a value and sets the frequency of polling (0=none, 1=every time through the list, 2=every other time, etc). If not specified then your device will not be polled.
Enable refreshing of the node value. Only the light integration uses this.
Specify the delay for refreshing of node value. Only the light integration uses this.
Inverts function of the open and close buttons for the cover domain. This will not invert the position and state reporting.
Inverts the percentage of the position for the cover domain. This will invert the position and state reporting.
Network Key
Security Z-Wave devices require a network key before being added to the network using the Add Secure Node button in the Z-Wave Network Management card. You must set the network_key configuration variable to use a network key before adding these devices.
An easy script to generate a random key:
You can also use sites like this one to generate the required data, just remember to put 0x
before each pair of characters and a ,
between them:
Ensure you keep a backup of this key. If you have to rebuild your system and don’t have a backup of this key, you won’t be able to reconnect to any security devices. This may mean you have to do a factory reset on those devices, and your controller, before rebuilding your Z-Wave network.
First Run
On platforms other than Home Assistant and Docker, the compilation and installation of python-openzwave happens when you first enable the Z-Wave component, and can take half an hour or more on a Raspberry Pi. When you upgrade Home Assistant and python-openzwave is also upgraded, this will also result in a delay while the new version is compiled and installed.
The first run after adding a device is when the zwave
integration will take time to initialize the entities, some entities may appear with incomplete names. Running a network heal may speed up this process.
Platform specific instructions
Home Assistant
You do not need to install any software to use Z-Wave.
If the path of /dev/ttyACM0
doesn’t work, look in the System section of the Supervisor menu. There you’ll find a Hardware button which will list all the hardware found.
You can also check what hardware has been found using the ha
command:
If you did an alternative install of Home Assistant on Linux (e.g., installing Ubuntu, then Docker, then Home Assistant Supervised) then the modemmanager
package will interfere with any Z-Wave (or Zigbee) stick and should be removed or disabled in the host OS. Failure to do so will result in random failures of those components, e.g., dead or unreachable Z-Wave nodes, most notably right after Home Assistant restarts. Connect to your host OS via SSH, then you can disable with sudo systemctl disable ModemManager
and remove with sudo apt-get purge modemmanager
(commands are for Debian/Ubuntu).
Docker
You do not need to install any software to use Z-Wave.
To enable access to the Z-Wave stick, add --device=/dev/ttyACM0
to the docker
command that starts your container, for example:
If the path of /dev/ttyACM0
doesn’t work then you can find the path of the stick by disconnecting and then reconnecting it, and running the following in the Docker host:
The modemmanager
package will interfere with any Z-Wave (or Zigbee) stick and should be removed or disabled. Failure to do so will result in random failures of those components. For example you can disable with sudo systemctl disable ModemManager
and remove with sudo apt-get purge modemmanager
Community install methods
Raspberry Pi specific
On the Raspberry Pi you will need to enable the serial interface in the raspi-config
tool before you can add Z-Wave to Home Assistant. Make sure to reboot the Raspberry Pi for the setting to take effect.
Linux with Home Assistant Core
On Debian Linux platforms there are dependencies you will need to have installed ahead of time (included in systemd-devel
on Fedora/RHEL systems):
You may also have to install the Python development libraries for your version of Python. For example libpython3.6-dev
, and possibly python3.6-dev
if you’re using Python 3.6.
Finding the controller path
To find the path of your Z-Wave USB stick, disconnect it and then reconnect it to your system and run:
That will give you a line that looks something like this:
Where the date and time displayed is approximately the time you connected the USB stick or module (it may also be something like /dev/ttyAMA0
or /dev/ttyUSB0
). The number will be zero for the first device connected, and higher numbers for later devices.
Or, if there is no result, try to find detailed USB connection info with:
If Home Assistant (hass
) runs with another user (e.g., homeassistant
) you need to give access to the stick with:
The output from ls -ltr
above contains the following information:
- The device type is
c
(character special). - The permissions are
rw-rw----
, meaning only the owner and group can read and write to it. - There is only
1
link to the file. - It is owned by
root
and can be accessed by members of the groupdialout
. - It has a major device number of
204
, and a minor device number of64
. - The device was connected at
10:25
on21 September
. - The device is
/dev/ttyUSB0
.
macOS
When installing on macOS you may have to also run the command below ahead of time, replace “x.x” with the version of Python ($ python3 --version
) you have installed.
On macOS you can find the USB stick with:
Troubleshooting
Device path changes
If your device path changes when you restart, see this guide on fixing it.
Random unreachable Z-Wave nodes: ModemManager interference
If this applies to your situation:
- Some or all Z-Wave nodes are unreachable after restarting Home Assistant; not necessarily after every restart but seemingly random.
- The Z-Wave stick stops responding, needs to be re-plugged or Home Assistant needs a restart to get Z-Wave back.
- Your host OS is Debian-based/Ubuntu (for example: you installed Ubuntu, then Docker, then Hass.io).
Generate Zwave Network Key Random Generator
Then chances are high that the ModemManager in the host OS is causing the issue, claiming or interfering with the USB Z-Wave stick like the much used Aeotec ones. In this case you need to disable ModemManager.
Connect to your host OS (e.g., Ubuntu) through SSH, then execute the following command on your host system to disable the ModemManager:
Component could not be set up
Sometimes the device may not be accessible and you’ll get an error message upon startup about not being able to set up Z-Wave. Run the following command for your device path (here we’re using /dev/ttyAMA0
for our Razberry board):
You should then see something like this:
The important pieces are the first piece crw-rw----
and the group dialout
. If those are different then, for your device path, run:
Check too that the account you’re running Home Assistant as is in the dialout
group. For instance, if you’re using homeassistant
:
That should include dialout
, if it doesn’t then:
Unable to install Python Openzwave
If you’re getting errors like:
Then the problem is that you’re missing libudev-dev
(or the equivalent for your distribution), please install it.
Random failures
If you’re having random failures of the mesh, devices going missing, things randomly not working, check your OZW_Log.txt
for the following messages:
If you see any of these messages repeated in the log then probably you’ve got something else running that’s also using the Z-Wave controller. That might mean you’ve also got the OpenZ-Wave control panel (ozwcp) running, a second instance of Home Assistant or something else. You need to stop that other process to resolve this.
Generate Zwave Network Key Random Password
Changing device paths
Configurations using udev
can experience race conditions in creating device paths such that they change on reboot. This can cause a device to appear to change between /dev/ttyACM0
and /dev/ttyACM1
after reboot. In this case using the symlinks created for device IDs can ensure the correct device is used, for example: /dev/serial/by-id/usb-0658_0200-if00
for Aeotec Z-Stick.
Network Key Mac
Suggest an edit to this page, or provide/view feedback for this page.