Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Unsolved
Collapse
Discussion Forum to share and further the development of home control and automation, independent of platforms.
  1. Home
  2. Software
  3. Multi-System Reactor
  4. Reactor logic talk
[Reactor] Variables not updating correctly in latest-25201-2aa18550
therealdbT
Topic thumbnail image
Multi-System Reactor
The reaction stopped working (Google Nest max playing a video)
F
Topic thumbnail image
Multi-System Reactor
Handling Dead Entities and Renamed Entities
PablaP
Hello all.. been a minute! I recently rebuilt my Z wave network and migrated to a new z wave stick. In order to prevent any downtime I kept my original z wave network up and ran a docker version of Z Wave JS UI with my new controller. This way I could add device by device without having any devices down. I finally moved all the devices over to my new stick today. The final step was to migrate everything from my Docker instance of Z Wave JS UI to the HA add-on of Z Wave JS UI. However during this migration some of the names didn't populate correctly which I later managed to import back into Z Wave JS UI. The issue was in Reactor it is stuck on the default names and the entities are not updating. I removed the controller from Reactor, restarted, hard refreshed, and added the controller back however the new entity names have not updated. Also it seems like the old entities from my previous instance of Z Wave JS UI are lingering and not being marked as dead (I believe a certain amount of time needs to lapse before they're marked as dead in Reactor). My goal is to basically purge all the entities for the 'ZWaveJS' controller in Reactor so it can pull all the updated entity names and only the entities that exist in Z Wave JS UI. I cannot find a quick way to do this, I know entities can be deleted one by one, but with over 100 entities this would take long I am guessing that if I added the controller with a new name in in the Reactor config it would pull the updated entities and names but I think that would break my rules since the entity IDs would change (I made sure to name all the entities the exact same as they were previously to prevent this issue).
Multi-System Reactor
Strange behavior for MQTT templates using payload and attributes
therealdbT
Topic thumbnail image
Multi-System Reactor
[MSR] reactor-mqtt-contrib package for additional MQTT templates
therealdbT
I'm slowly migrating all my stuff to MQTT under MSR, so I have a central place to integrate everything (and, in a not-so-distant future, to remove virtual devices from my Vera and leave it running zwave only). Anyway, here's my reactor-mqtt-contrib package: https://github.com/dbochicchio/reactor-mqtt-contrib Simply download yaml files (everything or just the ones you need) and you're good to go. I have mapped my most useful devices, but I'll add others soon. Feel free to ask for specific templates, since I've worked a lot in the last weeks to understand and operate them. The templates are supporting both init and query, so you have always up-to-date devices at startup, and the ability to poll them. Online status is supported as well, so you can get disconnected devices with a simple expression. Many-many thanks to @toggledbits for its dedication, support, and patience with me and my requests
Multi-System Reactor
HA 2025.9.4 Supported Yet?
CatmanV2C
Tangentially did I miss 2025.9.4 getting blessed in MSR? I've been holding off Cheers C
Multi-System Reactor
Rule Set UI bug - RESOLVED
3
Topic thumbnail image
Multi-System Reactor
[Reactor] Copy&Paste of Rules
therealdbT
I don't know if I'm the only one, but managing more than one Reactor installs, the need to have some sort of copy&paste for rules has grown on me. While I understand the technical challenges, I'm wondering if a "god mode" where I could copy the raw JSON rule and paste it into another rule could be an advanced, flag only feature that could benefit power users. I know I can copy the JSON file and proceed, but I must stop Reactor and when doing maintenance, it's more clicks to do. Just an idea
Multi-System Reactor
[Reactor] Help with screne controller cycling logic
therealdbT
I’ve added a couple of Shelly Wave i4 as scene controllers and I’m planning to add more, since I can just use standard buttons instead of battery-powered scene controllers, which also looks better aesthetically. That said, I’m struggling to figure out how to write a simple rule that cycles between states every time I press a button. Example: Light 1 ON → OFF, then Light 2 ON → OFF. The part I can’t get right is handling the case where Light 1 or Light 2 might already be ON independently of the rule. Maybe it’s just too much sun and relaxation clouding my brain, but any hint would be appreciated.
Multi-System Reactor
Stop the MSR by an external switch on Hubitat.
wmarcolinW
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?
Multi-System Reactor
Expose MSR entities
CatmanV2C
Probably a really dumb question. Currently I am using the owntracks_sensor for tracking phones being in region in MSR and it works great. Digging around with Home Assistant and toying with some dashboards, is there any way of exposing that sensor to HA trivially? I could set MSR to trip a virtual switch in OpenLuup which can then be exposed to HA (with all my other Vera devices) but that feels a bit in-elegant if I can do it directly. Any thoughts? Apologies if the ask is not clear/ TIA C
Multi-System Reactor
Comment in Globa Expressions
Tom_DT
I have several Global Expressions that are set by a rule so the definition area is blank. I'd like to add a comment in this area that explains what is setting the value. Commenting in this area breaks the remote setting. Any way to document what is setting the GE?
Multi-System Reactor
Unofficial thread for compatibility
tunnusT
As there are statements about compatibility for home assistant versions in MSR new version announcements (e.g. "HassController: Bless Hass to 2025.7.3"), I thought it would be good idea to track other controllers as well. As an example, I can confirm that build "latest-25208-c53e8513" works with Hubitat Elevation C-8 platform version 2.4.2.134 using Maker API. Updates: (the latest versions first in the list) OK: build "latest-25264-2fbe9217" with Hubitat C-8 platform v. 2.4.3.123
Multi-System Reactor
Gradually turn on lights.
Tom_DT
I have several lights that I would like to turn on very gradually over 15 or 20 seconds. from 0 to .25 in .01 increments. I have tried a few things that came nowhere near working, so here I am.
Multi-System Reactor
Reactor (Multi-System/Multi-Hub) Announcements
toggledbitsT
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.
Multi-System Reactor
Can't customize home page
G
I foolishly let my system wipe all cookies this morning and with it my settings for my MSR home page. Once logged back in I can no longer remove errant panes nor is the + available to add new ones. Brave Browser v1.80.122 (Jul 16, 2025) What have I done?! Will check other browsers on my M1. UPDATE: Safari exhibits same behaviour. I've tried both sans last-four public key entry and with - no change.
Multi-System Reactor
Error After Upgrade
T
Topic thumbnail image
Multi-System Reactor
Reset attribute value of entity in event handler
R
Topic thumbnail image
Multi-System Reactor
Need help figuring out how to delay a reset on reaction
T
Topic thumbnail image
Multi-System Reactor
Way to search for rules (rule state) in other rules
T
@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.
Multi-System Reactor

Reactor logic talk

Scheduled Pinned Locked Moved Multi-System Reactor
14 Posts 3 Posters 1.1k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • PerHP Offline
    PerHP Offline
    PerH
    wrote on last edited by
    #1

    I think most who play with automation logic comes to a point where the most logical (pun) solution evades us - this thread is for helping eachother making good logic. 🙂

    My issue of the day:
    I have a "night light" reactor that is supposed to turn on a very low level of lighting (navigation light) in the living room if there is movement when all lights are off.
    I want it to turn it on for 30 seconds, then off.
    Right now it senses on Motion Sensor, daylight(to see if its nessecary), and that all lights are off.
    it then turns on some lights, then a Delay for 30 seconds, then turn off.
    2667d40b-ecfd-4f4e-8242-a78c7f5ad5c8-image.png 2662cd91-c78c-4d49-81ed-571251469950-image.png

    When however my wife wakes up early, walks in and trips the sensor, and then turns on all the lights, the reactor is already in the delay phase, and subsequently turns off the lights. (WAF killer)

    I didn't want to use the Delay in the action, but i couldn't find a way to detect "x have been active for 30 seconds" or similar to keep it on?

    (i'm still in openLuup Reactor on this one, but i think the problem is common for both)

    1 Reply Last reply
    0
    • LibraSunL Offline
      LibraSunL Offline
      LibraSun
      wrote on last edited by
      #2

      My immediate reaction (if you'll pardon that pun!) is to notice that you have two competing Triggers:
      Tripped == 1
      and
      Tripped (changes) (any) to (any)

      Naturally, that pair will ONLY become true when Tripped == 1 immediately after == 0. Hence, you may as well not have the 2nd trigger.
      There's more to say, but wanted to lead with that basic fact.

      1 Reply Last reply
      0
      • PerHP Offline
        PerHP Offline
        PerH
        wrote on last edited by
        #3

        Yes, that's "by design", as i'm only using the "True" reaction in lack of a solution to the basic problem..
        If I had some way to make itself false after being enabled for 30 seconds..

        (good pun's are always welcome!)

        1 Reply Last reply
        1
        • LibraSunL Offline
          LibraSunL Offline
          LibraSun
          wrote on last edited by
          #4

          My gut tells me you might want to put something in the isFALSE Activity of your Reactor, which will automatically terminate the isTRUE one. When your wife turns on a light, we know that makes the Trigger section become FALSE (because now NOT "All the lights are off"). In which case you don't want the remainder of your isTRUE section to execute.

          Having one or more actions in the isFALSE should accomplish this.

          1 Reply Last reply
          0
          • PerHP Offline
            PerHP Offline
            PerH
            wrote on last edited by
            #5

            hmm.. but if I have "turn off night lights" in the IsFALSE, and the light is manually turned on (in day mode - more light) after this condition is True and night light is on, it will turn them back off immediately..

            A bit difficult to explain properly, but in essence i need a way to interrupt this automation on manual input..

            1 Reply Last reply
            0
            • LibraSunL Offline
              LibraSunL Offline
              LibraSun
              wrote on last edited by
              #6

              No, don't put any of your "Turn off" actions in the isFALSE. Put something else (a Comment may even suffice?), anything that won't impact this workflow negatively. So long as isFALSE is non-empty, it will behave as I've described above... effectively truncating the isTRUE Activity the moment the Reactor's AND group goes false (e.g. when wife turns on any light).

              1 Reply Last reply
              1
              • toggledbitsT Offline
                toggledbitsT Offline
                toggledbits
                wrote on last edited by toggledbits
                #7

                Generally, using delays in activities isn't going to get you where you are going, I find.

                Most people want the lights to go on when motion is sensed, but to remain on until motion has not been sensed for some period of time. That's a two-part problem that you can solve in one step in Reactor.

                Let's ignore the time of day component and just focus on the motion for a moment. If you just have a condition to check if the motion sensor is tripped, it will be true when the sensor signals tripped, and reset to false when the motion sensor untrips. So it's pretty clear, you can use that true edge to turn on the lights. The way you get the delay for the off is by using a "delay reset" option on the condition. The delay reset option lets you hold the condition in true state for a period of time after the underlying test has gone false. If you set the reset delay to the amount of time you want the lights to be on in response to motion, and have the false activity turn the light off, then the light will go on when the motion sensor trips, and then at some point after the motion sensor untrips, the delay will kick in and leave the lights alone until the delay expires, and at that point, the condition goes false, the false activity runs (or reset reaction in MSR) and the light goes out. An additional effect of the delay reset option is that if there are several tripped-untripped transitions from the motion sensor during the delay period, indicating someone is still moving about in the sensor's path, the delay is extended, so it's a convenient way to make sure the lights don't just blindly go off after 30 seconds while someone is still standing in the room.

                de628b26-10b1-4460-84d5-a078410d3966-image.png

                To get the time of day restriction, depends on whether you are doing it in Reactor for Luup (which seems to be what's in the screenshots), or MSR (this category).

                • For Reactor for Luup: I would wrap the motion condition in a group, then add the date/time condition as a sibling to the group. Then open condition options for the group, and set the "Condition must occur after" to the date/time condition.
                • For MSR: The motion sensor condition and option goes into Triggers, and the date/time condition goes into Constraints (no option needed).

                Here's what that looks like in Reactor for Luup:

                065f30e3-ca1c-4853-a468-f8727a7ea5bf-image.png

                Note the above screen shot is showing the condition options for the group containing the motion sensor condition. The motion sensor condition itself is not shown because the options are open for display/edit.

                Author of Multi-system Reactor and Reactor, DelayLight, Switchboard, and about a dozen other plugins that run on Vera and openLuup.

                1 Reply Last reply
                1
                • PerHP Offline
                  PerHP Offline
                  PerH
                  wrote on last edited by PerH
                  #8

                  Having good logic sometimes depend on wether what you want to do is smart. 😉
                  This may be one where i save myself some hassle by just delaying from untrip, as suggested. Thanks.

                  Didn't know that an the False action would interfere with/stop the execution of True group, is that a fact in MSR as well?

                  I took the liberty to discuss the old reactor in this forum, as i'm suspended from the forum for that one. 😉 This thread is however for reactor logic in general, but i realise there may be different approaches in the two..

                  1 Reply Last reply
                  1
                  • toggledbitsT Offline
                    toggledbitsT Offline
                    toggledbits
                    wrote on last edited by
                    #9

                    Yes, same in both. The reason is this: if you have the set reaction do something, often the reset reaction is used to undo it. Having both running at the same time, which could happen otherwise, may lead to undesirable effects.

                    On Reactor for Luup, you can add a separate group and check to see if your main logic group is false, and if so, run its activities. Since these actions are in a separate group, they are not pre-empted.

                    In MSR, you make a rule to see if the main rule is false, and have its reaction do what it needs to. Same effect.

                    Author of Multi-system Reactor and Reactor, DelayLight, Switchboard, and about a dozen other plugins that run on Vera and openLuup.

                    1 Reply Last reply
                    0
                    • PerHP Offline
                      PerHP Offline
                      PerH
                      wrote on last edited by
                      #10

                      Makes sense, by all means.

                      another thing, the "double trigger" I have in my example was something i got from a thread on the other forum, but the result would be the same with one "changes from 0 to 1" right? that would also just be true in one instance?

                      1 Reply Last reply
                      0
                      • toggledbitsT Offline
                        toggledbitsT Offline
                        toggledbits
                        wrote on last edited by
                        #11

                        Yeah, that double-trigger probably stems from a misunderstanding of how Reactor works. Reactor acts on changes, not states. So if you have a trigger that checks temperature >= 50, and it goes 49... 50... 51... it will of course go true at 50, and that's when action happens, because the trigger state changes from false to true at that point, but when the temperature goes from 50 to 51, the result of the test is still as true at 51 as it was at 50, so that's no change in state, so no action.

                        Author of Multi-system Reactor and Reactor, DelayLight, Switchboard, and about a dozen other plugins that run on Vera and openLuup.

                        1 Reply Last reply
                        0
                        • PerHP Offline
                          PerHP Offline
                          PerH
                          wrote on last edited by
                          #12

                          I've now taken this one over to MSR, and one part of the problem is still not solved. The Constraints i have is not time of day, its wether someone turned the lights on in the room. This may happen when the motion trigger have been set, and that means that it will turn the lights off at reset, which at this point have been turned on to stay on..

                          I think i may have to go back to having the actions in the "set" category, with the delay, in order to be able to intervene the "reset" of the motion sensor state?

                          One other option is to have another rule for "night light Off", and evaluate Off separately..

                          1 Reply Last reply
                          0
                          • toggledbitsT Offline
                            toggledbitsT Offline
                            toggledbits
                            wrote on last edited by
                            #13

                            I would choose opposing rules over delays. I think the topic of handling "manual on" is well-covered in the other forums. The gist is that you can do a little work with an expression variable to track whether the light is being turned on because the switch itself is changing state when there's no motion detection (manual mode), or if motion is detected when the switch is off (automatic mode).

                            It does have a caveat though: there's little chance of consistent success if the switch used to turn the lights on manually is in the detection area of the motion sensor, as this usually means the motion sensor sees you before you get to the switch, so the automatic on is already happening before you touch it.

                            Author of Multi-system Reactor and Reactor, DelayLight, Switchboard, and about a dozen other plugins that run on Vera and openLuup.

                            1 Reply Last reply
                            1
                            • PerHP Offline
                              PerHP Offline
                              PerH
                              wrote on last edited by
                              #14

                              It works well now with separate rules for on and off, where "OFF" has the same constraints as "ON", and "OFF" has "ON"-rule changes to false as trigger.

                              Now, the autolight (which turns on a very low dimming level) turn on, and if someone manually turns the light on at this point, the light goes to the dimming level chosen.
                              (In this case its not the switch connected to one light that is pressed, its a virtual switch that turns on multiple lights.)

                              1 Reply Last reply
                              0
                              • toggledbitsT toggledbits locked this topic on
                              Reply
                              • Reply as topic
                              Log in to reply
                              • Oldest to Newest
                              • Newest to Oldest
                              • Most Votes


                              Recent Topics

                              • [Reactor] Variables not updating correctly in latest-25201-2aa18550
                                tunnusT
                                tunnus
                                0
                                94
                                7.3k

                              • The reaction stopped working (Google Nest max playing a video)
                                F
                                Fanan
                                0
                                8
                                518

                              • Do you Matter?
                                akbooerA
                                akbooer
                                0
                                3
                                163

                              • Caution: zwave-js-ui docker 11.4.0 is broken
                                toggledbitsT
                                toggledbits
                                0
                                2
                                108

                              • Shelly Wall Display XL
                                therealdbT
                                therealdb
                                2
                                6
                                270

                              • Handling Dead Entities and Renamed Entities
                                PablaP
                                Pabla
                                0
                                5
                                196

                              • Strange behavior for MQTT templates using payload and attributes
                                toggledbitsT
                                toggledbits
                                0
                                6
                                248

                              • [MSR] reactor-mqtt-contrib package for additional MQTT templates
                                therealdbT
                                therealdb
                                1
                                46
                                8.9k

                              • HA 2025.9.4 Supported Yet?
                                toggledbitsT
                                toggledbits
                                0
                                2
                                148

                              • Rule Set UI bug - RESOLVED
                                toggledbitsT
                                toggledbits
                                1
                                2
                                295

                              • [Reactor] Copy&Paste of Rules
                                therealdbT
                                therealdb
                                0
                                1
                                323

                              • [Reactor] Help with screne controller cycling logic
                                toggledbitsT
                                toggledbits
                                0
                                5
                                472
                              Powered by NodeBB | Contributors
                              Hosted freely by 10RUPTiV - Solutions Technologiques | Contact us
                              • Login

                              • Don't have an account? Register

                              • Login or register to search.
                              • First post
                                Last post
                              0
                              • Categories
                              • Recent
                              • Tags
                              • Popular
                              • Unsolved