Use case:
When performing home maintenance, such as air conditioning, I want all rules involving air conditioning to be disabled.
To do this, to day, I have a virtual switch that I placed within all rules involving air conditioning, meaning that if I turn it off, none of them work.
Then another situation: the water pump system and garden irrigation, another switch.
In short, I had to create several virtual switches in Hubitat to disable rules in MSR.
Unfortunately, however, I was unable to cover all scenarios, so I wondered if it would be possible for MSR to support a virtual MSR switch, which, when configured in the reactor settings, would function as a general on/off switch for MSR.
If it is configured and turned off, the entire rules and actions in MSR stops working, except for the status change reading process, specifically for this switch, which, when turned on, would restart the MSR.
Would it be possible to do something like this? Any recommendations from the experts?
@toggledbits, not sure if this is a feature request or I'm using the search tool wrong. You have a "Search for rule" in the Rules Set tab in MSR. It works nicely to find a rule and bring up said rule, but can it/could it be used for as a "where used?" global search? For instance, I have a fairly large set of rules, divided up into 10 different rulesets. There's easily a hundred individual rules, and many of the rules have Rule State triggers, which of course refer to other rules. Amongst my troubleshooting today, I came across what may have been a duplicate or troubleshooting attempt, but I can't tell if it's actually used as a Rule State in another rule without opening each rule that I suspect it may be a part of.
Thanks.
I'm running MSR build 25139 on Docker, using MQTT controller 24293, and everything working as expected. But if I try to upgrade to MQTTController build 25139, I'm getting the following errors on MSR UI:
An Entity Attribute condition in "Lay-Z-Spa auto heating off" (Terrace) failed because the referenced entity "Lay-Z-Spa States" (mqtt>layzspa_states) does not have attribute value_sensor.god
Last 11:20:37
An Entity Attribute condition in "Lay-Z-Spa auto heating off" (Terrace) failed because the referenced entity "Lay-Z-Spa States" (mqtt>layzspa_states) does not have attribute temperature_sensor.green
Last 11:20:37
An Entity Attribute condition in "Lay-Z-Spa filter pump auto off" (Terrace) failed because the referenced entity "Lay-Z-Spa States" (mqtt>layzspa_states) does not have attribute temperature_sensor.red
Last 11:20:37
An Entity Attribute condition in "Lay-Z-Spa filter pump auto run" (Terrace) failed because the referenced entity "Lay-Z-Spa States" (mqtt>layzspa_states) does not have attribute value_sensor.pump
Last 11:20:37
An Entity Attribute condition in "Lay-Z-Spa watchdog" (Terrace) failed because the referenced entity "Lay-Z-Spa States" (mqtt>layzspa_states) does not have attribute value_sensor.status
Last 11:20:37
My MQTT configuration (local_mqtt_devices.yaml) for the related entity is:
layzspa_message:
type: ValueSensor
capabilities: ["temperature_sensor", "value_sensor", "power_sensor"]
primary_attribute: power_sensor.value
events:
"layzspa/message":
"power_sensor.value":
json_payload: true
if_expr: '! isnull( payload?.PWR )'
expr: "float(payload.PWR)"
"value_sensor.air":
json_payload: true
if_expr: '! isnull( payload?.AIR )'
expr: "float(payload.AIR)"
"value_sensor.pump":
json_payload: true
if_expr: '! isnull( payload?.FLT )'
expr: "float(payload.FLT)"
"value_sensor.god":
json_payload: true
if_expr: '! isnull( payload?.GOD )'
expr: "float(payload.GOD)"
"value_sensor.lock":
json_payload: true
if_expr: '! isnull( payload?.LCK )'
expr: "float(payload.LCK)"
"value_sensor.unit":
json_payload: true
if_expr: '! isnull( payload?.UNT )'
expr: "float(payload.UNT)"
"value_sensor.error":
json_payload: true
if_expr: '! isnull( payload?.ERR )'
expr: "float(payload.ERR)"
"temperature_sensor.green":
json_payload: true
if_expr: '! isnull( payload?.GRN )'
expr: "float(payload.GRN)"
"temperature_sensor.red":
json_payload: true
if_expr: '! isnull( payload?.RED )'
expr: "float(payload.RED)"
"temperature_sensor.target":
json_payload: true
if_expr: '! isnull( payload?.TGT )'
expr: "float(payload.TGT)"
"temperature_sensor.value":
json_payload: true
if_expr: '! isnull( payload?.TMP )'
expr: "float(payload.TMP)"
"temperature_sensor.virtual":
json_payload: true
if_expr: '! isnull( payload?.VTM )'
expr: "round(float(payload.VTM), 1)"
"temperature_sensor.ambient":
json_payload: true
if_expr: '! isnull( payload?.AMB )'
expr: "float(payload.AMB)"
"layzspa/Status":
"value_sensor.status":
if_expr: '! isnull( payload )'
expr: "payload"
"layzspa/button":
"value_sensor.button":
if_expr: '! isnull( payload )'
expr: "payload"
and in reactor.yaml I have:
"layzspa_states":
name: "Lay-Z-Spa States"
friendly_name: 'Lay-Z-Spa States'
include: layzspa_message
I realize my MQTT configuration might be a bit unorthodox, but could there still be something unintentional in the latest MQTTController build? If needed, I can provide detailed logs.
Since today is my birthday - and I still pretend to be unconventional - I'm giving away a present to this wonderful community and I'm releasing my first OpenSprinkler controller for MSR. It was real fun to code it - and while it's still WIP, it seems to work OK for me. It's polling-based at the moment, but I'll add support for updates via MQTT very soon (it's already partially coded).
Get it at (install is similar to MQTTController and such):
https://github.com/dbochicchio/reactor-opensprinkler
Feel free to try it. It's beta software, but it's stable. I'll update it weekly until all the tasks from my todo list are empty.
Since I've learnt a lot from this controller, I'll explore new controllers soon.
Good day all,
I'm in the process of trying to shut down my 10 year old Linux home server that served many purposes, but primarily it's what I used for my NAS/Plex Media server. I migrated the NAS aspect of the server in November of last year to a true NAS solution (Ubiquti UNAS Pro), which is rack mount and much more efficient than my old tower, which it's only side benefit was heating my home office during the winter. Unfortunately it also means heating my home office during the summer, which were about to be in full swing.
I have two things running on this 10 year old server at this point. MSR and pi-hole. I'm running Plex Media Server on Fedora Workstation in Podman on mini PC, which is much more energy efficient than my old tower. My next step is to migrate MSR. I know there are images of MSR out there, and creating it is well documented. I'm going to be using Podman instead of Docker for various reasons, but they work very similar. What I don't know, is what I need to do to migrate my existing Bare Metal installation over to a container.
Has anyone done this? Any advice?
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 guys,
Just wondering how you guys organize your rule sets and rules. I wish I had an extra layer to have some more granularity, but my feature request was not popular.
Maybe there are better ways to organize my rule sets.
I use the rule sets now primarily for rooms. So a rule set per room. But maybe grouping by functionality works better. Any examples/ suggestions would be appreciated.
I have the following yaml configuration in local_mqtt_devices file
x_mqtt_device:
set_speed:
arguments:
speed:
type: str
topic: "command/%friendly_name%"
payload:
type: json
expr: '{ "fan": parameters.speed }'
While this works fine, I'm wondering how this could be changed to "fixed" parameters, as in this case "fan" only accepts "A", "Q" or a numeric value of 1-5?
Hubitat primary attribute
-
I am trying to display the primary attribute on this device like all my other Hubitat devices. The attribute is x_hubitat_extra_attributes.Status. This gives an error in the log. I can't see what I am doing wrong with this one. Do I need to to something different to display this?
Log:[latest-21286]2021-10-16T14:42:23.141Z <HassController:INFO> HassController#hass device mapping data loaded; checking... [latest-21286]2021-10-16T14:42:23.166Z <HassController:NOTICE> HassController#hass attempting reconnection to ws://192.168.1.21:8123/api/websocket [latest-21286]2021-10-16T14:42:23.168Z <HassController:NOTICE> HassController#hass connecting via WS to ws://192.168.1.21:8123/api/websocket [latest-21286]2021-10-16T14:42:23.246Z <Controller:NOTICE> Controller SystemController#reactor_system is now online. [latest-21286]2021-10-16T14:42:23.269Z <app:INFO> Structure running; pausing for controllers' initial ready [latest-21286]2021-10-16T14:42:23.273Z <HubitatController:NOTICE> HubitatController#hubitat not ready; performing initial connect/query [latest-21286]2021-10-16T14:42:23.290Z <HassController:NOTICE> HassController#hass connected, starting protocol [latest-21286]2021-10-16T14:42:23.296Z <HassController:INFO> HassController#hass successful authentication with ws://192.168.1.21:8123; fetching initial data... [latest-21286]2021-10-16T14:42:23.300Z <HassController:INFO> HassController#hass Hass reports version "2021.10.5" location Home timezone America/Chicago state RUNNING safe_mode false [latest-21286]2021-10-16T14:42:23.303Z <HassController:ERR> HassController#hass reported Hass version "2021.10.5" is not supported! [latest-21286]2021-10-16T14:42:23.379Z <HassController:NOTICE> Controller HassController#hass is now online. [latest-21286]2021-10-16T14:42:23.563Z <default:ERR> [Entity:setPrimaryAttribute] Attempt to set primary to x_hubitat_extra_attributes.Status invalid, not in { "x_hubitat": { "id": "568", "name": "BlinkAPI", "commands": [ "ArmSystem", "Authorize", "CheckSyncModule", "DisableMotionDetection", "DisarmSystem", "EnableMotionDetection", "GetCameraInfo", "GetCameraLiveView", "GetCameraSensors", "GetCameraStatus", "GetCameraUsage", "GetHomescreen", "GetNetworkStatus", "GetNetworks", "GetNewThumbnail", "GetNotifications", "GetVideoEvents", "ListSchedules", "VerifyPIN", "refresh" ], "capabilities": [ "Actuator", "Refresh", "Sensor" ] }, "x_hubitat_Actuator": { }, "x_hubitat_Refresh": { }, "x_hubitat_Sensor": { }, "x_hubitat_extra_commands": { } } [latest-21286]2021-10-16T14:42:23.566Z <HubitatController:ERR> HubitatController#hubitat failed to connect/query http://192.168.1.70/apps/api/416: Error: Entity#hubitat>568:setPrimaryAttribute() can't set x_hubitat_extra_attributes.Status, not defined for entity [latest-21286]2021-10-16T14:42:23.567Z <HubitatController:CRIT> Error: Entity#hubitat>568:setPrimaryAttribute() can't set x_hubitat_extra_attributes.Status, not defined for entity Error: Entity#hubitat>568:setPrimaryAttribute() can't set x_hubitat_extra_attributes.Status, not defined for entity at Entity.setPrimaryAttribute (/opt/reactor/server/lib/Entity.js:403:19) at /opt/reactor/server/lib/HubitatController.js:865:183 at Array.forEach (<anonymous>) at /opt/reactor/server/lib/HubitatController.js:805:76 at processTicksAndRejections (internal/process/task_queues.js:95:5) [latest-21286]2021-10-16T14:42:23.713Z <OWMWeatherController:INFO> OWMWeatherController#weather done; 1 locations, 0 failed [latest-21286]2021-10-16T14:42:23.714Z <OWMWeatherController:NOTICE> Controller OWMWeatherController#weather is now online. [latest-21286]2021-10-16T14:42:48.577Z <HubitatController:NOTICE> HubitatController#hubitat not ready; performing initial connect/query [latest-21286]2021-10-16T14:42:48.779Z <HubitatController:INFO> HubitatController#hubitat connecting to hub's eventsocket WebSocket API at ws://192.168.1.70/eventsocket [latest-21286]2021-10-16T14:42:48.781Z <HubitatController:NOTICE> Controller HubitatController#hubitat is now online. [latest-21286]2021-10-16T14:42:48.786Z <app:NOTICE> Starting HTTP server and API... [latest-21286]2021-10-16T14:42:48.791Z <app:NOTICE> Starting Reaction Engine... [latest-21286]2021-10-16T14:42:48.792Z <Engine:INFO> Reaction Engine starting [latest-21286]2021-10-16T14:42:48.792Z <Engine:INFO> Checking rule sets... [latest-21286]2021-10-16T14:42:48.798Z <Engine:INFO> Checking rules...
local_hubitat_devices.yaml:
-
OK. That's a sequencing issue in HubitatController. I can fix that and release a build later today.
Also, I opened PR 261 to memorialize it.
-
OK. That's a sequencing issue in HubitatController. I can fix that and release a build later today.
Also, I opened PR 261 to memorialize it.
@toggledbits Confirming Build 21292 fixed the issue. Thank You
-
T toggledbits locked this topic on