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?
TypeError: Can't subscribe to object that is not Observable - Synology Docker
Multi-System Reactor
1
Posts
1
Posters
136
Views
1
Watching
-
I noticed this error multiple times in the logs: TypeError: Can't subscribe to object that is not Observable ([object Object]) Looking through the older logs this has been there awhile. Any hints on what to look for to track down the cause?
Synology Docker
v22025[latest-22025]2022-01-28T02:23:53.685Z <Rule:INFO> Watch TV (Rule#rule-knm8t6w2) starting evaluation; because startup [latest-22025]2022-01-28T02:23:53.685Z <Rule:INFO> Wardrobe Light (Rule#rule-kmmos2n7) starting evaluation; because startup [latest-22025]2022-01-28T02:23:53.691Z <Rule:INFO> Bedroom Scentsy (Rule#rule-kxm5tblk) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.693Z <Rule:INFO> Basement Minimote (Rule#rule-krbebzmw) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.694Z <Rule:INFO> Driveway Lights 40 (Rule#rule-kp4tw7tq) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.696Z <Rule:INFO> Driveway Lights 100 (Rule#rule-kp4tmgu6) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.698Z <Rule:INFO> Garage Door Presence (Rule#rule-kqztn5y9) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.699Z <Rule:INFO> Steve’s Garage Door (Rule#rule-knaz3on5) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.700Z <Rule:INFO> Vicki’s Garage Door (Rule#rule-kpemuy7m) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.702Z <Rule:INFO> Sun Elevation (Rule#rule-kx9xfe1f) evaluated; rule state transition from RESET to SET! [latest-22025]2022-01-28T02:23:53.718Z <Rule:INFO> OATemp Set (Rule#rule-ku660ffy) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.719Z <Rule:INFO> Hubitat Weekly Reboot (Rule#rule-ktuxil18) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.720Z <Rule:INFO> SunTimes (Rule#rule-kstnjezi) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.725Z <Rule:INFO> UPS Power Restored (Rule#rule-krvblyyr) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.731Z <Rule:INFO> UPS Power Outage (Rule#rule-krvblruz) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.735Z <Rule:INFO> Ring Power Restored (Rule#rule-kq4hhtmg) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.739Z <Rule:INFO> Ring Power Outage (Rule#rule-kpery3cq) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.740Z <Rule:INFO> UPS Hubitat Shutdown (Rule#rule-kpyt9iei) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.741Z <Rule:INFO> Sticks (Rule#rule-kpbmbi2d) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.743Z <Rule:INFO> Low Light (Rule#rule-kulslls9) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.744Z <Rule:INFO> Living Room Scentsy (Rule#rule-kuanpjpf) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.746Z <Rule:INFO> Corner Lamp (Rule#rule-kt9d7daq) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.747Z <Rule:INFO> LED Strip (Rule#rule-kpd1bax4) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.748Z <Rule:INFO> Stairs Light Morning (Rule#rule-km7cdbq3) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.749Z <Rule:INFO> Stairs Light Evening (Rule#rule-km7asbhr) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.751Z <Rule:INFO> Stairs Light Late Night (Rule#rule-km7by6pt) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.752Z <Rule:INFO> Battery Level Notification (Rule#rule-kwsrtrm4) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.752Z <Rule:INFO> Roomba Bin Full Notify (Rule#rule-kot9hprp) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.753Z <Rule:INFO> Hass Update Notify (Rule#rule-kmcuosts) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.754Z <Rule:INFO> Hubitat DB Size Notifiy (Rule#rule-kwcw80sf) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.754Z <Rule:INFO> Office Minimote (Rule#rule-kq5udrzr) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.756Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.756Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.757Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) [latest-22025]2022-01-28T02:23:53.757Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.758Z <Rule:INFO> Patio Light On (Rule#rule-kpsdnu42) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.759Z <Rule:INFO> String Light Timed Off (Rule#rule-krybhbjp) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.759Z <Rule:INFO> Pantry Light (Rule#rule-kpw0p0rl) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.760Z <Rule:INFO> Landscape Lights (Rule#rule-kpc0wep6) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.761Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.762Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) [latest-22025]2022-01-28T02:23:53.762Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.762Z <Rule:INFO> Porch Light On (Rule#rule-kmtyzj5f) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.763Z <Rule:CRIT> TypeError: Can't subscribe to object that is not Observable ([object Object]) TypeError: Can't subscribe to object that is not Observable ([object Object]) at Rule.subscribe (/opt/reactor/server/lib/Observer.js:77:19) at Rule.subscribeAsDependency (/opt/reactor/server/lib/Rule.js:602:249) at RulePredicateContext.subscribeAsDependency (/opt/reactor/server/lib/RulePredicateContext.js:56:67) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:670:155) at Predicate._evaluateGroup (/opt/reactor/server/lib/Predicate.js:1021:103) at Predicate._evaluateCondition (/opt/reactor/server/lib/Predicate.js:628:47) at Predicate.evaluate (/opt/reactor/server/lib/Predicate.js:334:38) at Rule._evaluate (/opt/reactor/server/lib/Rule.js:826:56) at processTicksAndRejections (node:internal/process/task_queues:96:5) at async /opt/reactor/server/lib/Rule.js:782:17 [latest-22025]2022-01-28T02:23:53.764Z <Rule:INFO> Dog Lights On (Rule#rule-kyxq7no4) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.764Z <Rule:INFO> Good Night with Checks (Rule#rule-kxbbbjbr) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.765Z <Rule:INFO> Bedtime (Rule#rule-knmbhl4t) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.766Z <Rule:INFO> Blink Motion Disable (Rule#rule-kut0f7me) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.766Z <Rule:INFO> Motion Overide Auto Off (Rule#rule-kpd3stki) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.766Z <Rule:INFO> Sleep Time (Rule#rule-knqotlgu) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.769Z <Rule:INFO> String Lights Auto Off (Rule#rule-kwmscbwj) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.769Z <Rule:INFO> Trouble (Rule#rule-kso26jyb) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.770Z <Rule:INFO> Watch TV (Rule#rule-knm8t6w2) evaluated; trigger state unchanged (false); rule state remains RESET [latest-22025]2022-01-28T02:23:53.770Z <Rule:INFO> Wardrobe Light (Rule#rule-kmmos2n7) evaluated; trigger state unchanged (true); rule state remains SET [latest-22025]2022-01-28T02:23:53.773Z <Engine:INFO> Enqueueing "Sun Elevation<SET>" (rule-kx9xfe1f:S) [latest-22025]2022-01-28T02:23:53.777Z <httpapi:NOTICE> HTTP API v1 22021 base URL http://192.168.1.21:8111; listening [latest-22025]2022-01-28T02:23:53.789Z <app:NOTICE> HTTP server running; registering proxy endpoints. [latest-22025]2022-01-28T02:23:53.790Z <app:NOTICE> Starting WSAPI... [latest-22025]2022-01-28T02:23:53.791Z <wsapi:NOTICE> wsapi: starting version 21334