mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 11:17:21 +00:00
More UpCloud config entry refactors (#135548)
This commit is contained in:
parent
f80f6d9e3d
commit
18de735619
@ -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)
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
@ -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__)
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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"
|
||||||
|
@ -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"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user