-
-
Notifications
You must be signed in to change notification settings - Fork 31.6k
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
Opentherm Gateway not showing up in google assistant #18515
Comments
Configuration and debug log would be helpful. |
Part configuration.yaml
google.yaml
No error in log so this would not give extra information |
By the way, you did great work regarding the OTGW integration in home assistant. I forgot to mention it in my previous post. |
I get the following in the debug log:
Not sure if that means it's a google_assistant issue or an opentherm_gw issue. Anyone more familiar with google_assistant care to chime in? EDIT: This seems to be caused by the fact that opentherm_gw does not publish SUPPORT_OPERATION_MODE as it only has 1 operation mode. If I mock support in supported_features the thermostat is shown in Google Home, albeit non-functional since the actual support is not there. It only shows the current room temperature but no way to change/view the setpoint. The above brings me to the conclusion that this issue will be present with all climate platforms that lack operation mode support. I could fix this in opentherm_gw by adding a single operation mode, but I am reluctant to do so because of UI issues and the fact that keeping the current situation as-is would make SUPPORT_OPERATION_MODE mandatory for all climate devices to have google_assistant support. In my opinion it would be better to mock a single mode of operation within google_assistant and keep the climate platform requirements as they are (see also the comments on home-assistant/frontend#1881). |
Ok thnx for the reply. So this should be fixed on the Google assistant component side? |
In my opinion, yes. Climate platforms can exist without operation modes by design. If that changes I will update opentherm_gw accordingly. I may have a go at trying to fix google assistant if nobody else beats me to it, but I'm not very familiar with the component so it could take a while. |
I am seeing similar problems with the ATAG One Component (see herikw/home-assistant-custom-components#5) |
@mvn23 , can't we apply the same fix @reharmsen has used for the Atag component? |
That would work, but it's a workaround at best and does not address the underlying problem. See my previous posts for my reasons not to work around the issue this way for now. |
@jodur and @mvn23 I created the workaround in the custom Atag component in order to get my own setup working. In me looking into the code (for as far as I understand Python and the buildup of Home-Assistant), I noticed the 'TemperatureSettingTrait' class in trait.py from the google_assistant component. The class only translates 4 states: I am not sure whether other states are returned to google (i guess It does, as before my fix the Atag component did not work), but it might be necessary to limit what can be returned to only the states google will understand. Also the hass state STATE_AUTO should be mapped to 'auto' and not to 'heatcool' as what is done currently. Next to this, eco and dry should be added into the translation. |
I am running the Hassio image with the opentherm gateway connected via the OTmonitor relay server. |
Closing in favor of #18645 |
Is this fixed?? because my OpenTherm Climate Thermostat is not exposed to google assistant.. running 84.3 |
I'm running 0.84.6 and it's not working in this version either. |
Try using this file as |
No difference for me, not showing up in the Google Home app after an |
2 things come to mind when comparing the custom component to other climate devices.
Recommend either, sending only heat/cool/off as operation modes, or handling auto correctly and sending all of them. |
That hit the nail right on the head. Changing |
Is it exposed now in your Google home app? Mine is not also with your last gist |
I set up a test environment this afternoon and I was able to control the thermostat through Google Home. |
I did no create the custom_components dir in the correct folder, now it works! It is now showing up in google home app and i can control it, but only when the state is heating, when it is idle i cannot change or see the setpoint. I only can see the current temperature. |
Should work now, but it will always show as state |
Is the state in home-assistant also always heat? Or can it be also inactive? Because I like the inactive/heating state in home-assistant so I can quickly see if it is heating right now. |
I actually found an issue with the EDIT: updated gist |
I have now just modified it to be always heat state, it works well for now. The only thing is that the state idle/off is more elegant for homeassistant so you can easy see the state. Maybe you/we need to implement the state switching for the google assistant, so it can enable the thermostat when it is idle/off. now the button does nothing or shows the supported states but does not allow to change it because it is not implemented in the opentherm climate right now. |
The true answer lies in home-assistant/architecture#22 |
Thanks for linking the architecture discussion, looks like that will be the way forward in the long term.
There's no operation mode concept within the OpenTherm Gateway, only the current state of the system. As a result there's no way to make it work two-way. On top of that there's the issue that Google Assistant doesn't support STATE_IDLE. |
I agree, the real problem is that Google Assistant is not supporting the current state of the current operation. For example, it cannot display if it is heating or just idle because it is the right temerature. So if we want to met the google assistant implementation we need to have the status to always heat. I have edited your gist to include only STATE_HEAT and have test it and it works fine. I cannot cool with my system so i have not included STATE_COOL. We can still read the current state in homeassistant if it is heating or idle. Switching from google assistant is not nessasary because it is not supported by opentherm to set an state i think? Edit: |
I have created this gist. |
There hasn't been any activity on this issue recently. Due to the high number of incoming GitHub notifications, we have to clean some of the old issues, as many of them have already been resolved with the latest updates. Please make sure to update to the latest Home Assistant version and check if that solves the issue. Let us know if that works for you by adding a comment 👍 |
Because of the way that google assistant works, the modes on this device don't really map well to google assistant's model of how climate devices work. Might I suggest implementing turn_on and turn_off, and then with #21842 at least you can say "ok google, turn on device" and have that work. Same solution as will work with #17559 |
There's no concept of 'on' and 'off' within the OpenTherm Gateway. The system is always 'on' and requires only a target temperature to work in its most basic form. |
OK in this case, the best solution would be to return heatcool for all the custom states that are unknown in GA, and then at least you can change the temp. I can put in a PR to do this. This will fix #17559 as well. |
There hasn't been any activity on this issue recently. Due to the high number of incoming GitHub notifications, we have to clean some of the old issues, as many of them have already been resolved with the latest updates. |
Home Assistant release with the issue:
Home Assistant0.82.1
Last working Home Assistant release (if known):
Operating environment (Hass.io/Docker/Windows/etc.):
Raspberry Pi 3, manual installation
Component/platform:
Description of problem:
Climate control doesn't show up in google assistant/home with the opentherm gateway.
I have exposed the domain climate!
Problem-relevant
configuration.yaml
entries and (fill out even if it seems unimportant):Traceback (if applicable):
Additional information:
The text was updated successfully, but these errors were encountered: