mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 13:17:32 +00:00
Move all Tuya device handling into device listener class (#57523)
This commit is contained in:
parent
879144b48d
commit
e23d35c6f0
@ -132,20 +132,6 @@ async def cleanup_device_registry(
|
|||||||
break
|
break
|
||||||
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def async_remove_hass_device(
|
|
||||||
hass: HomeAssistant, entry: ConfigEntry, device_id: str
|
|
||||||
) -> None:
|
|
||||||
"""Remove device from hass cache."""
|
|
||||||
device_registry_object = device_registry.async_get(hass)
|
|
||||||
device_entry = device_registry_object.async_get_device(
|
|
||||||
identifiers={(DOMAIN, device_id)}
|
|
||||||
)
|
|
||||||
if device_entry is not None:
|
|
||||||
device_registry_object.async_remove_device(device_entry.id)
|
|
||||||
hass.data[DOMAIN][entry.entry_id][TUYA_HA_DEVICES].discard(device_id)
|
|
||||||
|
|
||||||
|
|
||||||
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||||
"""Unloading the Tuya platforms."""
|
"""Unloading the Tuya platforms."""
|
||||||
_LOGGER.debug("integration unload")
|
_LOGGER.debug("integration unload")
|
||||||
@ -191,9 +177,7 @@ class DeviceListener(TuyaDeviceListener):
|
|||||||
*self.hass.data[DOMAIN][self.entry.entry_id][TUYA_HA_TUYA_MAP].values()
|
*self.hass.data[DOMAIN][self.entry.entry_id][TUYA_HA_TUYA_MAP].values()
|
||||||
):
|
):
|
||||||
ha_tuya_map = self.hass.data[DOMAIN][self.entry.entry_id][TUYA_HA_TUYA_MAP]
|
ha_tuya_map = self.hass.data[DOMAIN][self.entry.entry_id][TUYA_HA_TUYA_MAP]
|
||||||
self.hass.add_job(
|
self.hass.add_job(self.async_remove_device, device.id)
|
||||||
async_remove_hass_device, self.hass, self.entry, device.id
|
|
||||||
)
|
|
||||||
|
|
||||||
for domain, tuya_list in ha_tuya_map.items():
|
for domain, tuya_list in ha_tuya_map.items():
|
||||||
if device.category in tuya_list:
|
if device.category in tuya_list:
|
||||||
@ -224,4 +208,17 @@ class DeviceListener(TuyaDeviceListener):
|
|||||||
def remove_device(self, device_id: str) -> None:
|
def remove_device(self, device_id: str) -> None:
|
||||||
"""Add device removed listener."""
|
"""Add device removed listener."""
|
||||||
_LOGGER.debug("tuya remove device:%s", device_id)
|
_LOGGER.debug("tuya remove device:%s", device_id)
|
||||||
self.hass.add_job(async_remove_hass_device, self.hass, self.entry, device_id)
|
self.hass.add_job(self.async_remove_device, device_id)
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def async_remove_device(self, device_id: str) -> None:
|
||||||
|
"""Remove device from Home Assistant."""
|
||||||
|
device_registry_object = device_registry.async_get(self.hass)
|
||||||
|
device_entry = device_registry_object.async_get_device(
|
||||||
|
identifiers={(DOMAIN, device_id)}
|
||||||
|
)
|
||||||
|
if device_entry is not None:
|
||||||
|
device_registry_object.async_remove_device(device_entry.id)
|
||||||
|
self.hass.data[DOMAIN][self.entry.entry_id][TUYA_HA_DEVICES].discard(
|
||||||
|
device_id
|
||||||
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user