-
-
Notifications
You must be signed in to change notification settings - Fork 211
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MQTT Discovery payload incorrect. #3642
Comments
I know the change well... it was quite disruptive- both as a maintainer of MQTT integrations that Home Assistant users use, and as a maintainer of openHABs integration with Home Assistant style MQTT discovery. Essentially, @YogoGit is correct- a change needs to be made. openHAB is perfectly happy with the component name being However, it's not actually necessary to have I'm not sure how configuration works, @robertsLando. If we change the default value of the entity name template, would existing installs get that change? Or no, because they would have already persisted whatever they currently have? If they get the new default, then fixing this would be a breaking change. But technically it's something that should be done, to stay "in spec" (🙄 given there is no actual spec) with current Home Assistant versions. And even as a breaking change, it's not difficult for users to "roll back" the change in their own instance by setting the entity name template back to the old default. Perhaps there could be a migration for new installs to get the new default, but old installs to persist the old default, so they can migrate in their own time? |
@ccutrer - Are you saying that I could modify the code in the docker container (which is what I'm using) to change the default for the entity template, restart the container, and I could verify that it would correct the issue? In /usr/src/app/.server/lib/Gateway.js, near line 2027: Stock..
Modified:
If so, I can try making this change on my device this coming weekend (when I travel to the remote site) and see if it breaks anything on my HA system. Also, in a COMPLETELY unrelated topic I just noticed, but the directory /us/src/app/node_modules is populated in the docker container, and in my past life (software engineer for > 35 years) we never distributed node_modules inside our containers, as the generated file were created from the libraries prior to creating the final artifact (and weren't always used), so the contents of node_modules was just wasted space in the containers. Also, if you are aware of a way for me to change it to something else (or null), I am comfortable modifying code inside the container or attempting other changes to help debug this. Thanks for your attention to this issue! |
Yes so that would be breaking but considering all home assistant users should never use MQTT Discovery (as there is Zwave integration) and this is a very users specific case I think your workaround may be enough in this case for the ones that wants to fix that. About the node_modules thing, I dunno what you mean @YogoGit, this is how all nodejs projects are usually shipped with docker. Maybe you meant that node_modules could have been dropped and create an entrypoint that installs them on startup if missing? Could be a solution but the space advantages IMO aren't worth the additional startup time. |
I'm pretty sure that's not the case, at least in my experience. Generally, node_modules are excluded (.dockerignore) as node_modules is not used at runtime, and node_modules is almost always MUCH (!) larger than the resulting runtime dependencies. Again, I've created dozens of projects that use node as containers, and none of them have node_modules included in them. See https://www.digitalocean.com/community/tutorials/how-to-build-a-node-js-application-with-docker W/regards to size, in the docker container, node_modules contains 244/265 MB of files in /usr/src/app, so it's usage is > 90% of the entire image size. Without it, the image would be MUCH smaller.
Removing 244MB would make the image much smaller. (I'll do some investigating to see if it works correctly, and if so create a PR once that changes). |
Wow, I wouldn't got that far. I would venture to guess that a majority of the HA users don't use MQTT discovery, but I would guess that a measurable percentage (> 10%) of them probably use MQTT discovery instead of the WS server. And, I appreciate that it's supported, and am asking that this supported feature actually be setup to work properly, given that the setup is in the HA section, and that it doesn't work properly with HA. Given that it's currently broken, I would think that changing the template (as @ccutrer) mentioned wouldn't break any existing HA users as there setup is currently broken. However, at least I have a workaround, which I will be testing this weekend. |
@ccutrer - Thanks for the great instructions, I will try this out this coming weekend and update this issue with my results! |
Oh yeah now I understand what you mean, the reason why I removed them from dockerignore is to skip install inside docker build because of a bad bug that made me lost more then a week (was something related to docker alpine). Anyway It's not really clear to me why the image should be smaller then as anyway them would have been generated by the build process and then shipped within the image so the result is the same. |
Update. I modified the entity name template, first with %pn, and then later with ' ', and re-ran discovery. All of my entities appear to be working fine, although I won't know for sure until I add a new device, as I believe it cached some of the old entity_ids. But, so far so good, and my HA logs are MUCH quieter than before. |
@YogoGit Thanks for your feedback 🙏🏼 Closing this for now, feel free to re-open in case |
Hello. I don't want to reopen the issue as @YogoGit shows how to solve. I'm a dual domotic user (Domoticz and HA) and use MQTT for centralised data (zwave, zigbee, enphase, nodemcu...) and since my last update of zwavejsui (ok I had some month late) I run the same issue on Home Assistant side and no issue with Domoticz. |
It's not clear to me when you say it is not permanent, you mean that zwave-js ui updates don't persist the entity name template or what else? Maybe after the home assistant update you only had to restart zui in order to retrigger the discovery? |
Thanks for your message and sorry for the misunderstanding. |
Z-UI listens for Home assistant birth topic in order to detect if/when Home assistatn restarts and in that case it does a re-discovery of all devices. Maybe you didn't configured the birth topic well? From docs: In your Home Assistant configuration.yaml: mqtt:
discovery: true
discovery_prefix: <your_discovery_prefix>
broker: [YOUR MQTT BROKER] # Remove if you want to use builtin-in MQTT broker
birth_message:
topic: 'homeassistant/status'
payload: 'online'
will_message:
topic: 'homeassistant/status'
payload: 'offline' |
Hello. I use the MQTT integration but when I reboot HA it publish offline then online under homeassistant/status. This seems correct. I confirm too that all nodes are rediscovered because I see it under Domoticz log. |
No clue where the error is so, I'm sorry. @kpine better knows home assitant then me so may be able to help here |
Hello @robertsLando, |
@Turbox35 Check if when you restart home assitant you see this message on Z-Wave JS UI console: zwave-js-ui/api/lib/Gateway.ts Lines 2208 to 2209 in 425a817
|
When I reboot HA, in the Zwave-js UI log: |
Ok so this seems an error on Home Assistant as when that happens I re-send the discovery there (like when you click on save or restart the application), I wish I could be more helpful here |
Hi @robertsLando , is there a possibility that some retained messages are corrupt or cached? |
Retained messages are always cached on broker side, if you removed some entities it could be them are still loaded on your broker |
Checklist
Deploy method
Docker
Z-Wave JS UI version
9.9.1
ZwaveJS version
12.4.4
Describe the bug
The generated MQTT discovery (I'm NOT using the built-in device integration as my ZWave devices are over a hundred miles away from my HA server) is incorrect, and was not updated to follow recent HA MQTT discovery changes (> 6 months ago).
https://developers.home-assistant.io/blog/2023/06/28/entity-name-changes?_highlight=changing
This occurs for ALL of my zwave devices, causing errors similar to the following to litter my logs.
The above is the error from my Zooz Zen72 800LR, although I have similar errors for my other switches, thermostats (non-Zooz), etc...
Here is the actual payload
It is my understanding that the "name" field above should be either NOT be set, or set to null (from the error logs). I can manually fix ALL of my devices but modifying the configuration for all my devices (hundreds of messages) and disabling MQTT discovery, but IMO this really should be fixed at the zwave-js-ui (or zwave-js server and/or node-zwave-js).
Otherwise, everytime I add a new device, I have to re-enable MQTT discovery (to recognize the new device) and then manually fix all the messages again, or manually codify new MQTT discovery messages.
To Reproduce
Add a Zwave device to zwave-js-ui after disabling WS-Server and enabling MQTT discovery.
Expected behavior
A valid MQTT discovery payload would be sent for new devices, with the proper value in the 'name' field.
Additional context
As mentioned, my ZWave server is located 100 miles away from my HA server, so using MQTT is a MUCH lower-cost (and lower bandwidth) solution. In addition, the use of MQTT allows me to do additional intergrations that are not possible with the WS-Server coupling directly to HA.
Export of the Zen72 is provided below as described in the bug_report URL.
node_10.json
The text was updated successfully, but these errors were encountered: