Z-Wave
Connect to a Z-Wave network via a USB stick (tested with Aeotec Z-Stick Gen5), this protocol requires a device mapping for the manager Docker container to provide access to the USB stick.
Make sure that the device mapping and the volume configuration for the manager Docker container in the file docker-compose.yml looks like the following:
...
...
volumes:
  proxy-data:
  manager-data:
  postgresql-data:
  zwave-data:
...
...
  manager:
    restart: always
    ...
    ...
    volumes:
      ...
      ...
      - zwave-data:/zwave
    devices:
      - /dev/ttyACM0:/dev/ttyS0
...
...
In this example the serial port /dev/ttyACM0 of the host is mapped to the serial port /dev/ttyS0 of the manager Docker container.
Agent configuration
The following describes the supported agent configuration attributes:
| Attribute | Description | Value type | Required | 
|---|---|---|---|
| serialPort | Serial port address | Text ( /dev/ttyS0) | Y | 
Agent link
For attributes linked to this agent, the following describes the supported agent link fields which are in addition to the standard Agent Link fields:
| Field | Description | Value type | Required | 
|---|---|---|---|
| type | Agent type | Text (Must be ZWaveAgentLink) | Y | 
| deviceNodeId | Device node ID | Integer | Y | 
| deviceEndpoint | Device Endpoint | Integer | Y | 
| deviceValue | The device value to link to this attribute | Text | Y | 
Discovery and Import
To understand discovery and import refer to Agent and Asset Discovery/Import. This protocol supports the following:
- Protocol Asset Discovery
You can repeat this procedure as often as you want and devices are not imported more than once. You should execute this procedure initially and after you've added a new device to the Z-Wave network.
TODO: Clean up the following
Include Z-Wave devices
This procedure describes how to add a new device to the Z-Wave network (Z-Wave device inclusion).
Note that before you are able to execute this procedure you have to execute the Import Z-Wave Devices procedure at least once otherwise the Z-Wave Controller asset is missing.
- Select Z-Wave Controllerin the asset list on the left side
- Activate the Device Inclusioncheckbox
- Put the Z-Wave device into inclusion mode (see device manual)
- Execute the Import Z-Wave Devicesprocedure in order to add the new device to the asset list on the left side
Exclude Z-Wave devices
This procedure describes how to remove a device from the Z-Wave network (Z-Wave device exclusion).
Note that before you are able to execute this procedure you have to execute the Import Z-Wave Devices procedure at least once otherwise the Z-Wave Controller asset is missing.
- Select Z-Wave Controllerin the asset list on the left side
- Activate the Device Exclusioncheckbox
- Put the Z-Wave device into exclusion mode (see device manual)
Configure Z-Wave device parameters
- Select the Z-Wave device in the asset list on the left side and expand it so that you see the Parametersgroup
- Expand the Parametersgroup
- Select the Z-Wave parameter on the left side
- Edit the selected Z-Wave parameter on the right side. To get information about the selected Z-Wave parameter read the text in the Descriptionattribute on the right side. The attribute with the disabledWritebutton shows the current Z-Wave parameter value. All other attributes with an enabledWritebutton are used to modify the Z-Wave parameter value. In case of a battery powered device you have to wakeup the device (see device manual) so that the configured parameter value can be sent to the device.
Additional info
Unfortunately, Docker for Windows and Docker for Mac do not support device pass through. In case of a Windows or Mac computer you have to install Linux as a virtual machine by means of VirtualBox. There are two options to do this.
Windows - Option 1 (Docker Toolbox)
- Download and install VirtualBox.
- Download and install VirtualBox Extension Pack
- On Windows 10 open the Windows Featureswindow and make sure that the following features have not been selected:Hyper-V,Virtual Machine Platform,Windows Subsystem for Linux.
- Install Docker Toolbox. Select the following optional components: Docker Compose for WindowsandGit for Windows. Do not select and installVirtualBox.
- Start Git Bashand type the following command:
docker-machine create --driver virtualbox --virtualbox-boot2docker-url https://github.com/boot2docker/boot2docker/releases/download/v18.06.1-ce/boot2docker.iso default
Note that if a virtual machine with the name default already exists you can delete it with the following command:
docker-machine rm default
- Start VirtualBox and select the virtual machine with the name defaulton the left side and go to Settings -> Network -> Adapter 1 -> Advanced -> Port Forwarding
- Add the following rules:
| Name | Protocol | Host IP | Host Port | Guest IP | Guest Port | 
|---|---|---|---|---|---|
| postgresql | TCP | 5432 | 5432 | ||
| keycloak | TCP | 8081 | 8081 | ||
| map | TCP | 8082 | 8082 | ||
| proxy http | TCP | 80 | 80 | ||
| proxy https | TCP | 443 | 443 | 
- Connect the Aeotec Z-Stick to the PC
- In VirtualBox go to Settings -> USB
- Activate Enable USB Controller
- Select USB 2.0 (EHCI) Controller
- Press the Add USB-Filterbutton and select the Aeotec Z-Stick device (Sigma Designs, Inc.)
 
