More UpCloud config entry refactors (#135548)

This commit is contained in:
Ville Skyttä 2025-01-14 20:49:00 -01:00 committed by GitHub
parent f80f6d9e3d
commit 18de735619
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 18 additions and 21 deletions

View File

@ -8,7 +8,6 @@ import logging
import requests.exceptions import requests.exceptions
import upcloud_api import upcloud_api
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import ( from homeassistant.const import (
CONF_PASSWORD, CONF_PASSWORD,
CONF_SCAN_INTERVAL, CONF_SCAN_INTERVAL,
@ -23,14 +22,12 @@ from homeassistant.helpers.dispatcher import (
) )
from .const import CONFIG_ENTRY_UPDATE_SIGNAL_TEMPLATE, DEFAULT_SCAN_INTERVAL from .const import CONFIG_ENTRY_UPDATE_SIGNAL_TEMPLATE, DEFAULT_SCAN_INTERVAL
from .coordinator import UpCloudDataUpdateCoordinator from .coordinator import UpCloudConfigEntry, UpCloudDataUpdateCoordinator
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
PLATFORMS = [Platform.BINARY_SENSOR, Platform.SWITCH] PLATFORMS = [Platform.BINARY_SENSOR, Platform.SWITCH]
type UpCloudConfigEntry = ConfigEntry[UpCloudDataUpdateCoordinator]
def _config_entry_update_signal_name(config_entry: UpCloudConfigEntry) -> str: def _config_entry_update_signal_name(config_entry: UpCloudConfigEntry) -> str:
"""Get signal name for updates to a config entry.""" """Get signal name for updates to a config entry."""
@ -69,6 +66,7 @@ async def async_setup_entry(hass: HomeAssistant, entry: UpCloudConfigEntry) -> b
coordinator = UpCloudDataUpdateCoordinator( coordinator = UpCloudDataUpdateCoordinator(
hass, hass,
config_entry=entry,
update_interval=update_interval, update_interval=update_interval,
cloud_manager=manager, cloud_manager=manager,
username=entry.data[CONF_USERNAME], username=entry.data[CONF_USERNAME],
@ -94,8 +92,6 @@ async def async_setup_entry(hass: HomeAssistant, entry: UpCloudConfigEntry) -> b
return True return True
async def async_unload_entry( async def async_unload_entry(hass: HomeAssistant, entry: UpCloudConfigEntry) -> bool:
hass: HomeAssistant, config_entry: UpCloudConfigEntry
) -> bool:
"""Unload the config entry.""" """Unload the config entry."""
return await hass.config_entries.async_unload_platforms(config_entry, PLATFORMS) return await hass.config_entries.async_unload_platforms(entry, PLATFORMS)

View File

@ -7,7 +7,7 @@ from homeassistant.components.binary_sensor import (
from homeassistant.core import HomeAssistant from homeassistant.core import HomeAssistant
from homeassistant.helpers.entity_platform import AddEntitiesCallback from homeassistant.helpers.entity_platform import AddEntitiesCallback
from . import UpCloudConfigEntry from .coordinator import UpCloudConfigEntry
from .entity import UpCloudServerEntity from .entity import UpCloudServerEntity

View File

@ -13,8 +13,8 @@ from homeassistant.config_entries import ConfigFlow, ConfigFlowResult, OptionsFl
from homeassistant.const import CONF_PASSWORD, CONF_SCAN_INTERVAL, CONF_USERNAME from homeassistant.const import CONF_PASSWORD, CONF_SCAN_INTERVAL, CONF_USERNAME
from homeassistant.core import callback from homeassistant.core import callback
from . import UpCloudConfigEntry
from .const import DEFAULT_SCAN_INTERVAL, DOMAIN from .const import DEFAULT_SCAN_INTERVAL, DOMAIN
from .coordinator import UpCloudConfigEntry
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)

View File

@ -4,20 +4,20 @@ from __future__ import annotations
from datetime import timedelta from datetime import timedelta
import logging import logging
from typing import TYPE_CHECKING
import upcloud_api import upcloud_api
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import CONF_SCAN_INTERVAL from homeassistant.const import CONF_SCAN_INTERVAL
from homeassistant.core import HomeAssistant from homeassistant.core import HomeAssistant
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
if TYPE_CHECKING:
from . import UpCloudConfigEntry
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
type UpCloudConfigEntry = ConfigEntry[UpCloudDataUpdateCoordinator]
class UpCloudDataUpdateCoordinator( class UpCloudDataUpdateCoordinator(
DataUpdateCoordinator[dict[str, upcloud_api.Server]] DataUpdateCoordinator[dict[str, upcloud_api.Server]]
): ):
@ -27,13 +27,18 @@ class UpCloudDataUpdateCoordinator(
self, self,
hass: HomeAssistant, hass: HomeAssistant,
*, *,
config_entry: UpCloudConfigEntry,
cloud_manager: upcloud_api.CloudManager, cloud_manager: upcloud_api.CloudManager,
update_interval: timedelta, update_interval: timedelta,
username: str, username: str,
) -> None: ) -> None:
"""Initialize coordinator.""" """Initialize coordinator."""
super().__init__( super().__init__(
hass, _LOGGER, name=f"{username}@UpCloud", update_interval=update_interval hass,
_LOGGER,
config_entry=config_entry,
name=f"{username}@UpCloud",
update_interval=update_interval,
) )
self.cloud_manager = cloud_manager self.cloud_manager = cloud_manager

View File

@ -2,7 +2,6 @@
from __future__ import annotations from __future__ import annotations
import logging
from typing import Any from typing import Any
import upcloud_api import upcloud_api
@ -11,11 +10,8 @@ from homeassistant.const import CONF_USERNAME, STATE_OFF, STATE_ON, STATE_PROBLE
from homeassistant.helpers.device_registry import DeviceEntryType, DeviceInfo from homeassistant.helpers.device_registry import DeviceEntryType, DeviceInfo
from homeassistant.helpers.update_coordinator import CoordinatorEntity from homeassistant.helpers.update_coordinator import CoordinatorEntity
from . import UpCloudConfigEntry
from .const import DOMAIN from .const import DOMAIN
from .coordinator import UpCloudDataUpdateCoordinator from .coordinator import UpCloudConfigEntry, UpCloudDataUpdateCoordinator
_LOGGER = logging.getLogger(__name__)
ATTR_CORE_NUMBER = "core_number" ATTR_CORE_NUMBER = "core_number"
ATTR_HOSTNAME = "hostname" ATTR_HOSTNAME = "hostname"

View File

@ -8,7 +8,7 @@ from homeassistant.core import HomeAssistant
from homeassistant.helpers.dispatcher import dispatcher_send from homeassistant.helpers.dispatcher import dispatcher_send
from homeassistant.helpers.entity_platform import AddEntitiesCallback from homeassistant.helpers.entity_platform import AddEntitiesCallback
from . import UpCloudConfigEntry from .coordinator import UpCloudConfigEntry
from .entity import UpCloudServerEntity from .entity import UpCloudServerEntity
SIGNAL_UPDATE_UPCLOUD = "upcloud_update" SIGNAL_UPDATE_UPCLOUD = "upcloud_update"