Pages

Friday, December 30, 2016

Adding a Fibaro Button to control my hot water pump

Controlling the hot water pump by activating a ZWave switch from my phone app is great, but it would be more convenient for everyone if this could also be operated by a simple button located close to where the water is needed.

The only ZWave button I could find was this one by Fibaro. 


It seemed overkill (and pricey) for my purposes, but I liked the look of it. It had not been on the market long and I wasn't sure that it was going to work with the ZWay software. But I took a chance and ordered it anyway.

Setting up the button


Including it into my ZWave network was straightforward. And it appeared in the SmartHome UI:


And here are some of the views from the Expert UI:

Interview Tab showing supported command classes

Configuration Tab
Association Tab


but I wasn't sure what to expect after that. According to the ZWave.me forum it is not yet supported by ZWay, but a couple of people had managed to catch a single click event which was all I needed. So I started fiddling with it and seeing what messages appeared.


What happens for a single button press?

Pressing the button once resulted in a notification appearing in the SmartHome UI:


Looking into the log file, the first message picked up after this button press was:

[2016-12-30 14:48:07.676] [D] [zway] RECEIVED: ( 01 08 00 04 00 28 02 98 40 01 )

followed by a series of SENDS and ACKS

and then what looked like the information I needed:

[2016-12-30 14:48:08.319] [D] [zway] SETDATA devices.40.instances.0.commandClasses.91.data.sequence = **********
[2016-12-30 14:48:08.319] [D] [zway] SETDATA devices.1.instances.0.commandClasses.91.data.srcNodeId = 40 (0x00000028)
[2016-12-30 14:48:08.320] [D] [zway] SETDATA devices.1.instances.0.commandClasses.91.data.srcInstanceId = 0 (0x00000000)
[2016-12-30 14:48:08.320] [D] [zway] SETDATA devices.1.instances.0.commandClasses.91.data.keyAttribute = 0 (0x00000000)
[2016-12-30 14:48:08.320] [D] [zway] SETDATA devices.1.instances.0.commandClasses.91.data.currentScene = 1 (0x00000001)
[2016-12-30 14:48:08.320] [D] [zway] SETDATA devices.40.instances.0.commandClasses.91.data.keyAttribute = 0 (0x00000000)
[2016-12-30 14:48:08.321] [D] [zway] SETDATA devices.40.instances.0.commandClasses.91.data.currentScene = 1 (0x00000001)
[2016-12-30 14:48:08.378] [I] [core] Notification: device-info (device-OnOff): {"dev":"Fibar Group (40.0.0.1) Button","l":"on"}

From the ZWave.me documentation command class 91 is a 'central scene command':



I did a little experimenting here and found that the following keyAttribute values resulted from Fibaro button presses:


press 1 time: 0x00
press 2 times: 0x03
press 3 times: 0x04
press 4 times: 0x05
press 5 times: 0x06
hold down: 0x02 followed by 0x01 once released

But really I was only interested in 'has it been pressed' rather than how many times or for how long. Still, it is good to know that even though the button is not officially supported it is possible to use all of its features. For my purposes I just needed to bind to changes in the keyAttribute.

Binding to the keyAttribute value

Here is my code:

        // find the hot water pump switch
         hotWaterSwitch = getDeviceByManufacturer(FIBARO_ID, FIBARO_BUTTON_ID, FIBARO_BUTTON_TYPE);
         console.log ("MYTESTMOD: hot water switch is " + hotWaterSwitch);
         if (hotWaterSwitch != -1) { 
            zway.devices[hotWaterSwitch].instances[0].commandClasses[91].data.keyAttribute.bind(
                                                      function() 
                                                      {
                                                        self.rooms[1].setPumpStatus(true);
                                                      });
         }
         else {
            controller.addNotification("error", "No Hot Water Switch Present", "module", "MyTestMod");
         }
         self.hotWaterSwitch = hotWaterSwitch;

And here is my button:



currently residing on top of my radio, close to the sink. Working great so far!

Thursday, December 15, 2016

Remote Control of the hot water pump

Next step was to replace the timer switch for the hot water pump with a Z-Wave switch. I already had a Hostmann / Secure ASR-ZW boiler receiver unit that I had bought with the room thermostat and decided to use this. I had some doubts about the switch suitability because of something I had read on the HeatGenius website.



However according to the pump specification the maximum operating current is 0.47A at startup and the switch has a current limit of 3A so I didn't see a problem.

I left the installation to my husband! He added it alongside the existing timer such that we would be able to revert to the old method should the Z-Wave solution fail in some way.

The Hardware


New Z-Wave Switch alongside existing timer control


And the hot water pump 

Once installed, he checked that the on/off buttons were operating the pump and then left the remote part to me.

The ZWay SmartHome User Interface


The switch was easily included in the Z-Wave network and showed up in the ZWay web based UI (SmartHome) as two virtual devices as follows.

Which correspond to the two command classes ThermostatMode (64) and SwitchBinary (37)

Switching either to the on position resulted in the on light illuminating at the switch and the pump operating. And switching either to the off position resulted in the off light illuminating and the pump turning off.

All these events appeared in the event log of the SmartHome UI.

However, pressing ON or OFF at the switch did not result in the status being fed back to zway and nothing appeared in the event log. In order to report the actual status of the switch it is necessary to poll by forcing a SwitchBinary Get to be sent to the switch. This was not a big issue to implement in my ZWay module.

      // poll for the hot water pump status
      // this is necessary because if the pump is activated manually we do not receive a notification
      zway.devices[pumpController].instances[0].commandClasses[37].Get();

See this post for the Vera Controller that reports the same experience.

Adding control to my API


Either of the zway virtual devices created allow the pump to be turned on and off but I opted for the SwitchBinary (37) for my control. This can be activated from the browser with this command:

http://192.168.1.180:8083/ZWaveAPI/Run/zway.devices[37].instances[0].commandClasses[37].Set(true)

which I added to my ZWay module on the rPi:

Room.prototype.setPumpStatus = function (status) {
  console.log("setPumpStatus status is " + status + " (" + typeof(status) + ")");
  // set the actual status and wait for the response before updating our data
  // structures and starting the timer if necessary
  zway.devices[37].instances[0].commandClasses[37].Set(status);
}

registered GET and POST elements with my API:

    zAutomationAPI.router.get("/hillview/pumpstatus/:roomID",zAutomationAPI.ROLE.USER,getPumpStatus,[parseInt]);
    zAutomationAPI.router.post("/hillview/pumpstatus/:roomID",zAutomationAPI.ROLE.USER,setPumpStatus,[parseInt]);

and tested using a Python script.

By default, if the ASR-ZW is turned on it remains on for 45 minutes unless instructed otherwise. It is good to know that it will not remain on indefinitely. However, 45 minutes is way longer than required so I have set the rPi to automatically turn the switch off after 5 minutes of operation. I have made this timer configurable and also report how long the pump is running for. This required two further additions to the API:

pumpDuration GET & POST
pumpTime GET

Adding control via my Android App


I added a button to the Android App which operates the same as the on/off buttons on the device itself.



This has been operating the pump successfully for over a week now. The pump is only running when actually needed and I no longer have to rely on timed intervals to have hot water in my kitchen and utility room. Really pleased with the result!

However a hardware button in the kitchen would be much more convenient. On to the next step.