- Activate 
- Find out the serial port name. In VirtualBox start the virtual machine with the name defaulton the left side and press the start button. In the boot2docker terminal window type the following command:
ls -al /dev/tty* | more
In case of a Aeotec Z-Stick Gen5 the USB device name is usually /dev/ttyACM0. The older Aeotec Z-Stick S2 has usually the name /dev/ttyUSB0.
Mac - Option 1 (Docker Toolbox)
- Download and install VirtualBox.
- Download and install VirtualBox Extension Pack
- Install Docker Toolbox.
- Start a terminal and execute the following command:
docker-machine create --driver virtualbox --virtualbox-boot2docker-url https://github.com/boot2docker/boot2docker/releases/download/v18.06.1-ce/boot2docker.iso default
Note that if a virtual machine with the name default already exists you can delete it with the following command:
docker-machine rm default
- Start VirtualBox and select the virtual machine with the name defaulton the left side and go to Settings -> Network -> Adapter 1 -> Advanced -> Port Forwarding
- Add the following rules:
| Name | Protocol | Host IP | Host Port | Guest IP | Guest Port | 
|---|---|---|---|---|---|
| postgresql | TCP | 5432 | 5432 | ||
| keycloak | TCP | 8081 | 8081 | ||
| map | TCP | 8082 | 8082 | ||
| proxy http | TCP | 80 | 80 | ||
| proxy https | TCP | 443 | 443 | 
- Connect the Aeotec Z-Stick to the PC
- In VirtualBox go to Settings -> Ports -> USB
- Activate Enable USB Controller
- Select USB 2.0 (EHCI) Controller
- Press the Add USB-Filterbutton and select the Aeotec Z-Stick device (Sigma Designs, Inc.)
 
- Activate 
- Find out the USB device name in the boot2docker virtual machine. In VirtualBox start the virtual machine with the name defaulton the left side and press the start button. In the boot2docker terminal window type the following command:
ls -al /dev/tty* | more
In case of a Aeotec Z-Stick Gen5 the USB device name is usually /dev/ttyACM0. The older Aeotec Z-Stick S2 has usually the name /dev/ttyUSB0.
Windows & Mac - Option 2 (Ubuntu VM)
- Download and install VirtualBox
- Download and install VirtualBox Extension Pack
- Download Ubuntu Desktop
- Start VirtualBox and create a new virtual machine by clicking the Newbutton on the top toolbar.
- Make the following changes as VirtualBox guides you through a wizard:
- Type: Linux
- Version: Ubuntu (64-bit)
- Memory size: Minimum 4096 MB
- Virtual hard disk size: Minimum 20 GB
 
- Type: 
- Click the Startbutton in the top toolbar and select the Ubuntu iso image that you've downloaded in step #3 in order to install Ubuntu
- After installing Ubuntu it's recommended to install 'guest additions'. Start the Ubuntu virtual machine and in the upper menu bar select the following: Devices -> Insert Guest Additions CD image...
- Install Docker Engine
- Install Docker Compose
- Shutdown the Ubuntu virtual machine and connect the Aeotec Z-Stick to the PC. In the VirtualBox Manager go to Settings -> Ports -> USB -> Port1 and add the following configuration:
- Activate Enable USB Controller
- Select USB 3.0 (xHCI) Controller
- Press the Add Filterbutton and select the Aeotec Z-Stick USB device (Sigma Designs, Inc.)
 
- Activate 
- Find out the serial port name. Run the following command:
dmesg -w
You should see something like the following:
[15624.940828] cdc_acm 2-1:1.0: ttyACM0: USB ACM device
In this example the resulting serial port name would be:
/dev/ttyACM0
Linux
- Install Docker Engine
- Install Docker Compose
- Find out the serial port name. Connect the Aeotec Z-Stick to the PC and execute the following command:
dmesg -w
You should see something like the following:
[15624.940828] cdc_acm 2-1:1.0: ttyACM0: USB ACM device
In this example the resulting serial port name would be:
/dev/ttyACM0