As the title says, here's my OpenAI Controller for Reactor:
OpenAI Controller per Reactor. Contribute to dbochicchio/reactor-openai development by creating an account on GitHub.
It supports both OpenAI and Azure OpenAI endpoints. You'll need keys/endpoints, according to each service.
The controller supports multiple models, and each one could be mapped as an entity.
It's quite easy to use, and responses can be stored in variables, for easy access. Or sent to another action (Text To Speech, another endpoint, etc).
9013ae50-fd68-42a2-87c3-97479132e465-image.png
80a88eec-7c89-464a-8196-690b4b72d044-image.png
Have fun with LLM into your scenes!
In Home Assistant I have an integration that if I add entities to it, I will get the following error in MSR as certain entity values I'm using in expressions are null for a moment. This is more or less cosmetic issue and happens very rarely as I rarely modify that integration on the hass side.
Screenshot 2024-11-28 at 22.20.41.png
And the expression is
Screenshot 2024-11-28 at 22.38.19.png
Could I "wrap" hass-entity shown above somewhat differently to prevent this error from happening? Using build 24302.
Hello
I am trying to set up Multi System Reactor to automate routines across multiple smart home devices & platforms (e.g., Home Assistant, SmartThings, and Hubitat). While I have successfully linked the systems; I am facing issues with:
-Delays in triggering actions on secondary devices.
-Inconsistent execution of complex logic conditions.
-Synchronization of states between devices when one system updates.
Is there a recommended way to optimize performance & confirm seamless state sharing across systems?
I have checked https://smarthome.community/category/22/multi-system-reactor-msbi guide for reference but still need advice.
Any tips on debugging or log analysis to pinpoint where the issue arises would also be appreciated.
Thank you !
I've managed to use MSR UI on iOS devices to some degree*, so that although UI elements (e.g. rule sets) are not visible in portrait mode, you've seen them in landscape. Now with recents builds (24302) this does not work anymore, elements (rule sets, entities) are not anymore visible in landscape mode.
Does anyone have similar experiences? Using iOS 18 and Safari/Chrome browser.
( *Drag & drop of rule conditions have never worked on a mobile)
@toggledbits Since I have upgraded ZWaveJSController to 24293 from 24257 I am seeing entries related to registering action set_volume, but action is not defined by the capability 143 every time I restart Reactor.
The Siren seems to be doing what it is supposed to do. The volume levels are fine. Should I worry about it?
Reactor version 24302
ZWaveJSController version 24293
Z-Wave JS UI version 9.27.4
zwave-js version 14.3.4
I have the following ACL defined:
groups: admin: users: - admin applications: true api_acls: # This ACL allows users in the "admin" group to access the API - url: "/api" group: admin allow: true log: true # This ACL allows anyone/thing to access the /api/v1/alive API endpoint - url: "/api/v1/alive" allow: trueAnd I have authenticated to MSR as "admin" user. However, I'm getting "access denied" when trying to access http://*******:8111/api/v1/log
So what I'm missing, is my ACL incorrectly defined?
Using build 24302 on Docker.
Thanks to @toggledbits for adding a custom CSS. I've started doing a darker Reactor style.
Here's the file: https://gist.github.com/dbochicchio/825098ac13b7f8cac22012eae37ff7ce
A couple of things are still too bright and I'll eventually catch-up. Just place it under your /config directory, naming the file as customstyles.css. Hard refresh your browser.
Hi
I have just connected a bunch of EzloPi controllers to MSR to import some ESP based devices etc.
They all seemed to have worked and imported in to MSR apart from I have one missing device. It is a Digital Gas Sensor device.
This is how that device looks in the Ezlo API.
Devices Info:
_id: "10696001" deviceTypeId: "ezlopi" parentDeviceId: "10696000" category: "level_sensor" subcategory: "" gatewayId: "457a5069" batteryPowered: false name: "Gas Sensor Digital" type: "sensor" reachable: true persistent: true serviceNotification: false armed: false roomId: "" security: "no" ready: true status: "idle" parentRoom: true protectConfig: "default"Items Info:
_id: "20696001" deviceId: "10696001" hasGetter: true hasSetter: false name: "smoke_density" show: true valueType: "substance_amount" scale: "parts_per_million" value: 2.7472610473632812 valueFormatted: "2.75" status: "idle"There is also an Analog Gas sensor that one did import in to MSR OK.
68d63dab-b871-4f44-912b-cf6e0b9eb4c6-image.png
Devices Info:
_id: "10696000" deviceTypeId: "ezlopi" parentDeviceId: "10696000" category: "security_sensor" subcategory: "gas" gatewayId: "457a5069" batteryPowered: false name: "Gas Sensor Analog" type: "sensor" reachable: true persistent: true serviceNotification: false armed: false roomId: "" security: "no" ready: true status: "idle" parentRoom: true protectConfig: "default"Items Info:
_id: "20696000" deviceId: "10696000" hasGetter: true hasSetter: false name: "gas_alarm" show: true valueType: "token" enum: 0: "no_gas" 1: "combustible_gas_detected" 2: "toxic_gas_detected" 3: "unknown" valueFormatted: "no_gas" value: "no_gas" status: "idle"And this is how this MQ2 Gas Sensor looks like on their dashboard:
Digital
cb77dfa3-4af5-4d06-9635-89207a716a89-image.png
Analog
4fb4da1b-e946-4b89-876c-bcd9f5699b6c-image.png
They have an EzloPi website here you can create your own sensor projects using ESP boards, which is very interesting stuff!
And I just wrote on the Ezlo forum here, how to connect an EzloPi controller to MSR.
THANKS.
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.A couple of things for you @toggledbits, since you mentioned that this release has new features and some tweaks are expected.
Local expressions cannot be deleted. Pushing the X button has no effect for me.
When cloning an entity action, the result is strange (first is cloned one, second is the original action):
a92ea094-9e2c-4aaa-bf47-2d07a6ffdbd0-image.png
When changing the action on the cloned element, the params are added to the original one. See screenshot:
92ac3011-83c8-466b-bd23-47d483ad7a52-image.png
Dark theme has a couple of strange contrasts. One is visible in the previous screenshots (white text on yellow background). Another one is in groups (blue text on blue background):
9b3c4988-53ef-44e6-9672-30e744cacb75-image.png
Overall, I found blue, yellow, red and green (in buttons and forms) to be too bright.
On the bright side:
I love the new script action: thank you! The dark theme is a great start to avoid getting blinded at night I promise I'll try very soon the new features around actions. Thanks!@toggledbits
I just upgraded to version MSR 24293, bare metal running on Fedora. Upon restart, I am getting a error banner:
I followed the new directions about npm
npm i --no-save --no-package-lock --omit dev
Any idea what the issue is?
Seems like switching the UI to the newly added dark mode (thank you for this) does nothing. The UI stays in light mode and only a few buttons turn into dark mode (see screenshot)
Things I have tried:
Hard refresh
Different browser
Different computer
Restarting Reactor
Failed troubleshooting attempts:
No errors in Chrome console
No relevant errors in Reactor log (can still PM the full log file)
Reactor version: latest-24293-ea42a81d
Hardware: Odroid N2+
Linux version: Ubuntu 24.04.1 LTS
3df2806f-9146-485b-9ec1-d056e91cefe5-image.png Dark mode enabled
ff823023-c079-4684-b01f-d6ac6527d31a-image.png Light mode enabled
Good morning,
I have a service MQTT service that needs a restart occasionally. The add-on (Smartbed MQTT) is for the smart bed base for my bed. It has a "safety light" that I can control from HAAS & MSR as a light entity, and also moves the head of the bed to a preset at bedtime, and then lies it back flat in the morning The problem is, from time to time, the light becomes "unavailable" Restarting from the Add-ons tab in HAAS always fixes it, but I should be able to detect when it happens when "light.tempur_pedic_safety_lights" is not true or false, i.e., unavailable.
What I don't know how to do is how to restart that service. Does anybody have experience in restarting add-ons from MSR?
Running:
Reactor (Multi-hub) latest-24212-3ce15e25 ZWaveJSController [0.1.24232]HAAS:
RPi5-64 (8GB) Core 2024.7.3 Supervisor 2024.08.0 Operating System 13.0 Frontend 20240710.0Hi!
Is it possible to generate two additional log files, the first being the replica of what is displayed on screen by the Rule History widgets and the other with Recently Changed Entities?
And could I configure the generation of one file per day, and delete the older ones? For example, store the last 5 days?
And being more ambitious, does Windget have an icon to open these TXT files in the navigated?
Well, we're approaching Christmas, so here's my request to Santa Claus @toggledbits 🙂
Hi @toggledbits
I'm working on a controller to generate llm response from a prompt in reactor. I have http response coming thru an http request action at the moment, capturing the response inside a local variable. So, it's practically sync.
I want to create a controller, so I don't have to rely on a proxy (and have a simpler architecture), and duplicate absurd http actions, but AFAIK in the current implementation, actions are async only. But if I have multiple requests going on, I cannot be sure what it's really inside an attribute. I also thought that something like a correlation id when sending the request could be used to identity multiple responses, but I wanted to double check with you before starting with something too complicated. I also noticed that some actions in home assistant (ie forecast) are sync and I'm wondering if you have any plan or hint to address this situation. Thanks.
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
Zen32 question
-
Am using one of the buttons in the Zen32 to toggle the ceiling light in my master bedroom.
Rule set is pretty basic"
Have determined (with a lot of head scratching) that the 1 second delay is required on the button change for the reaction to run.Without the 1 second delay, the reaction goes true but the set reaction does not run. Even if the button state is already tripped.
Easy work around, but is that by design or a bug?
-
Is there anything (at all, even just a comment) in the Reset reaction?
-
OK. Let's unravel for a minute.
First, the pulse from changes is very short, and you will not usually see it in the UI without a delay. Adding a delay reset helps this, at the expense of losing responsiveness if the button is hit several times. This may be OK with the ZEN32, because it allows double, triple, quadruple and quintuple presses, so it has a delay of its own to detect that. But in reality, you don't need any delay in Reactor.
I was not suggesting you add actions to the reset; I was actually asking to make sure you didn't, because having them will actually work against you. You don't want to do that. Without the delay, or even with a short delay, there's a high likelihood that you will make the changes condition resetting itself (and thus its parent rule going back to RESET) preempt the SET reaction (because that's what happens when the RESET reaction isn't completely empty) and your SET reaction won't finish.
Also you may be experiencing an artifact of the way toggle.toggle is implemented. There is no toggle command in Z-Wave, so ZWaveJSController simulates it by looking at the current state of the target device and telling it to go opposite -- off if it's currently on, on if it's currently off. The issue, though, is that it can take from a few milliseconds to several seconds for the state of the Reactor switch entity to update, and this is highly dependent on the quality of your mesh as always. So if you're hitting the buttons fast, the entity states may not be fully caught up, and so it won't send the right on/off to the device. That's just a function of the responsiveness of the mesh and the connection between the controller, zwave-js and Reactor, all of which add latency. Not much to do there but take it as it comes.
Rather than use toggle.toggle, what I use in testing is a simple local variable on the rule as a counter that I increment in the SET reaction every time a button press is detected. This makes it very easy to tell if the changes is working, as the feedback is immediate and not reliant on any external hub, service, or device performance.
The ZEN32 is also not a perfect device. There is at least one firmware update for it that has been published that I am aware of, and there is discussion in various forums about bugs that people hope will soon lead to another. In my own experience, I can make it stop updating by pressing buttons too quickly. I have found that if I press a button again while its LED is blinking (during transmit of the previous press), about half the time the device will stop sending updates for that button. I don't need Reactor to see this, I can see it in the zwave-js logs and message stream (or lack thereof). It corrects itself usually after a few seconds, so I imagine something inside the ZEN32 gets in some state that times out after that period. So that also could be happening to you and befuddling your testing. Hopefully they find and fix whatever that is, but of course, it will require you to update the firmware on your ZEN32 when they do, which is a bit of a pain. That's a shame, really, because in terms of WAF, anything that makes buttons stop working, even briefly, is a non-starter for widespread use in my house.
-
Hi Patrick,
Couple questions on the ZEN32's. Since the 2002.3.x upgrade of HA my zwaveJS2mqtt has been very unstable, especially with the multi tap scenes on the ZEN32. They usually work for a period of time following a reboot and then become unresponsive at some point. Haven't been able to nail down a time frame on how long it runs till becoming unstable.
Currently working right now so I cannot get you any info.
Are you and I the only users in your test group using Zen32's? If not, anyone else seeing stability issues? -
HA has nothing to do with ZWave-JS, except for the fact that it uses it, but that has nothing to do with ZWaveJSController and what Reactor may see and do with those devices. Based on the above and your other post, I'm not clear if we're talking about entities that are coming from your HassController instance or your ZWaveJSController instance. More information/clarification is required here.
They usually work for a period of time following a reboot and then become unresponsive at some point.
Again, it's not clear to me what you are rebooting (Hass? zwavejs2mqtt? Reactor? ZEN32 itself?). And not clear what is unresponsive.
Are you and I the only users in your test group using Zen32's?
Based on the data, I think that's the case. I am using ZEN32s directly sourced from ZWaveJSController, though, having nothing to do with Hass, and having no issues other than those I have previously described to you, which are a result of the ZEN32 not sending data to the mesh temporarily under certain conditions. And that is only temporary and the ZEN32 recovers in 10-15 seconds.
EDIT: I just checked that last data update I have from your system, and the ZEN32 nodes 36 and 45 are both marked dead as of the moment that snapshot was taken. I'm guessing you rebooted zwavejs2mqtt and then immediately rebooted Reactor? That Reactor reboot would be around 5:30PM Eastern time/22:30GMT yesterday 3/8?
EDIT 2: Are you on the new 22067 build? If not, what build are you running?
-
Hey Patrick,
My setup for the ZEN32's is I use MSR to monitor zwavejs button.state(primary) for the string value with an AND condition to monitor zwavejs button.since for any changes. Works for awhile and then no response. When I look at it in MSR Entities nothing is changing on the entity for the button I am pressing. I usually reboot the HA box and it works for awhile. sometimes, though not all, MSR status reports zwavejs down though not always. -
@rogero See my other comment in your other thread. Based on what you've said there, it seems like you are running Hass with ZWave.me and a Razberry card, and trying to run zwavejs2mqtt at the same time interfacing to the same card? That sounds to me like a dog that won't hunt (i.e. two different interfaces wrestling for control of the same card seems like it's doomed to failure).
-
@RogerO OK. Since I'm squared away on the ZWave.me/zwavejs issue (you're using a ZWave.me card/hardware, but running only zwavejs software, all good)...
On the Z-Wave data from your system received yesterday mentioned above in my edit... the ZEN32s were not ready (interview completed) when ZWaveJSController connected to zwavejs. That would suggest either (a) you had just rebooted zwavejs and Reactor together (one immediately after the other), or (b) you have a serious mesh issue and initialization of the ZEN32s is taking a long time (maybe both). Either way, I can see how there's an opportunity for ZWaveJSController to miss setting up the update of some device values, because zwavejs doesn't transmit any values if the device isn't fully ready, so I've fixed that and there's now a 22068 build available for download. My zwavejs runs for days/weeks and doesn't crash, and I rarely restart it, so it's almost always in a state of readiness with all devices interviewed when I restart Reactor (which I do a lot during development) — I would not often see the conditions your data file was suggesting, and that would account for the difference in experience with this device. But that's now handled. I'm curious to hear if your ZEN32s improve on this version.
-