* Remove async_remove_listener
This avoids the ambuigity as to what happens if same callback is added multiple times.
* Keep track of a context for each listener
This allow a update coordinator to adapt what data to request on update from the backing service based on which entities are enabled.
* Clone list before calling callbacks
The callbacks can end up unregistering and modifying the dict while iterating.
* Only yield actual values
* Add a test for update context
* Factor out iteration of _listeners to helper
* Verify context is passed to coordinator
* Switch to Any as type instead of object
* Remove function which use was dropped earliers
The use was removed in 8bee25c938
29 lines
881 B
Python
29 lines
881 B
Python
"""Helpers for Toon."""
|
|
import logging
|
|
|
|
from toonapi import ToonConnectionError, ToonError
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
def toon_exception_handler(func):
|
|
"""Decorate Toon calls to handle Toon exceptions.
|
|
|
|
A decorator that wraps the passed in function, catches Toon errors,
|
|
and handles the availability of the device in the data coordinator.
|
|
"""
|
|
|
|
async def handler(self, *args, **kwargs):
|
|
try:
|
|
await func(self, *args, **kwargs)
|
|
self.coordinator.async_update_listeners()
|
|
|
|
except ToonConnectionError as error:
|
|
_LOGGER.error("Error communicating with API: %s", error)
|
|
self.coordinator.last_update_success = False
|
|
self.coordinator.async_update_listeners()
|
|
|
|
except ToonError as error:
|
|
_LOGGER.error("Invalid response from API: %s", error)
|
|
|
|
return handler
|