Beginning with the next Reactor release, there will be some dependency changes and new deprecations.
These apply to users on bare-metal installs only. If you are running Reactor in a docker container, the following does not apply to you — the container supplies its own dependencies and will be up-to-date.
All versions of nodejs prior to 18 are now end-of-life (no maintenance), so starting with the next Reactor build, they are deprecated for use with Reactor; they will continue to work until March 1 2024 (about 3 months from now), so you need to upgrade before that date. The recommended version of nodejs is 20, which is the current long-term support (LTS) version (EOL in mid-2026). Version 18 is the prior LTS version and still supported (by OpenJS Foundation and Reactor) until mid-2025, so it's a good fallback if you have issues getting version 20 running. As of this writing, the current 20 is 20.10.0, and the current 18 is 18.18.2. Both have been tested with Reactor 23302.
Now, nodejs version 20.9.0 seems to have dependencies that are not easily resolved on Raspberry Pi OS (formerly Raspbian) Buster (Debian 10). If you are using an RPi running Buster, you should select nodejs 18. That gives you until mid-2025 to upgrade both nodejs and the RPi OS to a more modern version (the current RPi OS is bookworm, Debian 12, 64-bit). The tools/rpi-install.sh script will be enhanced for the next build to try to discern what is reasonable for your system and make the appropriate upgrades; it is safe to run even on a current Reactor install.
If you are running an OS other than Raspberry Pi OS, try for nodejs 20, but use 18 as a fallback if you can't get it installed and running.
@togglebits I have another one for you.
HASS controller shows hvac_control.state="heating, cooling or idle".
ZWaveJSController controller shows hvac_control.state="heat, cool, or idle"
I believe hvac_control.state="heating, cooling or idle" should be what the ZWaveJSController should show.
"heat", "cool" or "off" are values assigned to the hvac_control.mode attribute.
Again, not sure if this is related to Reactor/ZwaveJSController implementation or the actual Z-Wave JS UI docker version. I have copied, below, the attributes of the thermostat in hopes it can help.
Thanks in advance.
Reactor version 23302
ZWaveJSController version 23254
Z-Wave JS UI version 9.3.0.724519f
zwave-js version 12.2.3
Certain MSR updates are irrelevant for some users (e.g. only Hass related changes when you are not using one), so I was wondering if there could be a dismiss (firmware) feature similar to Hubitat?
Then when you'll use "dismiss", a blue checkmark would disappear until there's a new firmware.
Noticed that if I try to use a case statement, I'll have to have multiple when clauses, otherwise I'll get syntax error.
(I tried to include a screenshot, but got parse error from the forum...)
The following works:
case when condition == true: "This is true" when condition == false: "Now it is false" else "Something else" endBut this will end up with syntax error:
case when condition == true: "This is true" else "Something else" endUsing build 23242 on Docker
When doing something like curl -o - 'http://localhost:8111/api/v1/entity/ezlo>device_61baf509129e0725bd9f80e1/attribute/dimming.level' I get a response with current dimming level for example "0.6"
but curl -o - 'http://localhost:8111/api/v1/entity/ezlo>device_61baf509129e0725bd9f80e1/perform/dimming.set?level=0.8' sets the dimming level to 0.8 but gives no response which causes the connection to eventually timeout.
Doing it in a browser performs the action but leaves the tab with a spinning wheel of a loading page.
Is this expected behavior?
Edit: Solved in build 22142
Hi @toggledbits
Apparently, there have been some changes to the CallMeBot interface, as the service recently stopped working for me. I've tried several configurations, and none of the ones below are working.
# CallMeBot CallMeBot: profiles: default: # description - A friendly description of this profile (for menus) description: Default Profile New # # api_url - Access URL for CallMeBot API being used api_url: http://api.callmebot.com/start.php # # api_key - (if needed) API key (use for Facebook API, WhatsApp API, etc.). # If the API you are using does not require it, leave it # commented out or blank. api_key: "177xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTGk" # # source - (if needed) Source field for some APIs. If yours does not require # it, leave it commented out or blank. #source: "source-value" # # phone - (if needed) Phone field for some APIs. If yours does not require # it, leave it commented out or blank. phone: "+5xxxxxxxx33" # # user - (if needed) User field for some APIs. If yours does not require # it, leave it commented out or blank. #user: "@xxxxxxxxxxxxx" # # lang - (optional) Language/voice; default "en-US-Standard-C". # See CallMeBot docs for possible values. lang: "en-US-Standard-C" # # rpt - (optional) Number of times to repeat message; default: 1. rpt: 2I have already tested using the phone or the user.
Looking at the action log, I see that it starts, runs and finishes without any problems.
[latest-23302]2023-11-05T14:35:54.106Z <Engine:INFO> Enqueueing "teste<SET>" (rule-lolk0nlj:S) [latest-23302]2023-11-05T14:35:54.108Z <Engine:NOTICE> Starting reaction teste<SET> (rule-lolk0nlj:S) [latest-23302]2023-11-05T14:35:54.111Z <Engine:INFO> teste<SET> all actions completed.When testing directly on the site, I see that it no longer uses API, and I haven't even found where to generate the API KEY.
http://api.callmebot.com/start.php?source=web&user=+5xxxxxxxx33&text=Teste callmebot pelo numero novo&lang=en-US-Standard-CPlease, can you advise me on what I should do to solve the problem?
Thanks.
@togglebits I am curious as to why the tilt_sensor.state (primary) = NULL. I believe it should show true or false. I have to use binary_sensor.state instead in my rules.
Again, not sure if this is related to Reactor/ZwaveJSController implementation or the actual Z-Wave JS UI docker version. I have copied, below, the attributes of the tilt sensor in hopes it can help.
Thanks in advance.
Reactor version 23302
ZWaveJSController version 23254
Z-Wave JS UI version 9.3.0.724519f
zwave-js version 12.2.3
I have just noticed that two of my z-wave switches, Inovelli LZW31 and Aeotec ZWA037, although responding correctly to commands such as (turning on the switch, changing LED color, etc.), are not displaying the right power_switch.state when turned ON. All other attributes are showing proper values.
Example when I turn on either switches,
In Home Assistant (hass), the power_switch.state = true while in ZWaveJSController (zwavejs), the power_switch.state = false.
Reactor version 23302
ZWaveJSController version 23254
Z-Wave JS UI version 9.3.0.724519f
zwave-js version 12.2.3
Here's what the log shows.
[latest-23302]2023-11-01T21:14:00.303Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) starting evaluation; because entity-changed System#reactor_system>system [latest-23302]2023-11-01T21:14:00.304Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) trigger evaluation result is false (previously false) [latest-23302]2023-11-01T21:14:00.304Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluated; trigger state unchanged (false); rule state remains RESET [latest-23302]2023-11-01T21:14:00.304Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluation complete [latest-23302]2023-11-01T21:14:00.308Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) starting evaluation; because entity-changed System#reactor_system>system [latest-23302]2023-11-01T21:14:00.309Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) trigger evaluation result is false (previously false) [latest-23302]2023-11-01T21:14:00.309Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluated; trigger state unchanged (false); rule state remains RESET [latest-23302]2023-11-01T21:14:00.309Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluation complete [latest-23302]2023-11-01T21:14:00.311Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) starting evaluation; because entity-changed System#reactor_system>system [latest-23302]2023-11-01T21:14:00.312Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) trigger evaluation result is false (previously false) [latest-23302]2023-11-01T21:14:00.312Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluated; trigger state unchanged (false); rule state remains RESET [latest-23302]2023-11-01T21:14:00.313Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluation complete [latest-23302]2023-11-01T21:14:00.315Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) starting evaluation; because entity-changed System#reactor_system>system [latest-23302]2023-11-01T21:14:00.317Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) trigger evaluation result is false (previously false) [latest-23302]2023-11-01T21:14:00.317Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluated; trigger state unchanged (false); rule state remains RESET [latest-23302]2023-11-01T21:14:00.317Z <Rule:INFO> Notification: Update Available - Reactor (rule-laeg075n in Notifications) evaluation complete [latest-23302]2023-11-01T21:14:03.258Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) starting evaluation; because entity-changed Light#hass>light_office_light [latest-23302]2023-11-01T21:14:03.259Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) trigger evaluation result is true (previously false) [latest-23302]2023-11-01T21:14:03.260Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluated; rule state transition from RESET to SET! [latest-23302]2023-11-01T21:14:03.271Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluation complete [latest-23302]2023-11-01T21:14:03.273Z <Engine:INFO> Enqueueing "Toggle office light LED color state between green/blue Copy<SET>" (rule-lof5hpwe:S) [latest-23302]2023-11-01T21:14:03.285Z <Engine:NOTICE> Starting reaction Toggle office light LED color state between green/blue Copy<SET> (rule-lof5hpwe:S) [latest-23302]2023-11-01T21:14:03.287Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs performing zwave_device.set_config on Light#zwavejs>138-0 with [Object]{ "parameter": "84", "size": 1, "value": 3, "bitmask": 0 } [latest-23302]2023-11-01T21:14:03.345Z <Engine:INFO> Resuming reaction Toggle office light LED color state between green/blue Copy<SET> (rule-lof5hpwe:S) from step 2 [latest-23302]2023-11-01T21:14:03.346Z <Engine:INFO> Toggle office light LED color state between green/blue Copy<SET> all actions completed. [latest-23302]2023-11-01T21:14:05.191Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs node 138-0 no value +currentValue: found for power_switch.state [latest-23302]2023-11-01T21:14:05.205Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) starting evaluation; because entity-changed Light#hass>light_office_light [latest-23302]2023-11-01T21:14:05.205Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) trigger evaluation result is true (previously true) [latest-23302]2023-11-01T21:14:05.206Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluated; trigger state unchanged (true); rule state remains SET [latest-23302]2023-11-01T21:14:05.206Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluation complete [latest-23302]2023-11-01T21:14:10.503Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs node 138-0 no value +currentValue: found for power_switch.state [latest-23302]2023-11-01T21:14:10.518Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) starting evaluation; because entity-changed Light#hass>light_office_light [latest-23302]2023-11-01T21:14:10.519Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) trigger evaluation result is false (previously true) [latest-23302]2023-11-01T21:14:10.520Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluated; rule state transition from SET to RESET! [latest-23302]2023-11-01T21:14:10.529Z <Rule:INFO> Toggle office light LED color state between green/blue Copy (rule-lof5hpwe in Office) evaluation complete [latest-23302]2023-11-01T21:14:10.530Z <Engine:INFO> Enqueueing "Toggle office light LED color state between green/blue Copy<RESET>" (rule-lof5hpwe:R) [latest-23302]2023-11-01T21:14:10.542Z <Engine:NOTICE> Starting reaction Toggle office light LED color state between green/blue Copy<RESET> (rule-lof5hpwe:R) [latest-23302]2023-11-01T21:14:10.543Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs performing zwave_device.set_config on Light#zwavejs>138-0 with [Object]{ "parameter": "84", "size": 1, "value": 2, "bitmask": 0 } [latest-23302]2023-11-01T21:14:10.596Z <Engine:INFO> Resuming reaction Toggle office light LED color state between green/blue Copy<RESET> (rule-lof5hpwe:R) from step 2 [latest-23302]2023-11-01T21:14:10.597Z <Engine:INFO> Toggle office light LED color state between green/blue Copy<RESET> all actions completed. [latest-23302]2023-11-01T21:14:12.441Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs node 138-0 no value +currentValue: found for power_switch.statePS I am trying to attach an image but getting "Something went wrong while parsing server response". Also, not sure if this is related to Reactor/ZwaveJSController implementation or the actual Z-Wave JS UI docker version.
Hopefully I have provided the necessary information.
Thanks in advance.
Some background
I have two simple rules that will toggle my carport's down lights depending on outdoor brightness when I open the motorized sliding gate. I.e. if the brightness is 1500 lux or less and the gate is opened, the down lights will be switched on, and when the gate is closed, the lights will switch off after 3 minutes. Pretty simple 'coming home' functionality so to speak.
Here's the switch off rule showing the 'hard coded' thresholds
Screenshot from 2023-10-31 18-44-46.png
The problem
I would like to parameterize the lux and switch off delay using entities. I bet the lux threshold can be done with local expressions the same way I do my WC background music scheduling:
But the since I'm using the Condition must be sustained for functionality for the switch off rule, I have no idea how to parameterize that with some entity value.
So my question is that is it even possible to do this using entities or could there some other way to accomplish the same functionality? In this example it's the sustain -value but I might need same kind of parameterization for the delay reset also.
I have to go with entities, since my own HA system will provide the threshold values for the MSR through the MQTTController.
Help would be appreciated @toggledbits
br,
mgvra
MSR latest-23302-b7def56a and MQTTController [0.1.23254]
So I have a strange one here and I don't know if there is a way to do this or not. I have blue iris triggering a vera virtual switch when AI detects motion on my front porch. Reactor then triggers the light, this works perfect. I want to shut the light off when there is no motion, this also works perfect. What I am having am issue with is when someone turns on the light manually I don't want it to turn off after motion is detected. Example: we are expecting a pizza so we turn on the porch light. 5 min later amazon delivers a package, trips motion. 10 min later Reactor is going to turn off the light. If I manually turn on the light before motion is detected I do not want reactor to turn it off. For the life of me I cannot figure the logic out. Does anyone have any ideas?
Build 21228 has been released. Docker images available from DockerHub as usual, and bare-metal packages here.
Home Assistant up to version 2021.8.6 supported; the online version of the manual will now state the current supported versions; Fix an error in OWMWeatherController that could cause it to stop updating; Unify the approach to entity filtering on all hub interface classes (controllers); this works for device entities only; it may be extended to other entities later; Improve error detail in messages for EzloController during auth phase; Add isRuleSet() and isRuleEnabled() functions to expressions extensions; Implement set action for lock and passage capabilities (makes them more easily scriptable in some cases); Fix a place in the UI where 24-hour time was not being displayed.Hi @toggledbits
Is there any way that in the trigger the Varable Value could select the desired part of the array?
For example, I could have a global variable VarTEST$[Part1, Part2, Part3] like this: ${{ [TestText, 5, 3] }}. Use the Variable Value to validate a VarTEST[Part2] == 5 trigger.
What am I doing today? I've defined 3 global variables:
3ae76d20-ffce-4f66-9002-1b4d6cc7c3c3-image.png
And I validate each variable.
3bcc1d62-2ce1-41ca-9f00-f98578c0d597-image.png
In short, I would like to have a global variable of the array type, and be able to select which element of the array I would use for validation in a trigger.
Thanks
Hello all I am trying to run the service call browser_mod.popup from MSR to HA. If I enter the service data in YAML like this:
dismissable: true autoclose: false timeout: 120000 content: type: custom:mushroom-alarm-control-panel-card entity: alarm_control_panel.home_partition states: - armed_home - armed_away layout: vertical show_keypad: true target: device_id: e684ad00b76e330e57a8c915dc367bc4For some reason the target portion of the data isn't sent and therefor the popup shows up on all my browser mod devices not the only one I had specified in the device_id. Here is a snippet of the reactor log, no errors that I see just looks like the target info isn't being passed on.
[latest-23242]2023-10-12T23:51:50.795Z <Engine:INFO> Enqueueing "Main Floor Tablet Alarm Arming Popup<SET>" (rule-lnmn8t54:S) [latest-23242]2023-10-12T23:51:50.800Z <Engine:NOTICE> Starting reaction Main Floor Tablet Alarm Arming Popup<SET> (rule-lnmn8t54:S) [latest-23242]2023-10-12T23:51:50.813Z <HassController:INFO> HassController#hass action x_hass_system.call_service([Object]{ "service": "browser_mod.popup", "data": "data:\n dismissable: true\n autoclose: false\n timeout: 120000\n content:\n type: custom:mushroom-alarm-control-panel-card\n entity: alarm_control_panel.home_partition\n states:\n - armed_home\n - armed_away\n layout: vertical\n show_keypad: true\ntarget:\n device_id: e684ad00b76e330e57a8c915dc367bc4" }) on System#hass>system succeeded [latest-23242]2023-10-12T23:51:50.816Z <Engine:INFO> Resuming reaction Main Floor Tablet Alarm Arming Popup<SET> (rule-lnmn8t54:S) from step 1 [latest-23242]2023-10-12T23:51:50.817Z <Engine:INFO> Main Floor Tablet Alarm Arming Popup<SET> all actions completed.So I used an online YAML to JSON converter since I am not the good with JSON and it converted the YAML to this:
{ "data": { "dismissable": true, "autoclose": false, "timeout": 120000, "content": { "type": "custom:mushroom-alarm-control-panel-card", "entity": "alarm_control_panel.bar_partition", "states": [ "armed_home", "armed_away" ], "layout": "vertical", "show_keypad": true } }, "target": { "device_id": "34ae76561192c4bb0b64fb07ad0f01c1" } }When I use this in my reaction the popup doesn't show up properly. Something pops up but it's just a grey bar. Interestingly the JSON version actually does target only the device_id I had specified. Here is the reactor log output:
[latest-23242]2023-10-12T23:52:39.875Z <Engine:INFO> Enqueueing "Main Floor Tablet Alarm Arming Popup<SET>" (rule-lnmn8t54:S) [latest-23242]2023-10-12T23:52:39.880Z <Engine:NOTICE> Starting reaction Main Floor Tablet Alarm Arming Popup<SET> (rule-lnmn8t54:S) [latest-23242]2023-10-12T23:52:40.291Z <HassController:INFO> HassController#hass action x_hass_system.call_service([Object]{ "service": "browser_mod.popup", "data": "{\n \"data\": {\n \"dismissable\": true,\n \"autoclose\": false,\n \"timeout\": 120000,\n \"content\": {\n \"type\": \"custom:mushroom-alarm-control-panel-card\",\n \"entity\": \"alarm_control_panel.home_partition\",\n \"states\": [\n \"armed_home\",\n \"armed_away\"\n ],\n \"layout\": \"vertical\",\n \"show_keypad\": true\n }\n },\n \"target\": {\n \"device_id\": \"e684ad00b76e330e57a8c915dc367bc4\"\n }\n}" }) on System#hass>system succeeded [latest-23242]2023-10-12T23:52:40.293Z <Engine:INFO> Resuming reaction Main Floor Tablet Alarm Arming Popup<SET> (rule-lnmn8t54:S) from step 1 [latest-23242]2023-10-12T23:52:40.294Z <Engine:INFO> Main Floor Tablet Alarm Arming Popup<SET> all actions completed.My limited skill with JSON has kind of backed me into a corner here, so if anyone could help me format it correctly that would be great!
MSR latest 23242
HA 2023.10.1
Here's my second attempt at a Reactor Controller, this time to integrate LG TVs:

