mirror of
https://github.com/home-assistant/core.git
synced 2026-05-08 09:38:58 +01:00
Migrate tolo to entry.runtime_data (#153744)
This commit is contained in:
@@ -2,12 +2,10 @@
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import Platform
|
||||
from homeassistant.core import HomeAssistant
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
|
||||
PLATFORMS = [
|
||||
Platform.BINARY_SENSOR,
|
||||
@@ -22,21 +20,17 @@ PLATFORMS = [
|
||||
]
|
||||
|
||||
|
||||
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||
async def async_setup_entry(hass: HomeAssistant, entry: ToloConfigEntry) -> bool:
|
||||
"""Set up tolo from a config entry."""
|
||||
coordinator = ToloSaunaUpdateCoordinator(hass, entry)
|
||||
await coordinator.async_config_entry_first_refresh()
|
||||
|
||||
hass.data.setdefault(DOMAIN, {})[entry.entry_id] = coordinator
|
||||
entry.runtime_data = coordinator
|
||||
await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
|
||||
|
||||
return True
|
||||
|
||||
|
||||
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||
async def async_unload_entry(hass: HomeAssistant, entry: ToloConfigEntry) -> bool:
|
||||
"""Unload a config entry."""
|
||||
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
||||
if unload_ok:
|
||||
hass.data[DOMAIN].pop(entry.entry_id)
|
||||
|
||||
return unload_ok
|
||||
return await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
||||
|
||||
@@ -4,23 +4,21 @@ from homeassistant.components.binary_sensor import (
|
||||
BinarySensorDeviceClass,
|
||||
BinarySensorEntity,
|
||||
)
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import EntityCategory
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up binary sensors for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
[
|
||||
ToloFlowInBinarySensor(coordinator, entry),
|
||||
@@ -37,7 +35,7 @@ class ToloFlowInBinarySensor(ToloSaunaCoordinatorEntity, BinarySensorEntity):
|
||||
_attr_device_class = BinarySensorDeviceClass.OPENING
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize TOLO Water In Valve entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
@@ -58,7 +56,7 @@ class ToloFlowOutBinarySensor(ToloSaunaCoordinatorEntity, BinarySensorEntity):
|
||||
_attr_device_class = BinarySensorDeviceClass.OPENING
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize TOLO Water Out Valve entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
|
||||
@@ -3,23 +3,21 @@
|
||||
from tololib import LampMode
|
||||
|
||||
from homeassistant.components.button import ButtonEntity
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import EntityCategory
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up buttons for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
[
|
||||
ToloLampNextColorButton(coordinator, entry),
|
||||
@@ -34,7 +32,7 @@ class ToloLampNextColorButton(ToloSaunaCoordinatorEntity, ButtonEntity):
|
||||
_attr_translation_key = "next_color"
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize lamp next color button entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
|
||||
@@ -20,23 +20,21 @@ from homeassistant.components.climate import (
|
||||
HVACAction,
|
||||
HVACMode,
|
||||
)
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import ATTR_TEMPERATURE, PRECISION_WHOLE, UnitOfTemperature
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up climate controls for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities([SaunaClimate(coordinator, entry)])
|
||||
|
||||
|
||||
@@ -62,7 +60,7 @@ class SaunaClimate(ToloSaunaCoordinatorEntity, ClimateEntity):
|
||||
_attr_temperature_unit = UnitOfTemperature.CELSIUS
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize TOLO Sauna Climate entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
|
||||
@@ -17,6 +17,8 @@ from .const import DEFAULT_RETRY_COUNT, DEFAULT_RETRY_TIMEOUT
|
||||
|
||||
_LOGGER = logging.getLogger(__name__)
|
||||
|
||||
type ToloConfigEntry = ConfigEntry[ToloSaunaUpdateCoordinator]
|
||||
|
||||
|
||||
class ToloSaunaData(NamedTuple):
|
||||
"""Compound class for reflecting full state (status and info) of a TOLO Sauna."""
|
||||
@@ -28,9 +30,9 @@ class ToloSaunaData(NamedTuple):
|
||||
class ToloSaunaUpdateCoordinator(DataUpdateCoordinator[ToloSaunaData]):
|
||||
"""DataUpdateCoordinator for TOLO Sauna."""
|
||||
|
||||
config_entry: ConfigEntry
|
||||
config_entry: ToloConfigEntry
|
||||
|
||||
def __init__(self, hass: HomeAssistant, entry: ConfigEntry) -> None:
|
||||
def __init__(self, hass: HomeAssistant, entry: ToloConfigEntry) -> None:
|
||||
"""Initialize ToloSaunaUpdateCoordinator."""
|
||||
self.client = ToloClient(
|
||||
address=entry.data[CONF_HOST],
|
||||
|
||||
@@ -2,12 +2,11 @@
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.helpers.device_registry import DeviceInfo
|
||||
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
|
||||
|
||||
class ToloSaunaCoordinatorEntity(CoordinatorEntity[ToloSaunaUpdateCoordinator]):
|
||||
@@ -16,7 +15,7 @@ class ToloSaunaCoordinatorEntity(CoordinatorEntity[ToloSaunaUpdateCoordinator]):
|
||||
_attr_has_entity_name = True
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize ToloSaunaCoordinatorEntity."""
|
||||
super().__init__(coordinator)
|
||||
|
||||
@@ -5,22 +5,20 @@ from __future__ import annotations
|
||||
from typing import Any
|
||||
|
||||
from homeassistant.components.fan import FanEntity, FanEntityFeature
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up fan controls for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities([ToloFan(coordinator, entry)])
|
||||
|
||||
|
||||
@@ -31,7 +29,7 @@ class ToloFan(ToloSaunaCoordinatorEntity, FanEntity):
|
||||
_attr_supported_features = FanEntityFeature.TURN_OFF | FanEntityFeature.TURN_ON
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize TOLO fan entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
|
||||
@@ -5,22 +5,20 @@ from __future__ import annotations
|
||||
from typing import Any
|
||||
|
||||
from homeassistant.components.light import ColorMode, LightEntity
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up light controls for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities([ToloLight(coordinator, entry)])
|
||||
|
||||
|
||||
@@ -32,7 +30,7 @@ class ToloLight(ToloSaunaCoordinatorEntity, LightEntity):
|
||||
_attr_supported_color_modes = {ColorMode.ONOFF}
|
||||
|
||||
def __init__(
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ConfigEntry
|
||||
self, coordinator: ToloSaunaUpdateCoordinator, entry: ToloConfigEntry
|
||||
) -> None:
|
||||
"""Initialize TOLO Sauna Light entity."""
|
||||
super().__init__(coordinator, entry)
|
||||
|
||||
@@ -15,13 +15,11 @@ from tololib import (
|
||||
)
|
||||
|
||||
from homeassistant.components.number import NumberEntity, NumberEntityDescription
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import EntityCategory, UnitOfTime
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
@@ -67,11 +65,11 @@ NUMBERS = (
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up number controls for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
ToloNumberEntity(coordinator, entry, description) for description in NUMBERS
|
||||
)
|
||||
@@ -85,7 +83,7 @@ class ToloNumberEntity(ToloSaunaCoordinatorEntity, NumberEntity):
|
||||
def __init__(
|
||||
self,
|
||||
coordinator: ToloSaunaUpdateCoordinator,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
entity_description: ToloNumberEntityDescription,
|
||||
) -> None:
|
||||
"""Initialize TOLO Number entity."""
|
||||
|
||||
@@ -8,13 +8,12 @@ from dataclasses import dataclass
|
||||
from tololib import ToloClient, ToloSettings
|
||||
|
||||
from homeassistant.components.select import SelectEntity, SelectEntityDescription
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import EntityCategory
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN, AromaTherapySlot, LampMode
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .const import AromaTherapySlot, LampMode
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
@@ -53,11 +52,11 @@ SELECTS = (
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up select entities for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
ToloSelectEntity(coordinator, entry, description) for description in SELECTS
|
||||
)
|
||||
@@ -73,7 +72,7 @@ class ToloSelectEntity(ToloSaunaCoordinatorEntity, SelectEntity):
|
||||
def __init__(
|
||||
self,
|
||||
coordinator: ToloSaunaUpdateCoordinator,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
entity_description: ToloSelectEntityDescription,
|
||||
) -> None:
|
||||
"""Initialize TOLO select entity."""
|
||||
|
||||
@@ -13,7 +13,6 @@ from homeassistant.components.sensor import (
|
||||
SensorEntityDescription,
|
||||
SensorStateClass,
|
||||
)
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.const import (
|
||||
PERCENTAGE,
|
||||
EntityCategory,
|
||||
@@ -23,8 +22,7 @@ from homeassistant.const import (
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
@@ -88,11 +86,11 @@ SENSORS = (
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up (non-binary, general) sensors for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
ToloSensorEntity(coordinator, entry, description) for description in SENSORS
|
||||
)
|
||||
@@ -106,7 +104,7 @@ class ToloSensorEntity(ToloSaunaCoordinatorEntity, SensorEntity):
|
||||
def __init__(
|
||||
self,
|
||||
coordinator: ToloSaunaUpdateCoordinator,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
entity_description: ToloSensorEntityDescription,
|
||||
) -> None:
|
||||
"""Initialize TOLO Number entity."""
|
||||
|
||||
@@ -9,12 +9,10 @@ from typing import Any
|
||||
from tololib import ToloClient, ToloStatus
|
||||
|
||||
from homeassistant.components.switch import SwitchEntity, SwitchEntityDescription
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||
|
||||
from .const import DOMAIN
|
||||
from .coordinator import ToloSaunaUpdateCoordinator
|
||||
from .coordinator import ToloConfigEntry, ToloSaunaUpdateCoordinator
|
||||
from .entity import ToloSaunaCoordinatorEntity
|
||||
|
||||
|
||||
@@ -44,11 +42,11 @@ SWITCHES = (
|
||||
|
||||
async def async_setup_entry(
|
||||
hass: HomeAssistant,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
async_add_entities: AddConfigEntryEntitiesCallback,
|
||||
) -> None:
|
||||
"""Set up switch controls for TOLO Sauna."""
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
coordinator = entry.runtime_data
|
||||
async_add_entities(
|
||||
ToloSwitchEntity(coordinator, entry, description) for description in SWITCHES
|
||||
)
|
||||
@@ -62,7 +60,7 @@ class ToloSwitchEntity(ToloSaunaCoordinatorEntity, SwitchEntity):
|
||||
def __init__(
|
||||
self,
|
||||
coordinator: ToloSaunaUpdateCoordinator,
|
||||
entry: ConfigEntry,
|
||||
entry: ToloConfigEntry,
|
||||
entity_description: ToloSwitchEntityDescription,
|
||||
) -> None:
|
||||
"""Initialize TOLO switch entity."""
|
||||
|
||||
Reference in New Issue
Block a user