Reactor controller for LG TV (webos). Contribute to dbochicchio/reactor-lgtv development by creating an account on GitHub.
Standard capabilities are provided and TV volume, mute and switch status are controllable.
There's also an action to send toast notifications on your TV.
webos 5+ is required.
I installed a new iblind this evening and it is appearing in ZWaveJS. It is operational thru Home Assistant just fine. It is operational thru the HA ZwaveJS plugin just fine.
Where it is non-responsive is in MSR for some reason. The entities are there. Adding the node to a Reaction and then attempting to run said Reaction nets me this:
[latest-23242]2023-09-08T05:33:08.454Z <ZWaveJSController:5:ZWaveJSController.js:655> ZWaveJSController#zwavejs _apply_value motion_sensor.state=false [latest-23242]2023-09-08T05:33:08.455Z <ZWaveJSController:5:ZWaveJSController.js:722> ZWaveJSController#zwavejs setting Binary Sensor#zwavejs>11-0.x_zwave_values.Binary_Sensor_Motion to false [latest-23242]2023-09-08T05:33:08.692Z <ZWaveJSController:5:ZWaveJSController.js:360> ZWaveJSController#zwavejs handling node event statistics updated entity Binary Sensor#zwavejs>11-0 [latest-23242]2023-09-08T05:40:23.960Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs performing cover.open on Cover#zwavejs>20-0 with [Object]{ } [latest-23242]2023-09-08T05:40:23.962Z <ZWaveJSController:5:ZWaveJSController.js:1843> ZWaveJSController#zwavejs no implementation mapped; attempting default [latest-23242]2023-09-08T05:40:25.062Z <ZWaveJSController:INFO> ZWaveJSController#zwavejs performing zwave_device.refresh on Cover#zwavejs>20-0 with [Object]{ } **[latest-23242]2023-09-08T05:40:25.063Z <ZWaveJSController:5:ZWaveJSController.js:1843> ZWaveJSController#zwavejs no implementation mapped; attempting default** [latest-23242]2023-09-08T05:40:25.065Z <ZWaveJSController:5:ZWaveJSController.js:294> ZWaveJSController#zwavejs sending #1694151625064<9/8/2023, 1:40:25 AM>: [Object]{ "command": "node.refresh_values", "nodeId": 20, "messageId": 1694151625064 } [latest-23242]2023-09-08T05:40:26.307Z <ZWaveJSController:5:ZWaveJSController.js:360> ZWaveJSController#zwavejs handling node event statistics updated entity Cover#zwavejs>20-0 [latest-23242]2023-09-08T05:40:26.317Z <ZWaveJSController:5:ZWaveJSController.js:360> ZWaveJSController#zwavejs handling node event value updated entity Cover#zwavejs>20-0 [latest-23242]2023-09-08T05:40:26.318Z <ZWaveJSController:5:ZWaveJSController.js:667> ZWaveJSController#zwavejs update node 20 value "0:128:level:" data [Object]{ "source": "node", "event": "value updated", "nodeId": 20, "args": { "commandClassName": "Battery", "commandClass": 128, "property": "level", "endpoint": 0, "newValue": 100, "prevValue": 100, "propertyName": "level" } } [latest-23242]2023-09-08T05:40:26.319Z <ZWaveJSController:5:ZWaveJSController.js:684> ZWaveJSController#zwavejs updating attributes for node 20 value "0:128:level:"=100: [Array][ "battery_power.level", "battery_power.since" ] [latest-23242]2023-09-08T05:40:26.320Z <ZWaveJSController:5:ZWaveJSController.js:698> ZWaveJSController#zwavejs updating attribute battery_power.level with [Object]{ "entity": "20-0", "impl": { "expr": "float( value ) / 100", "valueId": "128:level:" } } [latest-23242]2023-09-08T05:40:26.321Z <ZWaveJSController:5:ZWaveJSController.js:591> ZWaveJSController#zwavejs _apply_value entity Cover#zwavejs>20-0 battery_power.level [latest-23242]2023-09-08T05:40:26.322Z <ZWaveJSController:5:ZWaveJSController.js:655> ZWaveJSController#zwavejs _apply_value battery_power.level=1 [latest-23242]2023-09-08T05:40:26.323Z <ZWaveJSController:5:ZWaveJSController.js:698> ZWaveJSController#zwavejs updating attribute battery_power.since with [Object]{ "entity": "20-0", "impl": { "expr": "time()", "valueId": "128:level:" } } [latest-23242]2023-09-08T05:40:26.323Z <ZWaveJSController:5:ZWaveJSController.js:591> ZWaveJSController#zwavejs _apply_value entity Cover#zwavejs>20-0 battery_power.since [latest-23242]2023-09-08T05:40:26.324Z <ZWaveJSController:5:ZWaveJSController.js:655> ZWaveJSController#zwavejs _apply_value battery_power.since=1694151626324<9/8/2023, 1:40:26 AM> [latest-23242]2023-09-08T05:40:26.325Z <ZWaveJSController:5:ZWaveJSController.js:722> ZWaveJSController#zwavejs setting Cover#zwavejs>20-0.x_zwave_values.Battery_level to 100 [latest-23242]2023-09-08T05:40:26.333Z <ZWaveJSController:5:ZWaveJSController.js:360> ZWaveJSController#zwavejs handling node event value updated entity Cover#zwavejs>20-0 [latest-23242]2023-09-08T05:40:26.334Z <ZWaveJSController:5:ZWaveJSController.js:667> ZWaveJSController#zwavejs update node 20 value "0:128:isLow:" data [Object]{ "source": "node", "event": "value updated", "nodeId": 20, "args": { "commandClassName": "Battery", "commandClass": 128, "property": "isLow", "endpoint": 0, "newValue": false, "prevValue": false, "propertyName": "isLow" } } [latest-23242]2023-09-08T05:40:26.336Z <ZWaveJSController:5:ZWaveJSController.js:324> ZWaveJSController#zwavejs request 1694151625064<9/8/2023, 1:40:25 AM> (node.refresh_values) success notification [latest-23242]2023-09-08T05:40:26.337Z <ZWaveJSController:5:ZWaveJSController.js:684> ZWaveJSController#zwavejs updating attributes for node 20 value "0:128:isLow:"=false: [Array][ ] [latest-23242]2023-09-08T05:40:26.338Z <ZWaveJSController:5:ZWaveJSController.js:722> ZWaveJSController#zwavejs setting Cover#zwavejs>20-0.x_zwave_values.Battery_isLow to false [latest-23242]2023-09-08T05:40:26.558Z <ZWaveJSController:5:ZWaveJSController.js:360> ZWaveJSController#zwavejs handling node event statistics updated entity Cover#zwavejs>20-0Please note the highlighted logpart - no other iblind has this. In addition, in MSR>Entities several show as null rather than having a value as the others do.
69631fbc-db4e-4e8d-aa98-10565811cd93-image.png
I tried deleting all Entities associated with this device from MSR and then refreshing ZWaveJS in Home Assistant and restarting MSR - the Entities return but in the same state/s.
Admittedly, it's been a very long three weeks at work - I could have missed something obvious during setup but I sure can't figure what it is.
Hi @toggledbits
I'm trying to use OWM, apparently, I receive the correct information, but after a while, the MSR disconnects.
My configuration is as follows.
- id: weather enabled: true implementation: OWMWeatherController name: OWM Weather config: # Place your OWM API key here (remember to enable the controller after adding your appid) appid: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" # How often weather is allowed to be refreshed. This helps limit OWN API use, # to keep you in their good graces (and on their free tier). This value is # in minutes. interval: 30 locations: - id: home name: Home Weather # Set the location by specifying ONE OF: latitude+longitude, OWN city # ID, or location (as postal,country). If none is set, the system # location will be used. latitude: 8.9936 longitude: -79.5197 city_id: 3703443 #location: "30269,us" # Enable "save_full_response" to save the full response (you may have # need to use parts of the response that are not part of the wx # capability in your dashboard widgets). #save_full_response: falseWhen I request a systemctl status reactor I get this message:
root@main:/home/wilson/reactor/logs# systemctl status reactor ● reactor.service - Multi System Reactor Loaded: loaded (/etc/systemd/system/reactor.service; enabled; vendor preset: enabled) Active: active (running) since Fri 2023-09-08 21:03:13 EST; 5s ago Main PID: 194711 (node) Tasks: 11 (limit: 9390) Memory: 82.5M CPU: 2.508s CGroup: /system.slice/reactor.service └─194711 /usr/bin/node app -p Sep 08 21:03:13 main node[194711]: Error: Incompatible serialization data; can't unserialize Sep 08 21:03:13 main node[194711]: at System.unserialize (/home/wilson/reactor/server/lib/Entity.js:624:19) Sep 08 21:03:13 main node[194711]: at /home/wilson/reactor/server/lib/Controller.js:458:70 Sep 08 21:03:13 main node[194711]: at Array.forEach (<anonymous>) Sep 08 21:03:13 main node[194711]: at OWMWeatherController._restoreEntities (/home/wilson/reactor/server/lib/Controller.js:446:36) Sep 08 21:03:13 main node[194711]: at new Controller (/home/wilson/reactor/server/lib/Controller.js:37:45) Sep 08 21:03:13 main node[194711]: at new OWMWeatherController (/home/wilson/reactor/server/lib/OWMWeatherController.js:327:9) Sep 08 21:03:13 main node[194711]: at /home/wilson/reactor/server/lib/Controller.js:93:37 Sep 08 21:03:13 main node[194711]: [latest-23242]2023-09-09T02:03:13.855Z <NUTController:null> Module NUTController v22305 Sep 08 21:03:13 main node[194711]: [latest-23242]2023-09-09T02:03:13.859Z <SystemController:null> Module SystemController v23214 root@main:/home/wilson/reactor/logs# root@main:/home/wilson/reactor# systemctl status reactor ● reactor.service - Multi System Reactor Loaded: loaded (/etc/systemd/system/reactor.service; enabled; vendor preset: enabled) Active: active (running) since Fri 2023-09-08 20:48:36 EST; 2min 58s ago Main PID: 194353 (node) Tasks: 11 (limit: 9390) Memory: 66.0M CPU: 9.493s CGroup: /system.slice/reactor.service └─194353 /usr/bin/node app -p Sep 08 20:48:37 main node[194353]: at System.unserialize (/home/wilson/reactor/server/lib/Entity.js:624:19) Sep 08 20:48:37 main node[194353]: at /home/wilson/reactor/server/lib/Controller.js:458:70 Sep 08 20:48:37 main node[194353]: at Array.forEach (<anonymous>) Sep 08 20:48:37 main node[194353]: at OWMWeatherController._restoreEntities (/home/wilson/reactor/server/lib/Controller.js:446:36) Sep 08 20:48:37 main node[194353]: at new Controller (/home/wilson/reactor/server/lib/Controller.js:37:45) Sep 08 20:48:37 main node[194353]: at new OWMWeatherController (/home/wilson/reactor/server/lib/OWMWeatherController.js:327:9) Sep 08 20:48:37 main node[194353]: at /home/wilson/reactor/server/lib/Controller.js:93:37 Sep 08 20:48:37 main node[194353]: [latest-23242]2023-09-09T01:48:37.017Z <NUTController:null> Module NUTController v22305 Sep 08 20:48:37 main node[194353]: [latest-23242]2023-09-09T01:48:37.024Z <SystemController:null> Module SystemController v23214 Sep 08 20:48:37 main node[194353]: [latest-23242]2023-09-09T01:48:37.475Z <Timer:null> Timer#rule-l7ujwva5 just a note: I'm setting a delay of > lines 1-20/20 (END)I can see this information in the log, but I don't understand what I should do to fix it.
[latest-23242]2023-09-09T02:03:13.838Z <DynamicGroupController:null> Module DynamicGroupController v22313 [latest-23242]2023-09-09T02:03:13.845Z <Structure:INFO> Structure#1 loading controller interface weather (OWMWeatherController) [latest-23242]2023-09-09T02:03:13.847Z <OWMWeatherController:null> Module OWMWeatherController v22294 [latest-23242]2023-09-09T02:03:13.850Z <Controller:WARN> OWMWeatherController#weather failed (1) to restore entity controller_all: [Error] Inco> [latest-23242]2023-09-09T02:03:13.850Z <Controller:CRIT> Error: Incompatible serialization data; can't unserialize [-] Error: Incompatible serialization data; can't unserialize at Group.unserialize (/home/wilson/reactor/server/lib/Entity.js:624:19) at /home/wilson/reactor/server/lib/Controller.js:458:70 at Array.forEach (<anonymous>) at OWMWeatherController._restoreEntities (/home/wilson/reactor/server/lib/Controller.js:446:36) at new Controller (/home/wilson/reactor/server/lib/Controller.js:37:45) at new OWMWeatherController (/home/wilson/reactor/server/lib/OWMWeatherController.js:327:9) at /home/wilson/reactor/server/lib/Controller.js:93:37 [latest-23242]2023-09-09T02:03:13.851Z <Controller:WARN> OWMWeatherController#weather failed (1) to restore entity default: [Error] Incompatibl> [latest-23242]2023-09-09T02:03:13.851Z <Controller:CRIT> Error: Incompatible serialization data; can't unserialize [-] Error: Incompatible serialization data; can't unserialize at Entity.unserialize (/home/wilson/reactor/server/lib/Entity.js:624:19) at /home/wilson/reactor/server/lib/Controller.js:458:70 at Array.forEach (<anonymous>) at OWMWeatherController._restoreEntities (/home/wilson/reactor/server/lib/Controller.js:446:36) at new Controller (/home/wilson/reactor/server/lib/Controller.js:37:45) at new OWMWeatherController (/home/wilson/reactor/server/lib/OWMWeatherController.js:327:9) at /home/wilson/reactor/server/lib/Controller.js:93:37 [latest-23242]2023-09-09T02:03:13.852Z <Controller:WARN> OWMWeatherController#weather failed (1) to restore entity system: [Error] Incompatible> [latest-23242]2023-09-09T02:03:13.852Z <Controller:CRIT> Error: Incompatible serialization data; can't unserialize [-] Error: Incompatible serialization data; can't unserialize at System.unserialize (/home/wilson/reactor/server/lib/Entity.js:624:19) at /home/wilson/reactor/server/lib/Controller.js:458:70 at Array.forEach (<anonymous>) at OWMWeatherController._restoreEntities (/home/wilson/reactor/server/lib/Controller.js:446:36) at new Controller (/home/wilson/reactor/server/lib/Controller.js:37:45) at new OWMWeatherController (/home/wilson/reactor/server/lib/OWMWeatherController.js:327:9) at /home/wilson/reactor/server/lib/Controller.js:93:37 [latest-23242]2023-09-09T02:03:13.853Z <Structure:INFO> Structure#1 loading controller interface nut (NUTController) [latest-23242]2023-09-09T02:03:13.855Z <NUTController:null> Module NUTController v22305 [latest-23242]2023-09-09T02:03:13.855Z <Controller:INFO> Loaded NUTController version "0.1.22305"; Patrick Rigney/Kedron Holdings LLC <patrick@> [latest-23242]2023-09-09T02:03:13.857Z <Structure:INFO> Structure#1 loading controller interface reactor_system (SystemController) [And finally, I have a second house, with the same OWM configuration I made today, and it doesn't show any errors.
Please, your traditional help.
Thanks.
After a prolonged power cut, the UPS was unable to cope with the weather and shut down the entire system.
When I returned, I had the problem that the host time displayed in the browser and automatically used in the rules was not correct.
I searched for a topic here on this forum that talked about it, but it referred to a container installation. There was a recommendation to go into the storage/states directory and delete the files and restart MSR, I did it and it didn't solve the problem.
There was also a recommendation to go directly to the browser to check the time, and I did so and I see that the time is correct.
8ad429c8-ea5f-45b4-8670-7d0353a50a0e-image.png
As you can see on the screen above:
MSR browser shows the correct browser time 21:23, but host time 13:02; In the browser below the direct query and the host time is correct 9:22:54 PM; Setting the VM date command on the third screen, the time is 9:23:00 PM.I've opened the entire reactor.log file and searched for any errors, and there aren't any.
^L [latest-23242]2023-09-15T02:11:12.928Z <app:null> Reactor build latest-23242-5ee8e1d4 starting on v18.12.0 [latest-23242]2023-09-15T02:11:12.929Z <app:null> Process ID 1807 user/group 1000/1000; bare-metal; platform linux/x64 #179-Ubuntu SMP Mo> [latest-23242]2023-09-15T02:11:12.929Z <app:null> Basedir /home/leonardo/reactor; data in /home/leonardo/reactor/storage [latest-23242]2023-09-15T02:11:12.929Z <app:null> NODE_PATH=/home/leonardo/reactor [latest-23242]2023-09-15T02:11:12.933Z <app:INFO> Configured locale (undefined); selected locale(s) en_US.UTF-8 [latest-23242]2023-09-15T02:11:12.955Z <app:INFO> Loaded locale en-US for en-US [latest-23242]2023-09-15T02:11:12.958Z <Structure:null> Module Structure v23172 [latest-23242]2023-09-15T02:11:12.959Z <Capabilities:null> Module Capabilities v22356 [latest-23242]2023-09-15T02:11:12.969Z <Capabilities:NOTICE> System capabilities loaded from core distribution, data version 23914 revisi> [latest-23242]2023-09-15T02:11:12.978Z <Plugin:null> Module Plugin v22300 [latest-23242]2023-09-15T02:11:12.981Z <TimerBroker:null> Module TimerBroker v22283 [latest-23242]2023-09-15T02:11:12.983Z <Entity:null> Module Entity v22353 [latest-23242]2023-09-15T02:11:12.986Z <Controller:null> Module Controller v23069 [latest-23242]2023-09-15T02:11:12.992Z <default:null> Module Ruleset v22293 [latest-23242]2023-09-15T02:11:12.992Z <default:null> Module Rulesets v22146 [latest-23242]2023-09-15T02:11:12.996Z <GlobalExpression:null> Module GlobalExpression v23211 [latest-23242]2023-09-15T02:11:13.003Z <Predicate:null> Module Predicate v23093 [latest-23242]2023-09-15T02:11:13.005Z <AlertManager:null> Module AlertManager v22283 [latest-23242]2023-09-15T02:11:13.007Z <Rule:null> Module Rule v23107 [latest-23242]2023-09-15T02:11:13.009Z <GlobalReaction:null> Module GlobalReaction v22324 [latest-23242]2023-09-15T02:11:13.010Z <Engine:null> Module Engine v23231 [latest-23242]2023-09-15T02:11:13.012Z <httpapi:null> Module httpapi v23058 [latest-23242]2023-09-15T02:11:13.019Z <wsapi:null> Module wsapi v23172 [latest-23242]2023-09-15T02:11:13.019Z <app:NOTICE> Starting Structure...As you can see, the time in the log is 02:11, which is correct, because I'm in time zone -5, which means it's 09:11PM for me.
I've restarted the VM, the computer hosting the VM, and the MSR a few times and the same difference remains. What do you recommend for the next step in understanding and solving the problem?
Thanks.
Good afternoon,
I'm running my MSR instance on an old NAS server running Fedora 37 Server. This is an older Core i5-4690K server that has served me well overall, but it's showing it's age, and will often reboot into maint mode if it applies updates overnight. I've been trying to troubleshoot, but it's also in my office (makes my office hot), and I'm looking at getting either a QNAP or Syslogy rack mount NAS to replace it.
What I'm wondering is what the process would be to migrate my current MSR config and move it to a different platform. I have quite a large ruleset that I don't want to have to recreate. I know I can run it in a container on either platform, but I'm not sure how I would migrate all my rules over. Is there one config file that has all of the rules, or could I simply copy my /reactor directory over to a enw platform?
I am also considering moving the MSR instance to a stand alone RPI 4 with a SSD. This way, while I'm migrating all of my files off of my NAS, I'm not loosing Reactor's functionality until I have whichever rack mount NAS I go with up and running, with all of the data migrated.
Thoughts?
Can I use Dynamic Group Control for Triggers and Reactions?
-
Good evening all,
I've run across a quirk with my iBlinds motors in Home Assistant. Each iBlinds zwave motor has two controls that I can use. One is a switch, and one is a cover control.cid:A1190F3F-FB02-4332-93DE-9A15A490D9AB
The switch control is a binary on/off switch. On, the blind goes to the "open" position (v2 controllers, 50%, v3 controllers user definable parameter)
If you click on the cover icon, it moves between two positions. Essentially, it's closed in both positions, just 180 degrees apart. The cover control does give you the granularity to move to any position between 0 and 100, which is sometimes useful, when you just don't want it open or closed, such as letting some light in, but closing it enough when the sun is shining directly into the window and blinding everyone.
Here's the problem, which I've brought up with iBlinds support, and they're singing Simon and Garfunkel (Sound of Silence). The two controls don't update each other. If I open or close using the switch, the cover position value doesn't change. If I open or close using the cover control, the switch doesn't change to on or off. I've verified that this isn't just an issue with the dashboard/templates I'm using by going into the developer tools on HA and the values do not change. I've also checked those values in Reactor (Entities tab) and they do not update properly.
I've come up with a Reactor work around which sort of forces the controls to update. If anyone knows of a better way, please tell me. I have two rules set up that monitor for changes in the switch state, that then performs a x_haas_cover.set_cover_position to either 0 or 50 for either to off or to on respectively.
This is sort of a one way street at the moment. I don't have a reverse rule set up to change the switch value, but the current rule seems more of an issue.
All that being said. I have 14 iBlinds motors in my home. That would mean 28 rules in Reactor. I know how to set up a Dynamic Group Control for Triggers. I put all 14 switches in the reactor.yaml file, and I can use those for triggers. How would I go about using 14 corresponding cover controls for the reactions?
It may be a simple matter, but I'm not sure. One thing i can say is the name of the switch and cover entities are the same, except for the control type:
Edit:
Running:
Reactor: latest-23078-d592d400
Home Assistant 2023.3.5
Supervisor 2023.03.3
Operating System 9.5
Frontend 20230309.1 - latest -
@tamorgen So iBlinds are a funny beast. I'm running 11 of the v3's and my automations run the gamut from normal open/close to "tilt when the sun hits this side of the house", "tilt when I'm not home (for privacy)" - smashing the sun tilt together with the Away tilt... oh boy is that fun.
I use a Zooz ZWave stick connected to Home Assistant to run them. They're happy together but I also do run a ping rule hourly lest they lose sight of the stick. Hubitat runs the rest of the house for now.
To control them... oy. Here's a couple samples:
The
.refresh
keeps Home Assistant happy in keeping the two status' you have in your first screenshot in sync.I have fought long and hard over the past two years with many, many hours of trial and error with these and, even this morning, am still making adjustments. I am quite demanding of my automations with them, in all fairness to both the blinds themselves and MSR.
ProTip: if you're controlling multiple iBlinds in one automation, a five or so second delay between each blind's actions will help a LOT. I believe I actually got that advice from iBlinds Support (when they answer).
Yes - you will have a LOT of iBlinds rules and reactions to truly control these bad boys. No - you will never get them all to open/close simultaneously. I've settled on a nice routine where they start their actions at the front of the house and end at the back, each performing it's task sequentially after the other. Not quite as cool but it's still ok.
OH - I also do a weekly recalibration to keep the iBlinds "accurate" lest they drift a bit over time.
To your actual ask - I've installed the Dynamic Group Controller but not delved into it as yet. Hopefully the info above helps you as the iBlinds rabbithole can run deep and dark. MSR has been key in my ability to get the iBlinds to function the best of any integration I've tried.
-
Note that @gwp1 is using ZWaveJSController to interface with iBlinds, not HassController. So this is more direct control that circumvents HA's interpretation.
-
@gwp1 said in Can I use Dynamic Group Control for Triggers and Reactions?:
@tamorgen So iBlinds are a funny beast. I'm running 11 of the v3's and my automations run the gamut from normal open/close to "tilt when the sun hits this side of the house", "tilt when I'm not home (for privacy)" - smashing the sun tilt together with the Away tilt... oh boy is that fun.
I use a Zooz ZWave stick connected to Home Assistant to run them. They're happy together but I also do run a ping rule hourly lest they lose sight of the stick. Hubitat runs the rest of the house for now.
To control them... oy. Here's a couple samples:
The
.refresh
keeps Home Assistant happy in keeping the two status' you have in your first screenshot in sync.I have fought long and hard over the past two years with many, many hours of trial and error with these and, even this morning, am still making adjustments. I am quite demanding of my automations with them, in all fairness to both the blinds themselves and MSR.
ProTip: if you're controlling multiple iBlinds in one automation, a five or so second delay between each blind's actions will help a LOT. I believe I actually got that advice from iBlinds Support (when they answer).
Yes - you will have a LOT of iBlinds rules and reactions to truly control these bad boys. No - you will never get them all to open/close simultaneously. I've settled on a nice routine where they start their actions at the front of the house and end at the back, each performing it's task sequentially after the other. Not quite as cool but it's still ok.
OH - I also do a weekly recalibration to keep the iBlinds "accurate" lest they drift a bit over time.
To your actual ask - I've installed the Dynamic Group Controller but not delved into it as yet. Hopefully the info above helps you as the iBlinds rabbithole can run deep and dark. MSR has been key in my ability to get the iBlinds to function the best of any integration I've tried.
I've been running 14 iBlinds v2 since 2019, and I just replaced 2 of them with v3.1. I've always had issues with the units responding consistently. The answers I've gotten from their support is "try repairing it closer", or you need to have beaming repeaters. I have 75 Z-wave devices in my house, and every single device that is hard wired is beaming. I think they just have a script that assumes it's the users fault, and they really aren't interested in helping.
I could set up a ping hourly, and that may help with connectivity. I don't run them all at once. I have Reactor set to "wait for completion" on each of the reactions before moving on to the next one.
None of this unfortunately addresses the issue of the switch control and the cover control not being in sync. I don't seem to have a .refresh command in HA, or at least I'm not sure where it is. If that syncs them up, then I'll be happy. Where is that refresh command located?
-
T toggledbits forked this topic on
-
@gwp1 said in Can I use Dynamic Group Control for Triggers and Reactions?:
@tamorgen That sounds vaguely familiar!
Low and behold iBlinds support finally got back with me, and they actually acknowledged the original problem I was seeing was actually a problem.
Hi Timothy, Very sorry for the delayed response, we have been getting more reports of this issue and have been building up to a solution. We have determined this to be a driver issue within Home Assistant that will need to be addressed for each hub. We have never really sent battery report until battery level drops to the low battery alert threshold and this feature is required by zwave certification. We always had the hub poll the battery level since some hubs opted for polling the device independently of the device sending a report. We will need to add polling to the HA driver and other drivers of the same issue. Thank you for your patience. Thanks, Chance H. The iBlinds Team
and
Hi Timothy, To add to this, the polling will update the position as well as the battery to address your issue specifically. Thanks, Chance H. The iBlinds Team
Feeling some vindication, after their original emails were all to the tone of "you're doing it wrong, you need to exclude and pair your devices. You need beaming repeaters (I guess the 55 other devices that aren't battery powered and are beaming don't count)."
-
T toggledbits locked this topic on
-
T toggledbits unlocked this topic on
-
I've split this topic. This thread remains for discussion specific to iBlinds only; if you have further comments on your issue getting ZWaveJSController running, please make those in the new thread where that specific discussion takes place.
-
@toggledbits said in Can I use Dynamic Group Control for Triggers and Reactions?:
I've split this topic. This thread remains for discussion specific to iBlinds only; if you have further comments on your issue getting ZWaveJSController running, please make those in the new thread where that specific discussion takes place.
Thanks Patrick, that's fine. I knew it was going off on a bit of a tangent and asked you to fork it a bit ago.
Back to the original subject, now that I'm have ZWaveJSController working and I can use the refresh command, I still want to set up a rule based upon a state changing to poll the entity and force that refresh.
I set up the Dynamic Groups in my reactor.yaml using the zwavejs entities. I have three ones set up. One for the switch state, one for the position state, and one for the cover state. This way, I can run refresh if anyone of them changes. If there is a better way, please let me know.
"iblinds_switch": select: - include_entity: - 'zwavejs>63-0' - 'zwavejs>62-0' - 'zwavejs>64-0' - 'zwavejs>65-0' - 'zwavejs>79-0' - 'zwavejs>77-0' - 'zwavejs>78-0' - 'zwavejs>206-0' - 'zwavejs>205-0' - 'zwavejs>75-0' - 'zwavejs>74-0' - 'zwavejs>71-0' - 'zwavejs>16-0' - 'zwavejs>61-0' filter_expression: > entity.power_switch.state "iblinds_position": select: - include_entity: - 'zwavejs>63-0' - 'zwavejs>62-0' - 'zwavejs>64-0' - 'zwavejs>65-0' - 'zwavejs>79-0' - 'zwavejs>77-0' - 'zwavejs>78-0' - 'zwavejs>206-0' - 'zwavejs>205-0' - 'zwavejs>75-0' - 'zwavejs>74-0' - 'zwavejs>71-0' - 'zwavejs>16-0' - 'zwavejs>61-0' filter_expression: > entity.cover.position.value "iblinds_cover": select: - include_entity: - 'zwavejs>63-0' - 'zwavejs>62-0' - 'zwavejs>64-0' - 'zwavejs>65-0' - 'zwavejs>79-0' - 'zwavejs>77-0' - 'zwavejs>78-0' - 'zwavejs>206-0' - 'zwavejs>205-0' - 'zwavejs>75-0' - 'zwavejs>74-0' - 'zwavejs>71-0' - 'zwavejs>16-0' - 'zwavejs>61-0' filter_expression: > entity.cover.state
The rule I'm trying to set up is to look for any change on those switches (on to off or off to on), and then set a reaction to refresh the cover (zwave_device.refresh)
In the set reaction, it doesn't appear to let my dig down any further once I put the group in. What do I need to do to make this work, if it's even possible.
-
@tamorgen said in Can I use Dynamic Group Control for Triggers and Reactions?:
In the set reaction, it doesn't appear to let my dig down any further once I put the group in. What do I need to do to make this work, if it's even possible.
Experimental, undocumented feature: add
group_actions: true
to your group's configuration:"iblinds_switch": select: - include_entity: - 'zwavejs>63-0' ... - 'zwavejs>61-0' filter_expression: "entity.power_switch.state" group_actions: true
-
@toggledbits said in Can I use Dynamic Group Control for Triggers and Reactions?:
@tamorgen said in Can I use Dynamic Group Control for Triggers and Reactions?:
In the set reaction, it doesn't appear to let my dig down any further once I put the group in. What do I need to do to make this work, if it's even possible.
Experimental, undocumented feature: add
group_actions: true
to your group's configuration:"iblinds_switch": select: - include_entity: - 'zwavejs>63-0' ... - 'zwavejs>61-0' filter_expression: "entity.power_switch.state" group_actions: true
Thanks Patrick. I'll give that a try.
-
@toggledbits said in Can I use Dynamic Group Control for Triggers and Reactions?:
@tamorgen said in Can I use Dynamic Group Control for Triggers and Reactions?:
In the set reaction, it doesn't appear to let my dig down any further once I put the group in. What do I need to do to make this work, if it's even possible.
Experimental, undocumented feature: add
group_actions: true
to your group's configuration:"iblinds_switch": select: - include_entity: - 'zwavejs>63-0' ... - 'zwavejs>61-0' filter_expression: "entity.power_switch.state" group_actions: true
You said it was unsupported
Reactor doesn't seem to like my filter.
[latest-23078]2023-04-03T18:19:59.724Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>63-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-]
These are the values when I look at the Entities tab for one of the blind controllers.
-
Well that has nothing to do with group actions. It's specifically complaining about your filter. Hass is famous for giving null state when a device is unreachable or still initializing. If the DGC comes up faster than Hass, you get those messages. They usually don't stick.
And please remember the posting guidelines. When posting an error, don't just post the error message; you need to post several dozen lines from before it, for context.
-
@toggledbits said in Can I use Dynamic Group Control for Triggers and Reactions?:
Well that has nothing to do with group actions. It's specifically complaining about your filter. Hass is famous for giving null state when a device is unreachable or still initializing. If the DGC comes up faster than Hass, you get those messages. They usually don't stick.
And please remember the posting guidelines. When posting an error, don't just post the error message; you need to post several dozen lines from before it, for context.
Understood, however, the system has been back up for white a while, and it just keeps repeating those errors. The lines I'm seeing before are unrelated and appear to be just normal reactions in my system.
[latest-23078]2023-04-03T18:44:11.461Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>63-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>62-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>64-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>65-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>79-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>77-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>78-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.462Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Cover#zwavejs>206-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Cover#zwavejs>205-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>75-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>74-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>71-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>16-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T18:44:11.463Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.cover.state error with Light#zwavejs>61-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-]
-
I restarted Reactor to see if I could see anything coming back up.
latest-23078]2023-04-03T19:06:05.925Z <Structure:INFO> Structure#1 stopping DynamicGroupController#groups [latest-23078]2023-04-03T19:06:05.926Z <DynamicGroupController:null> DynamicGroupController#groups stopping [latest-23078]2023-04-03T19:06:05.926Z <Controller:NOTICE> DynamicGroupController#groups stopping [latest-23078]2023-04-03T19:06:05.927Z <Controller:ERR> Controller DynamicGroupController#groups is off-line! [latest-23078]2023-04-03T19:06:09.706Z <Structure:INFO> Structure#1 loading controller interface groups (DynamicGroupController) [latest-23078]2023-04-03T19:06:09.710Z <DynamicGroupController:null> Module DynamicGroupController v22313 [latest-23078]2023-04-03T19:06:09.746Z <Structure:INFO> Starting controller DynamicGroupController#groups [latest-23078]2023-04-03T19:06:09.750Z <Controller:NOTICE> Controller DynamicGroupController#groups is now online. [latest-23078]2023-04-03T19:06:14.711Z <DynamicGroupController:INFO> All controllers ready, setting up dynamic groups [latest-23078]2023-04-03T19:06:14.728Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>63-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.728Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>62-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.728Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>64-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.728Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>65-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.728Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>79-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.729Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>77-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.729Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Light#zwavejs>78-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.729Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Cover#zwavejs>206-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-] [latest-23078]2023-04-03T19:06:14.729Z <DynamicGroupController:ERR> DynamicGroupController#groups filter expression entity.power_switch.state error with Cover#zwavejs>205-0: [ReferenceError] Invalid scope in reference to member state of (object)null [-]
-
OK. Two things:
-
When I made the example for
group_actions
above, I abbreviated the select and filter expressions, which I didn't expect you to copy verbatim; I just put it there for alignment/indenting. Use the select and filter expressions you had previously. -
Update to the 23093 version of ZWaveJSController I just released, which fixes another small iBlinds issue.
-
-
@toggledbits said in Can I use Dynamic Group Control for Triggers and Reactions?:
OK. Two things:
-
When I made the example for
group_actions
above, I abbreviated the select and filter expressions, which I didn't expect you to copy verbatim; I just put it there for alignment/indenting. Use the select and filter expressions you had previously. -
Update to the 23093 version of ZWaveJSController I just released, which fixes another small iBlinds issue.
Thanks. I thought the filter expressions format had changed for with the group_actions flag, so I changed it to your example.
I also updated to the latest ZWaveJSController.
I still eppar to be getting those same errors, even with changing back to:
"iblinds_switch": select: - include_entity: - 'zwavejs>63-0' - 'zwavejs>62-0' - 'zwavejs>64-0' - 'zwavejs>65-0' - 'zwavejs>79-0' - 'zwavejs>77-0' - 'zwavejs>78-0' - 'zwavejs>206-0' - 'zwavejs>205-0' - 'zwavejs>75-0' - 'zwavejs>74-0' - 'zwavejs>71-0' - 'zwavejs>16-0' - 'zwavejs>61-0' filter_expression: > entity.power_switch.state group_actions: true "iblinds_position": select: - include_entity: - 'zwavejs>63-0' - 'zwavejs>62-0' - 'zwavejs>64-0' - 'zwavejs>65-0' - 'zwavejs>79-0' - 'zwavejs>77-0' - 'zwavejs>78-0' - 'zwavejs>206-0' - 'zwavejs>205-0' - 'zwavejs>75-0' - 'zwavejs>74-0' - 'zwavejs>71-0' - 'zwavejs>16-0' - 'zwavejs>61-0' filter_expression: > entity.cover.position.value group_actions: true
-
-
entity.attributes.power_switch.state
and the same change for the others, like you had originally. -
@toggledbits
Thanks, that did the trick. Do I need to use the local expressions when using this approach? I'm guessing no. -
That would depend on what you're using them for. The only one I see above is to make a list of entity names from a group's members, presumably to use it in a message or something else not yet completed?
-
T toggledbits locked this topic on