mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 21:27:38 +00:00
Netgear cleanup (#99505)
Co-authored-by: Robert Resch <robert@resch.dev> Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>
This commit is contained in:
parent
b84076d3d6
commit
98c9edc00c
@ -793,6 +793,7 @@ omit =
|
|||||||
homeassistant/components/netgear/__init__.py
|
homeassistant/components/netgear/__init__.py
|
||||||
homeassistant/components/netgear/button.py
|
homeassistant/components/netgear/button.py
|
||||||
homeassistant/components/netgear/device_tracker.py
|
homeassistant/components/netgear/device_tracker.py
|
||||||
|
homeassistant/components/netgear/entity.py
|
||||||
homeassistant/components/netgear/router.py
|
homeassistant/components/netgear/router.py
|
||||||
homeassistant/components/netgear/sensor.py
|
homeassistant/components/netgear/sensor.py
|
||||||
homeassistant/components/netgear/switch.py
|
homeassistant/components/netgear/switch.py
|
||||||
|
@ -6,7 +6,7 @@ import logging
|
|||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import CONF_HOST, CONF_PORT, CONF_SSL
|
from homeassistant.const import CONF_PORT, CONF_SSL
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.exceptions import ConfigEntryNotReady
|
from homeassistant.exceptions import ConfigEntryNotReady
|
||||||
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
||||||
@ -62,23 +62,6 @@ async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
|||||||
|
|
||||||
entry.async_on_unload(entry.add_update_listener(update_listener))
|
entry.async_on_unload(entry.add_update_listener(update_listener))
|
||||||
|
|
||||||
configuration_url = None
|
|
||||||
if host := entry.data[CONF_HOST]:
|
|
||||||
configuration_url = f"http://{host}/"
|
|
||||||
|
|
||||||
assert entry.unique_id
|
|
||||||
device_registry = dr.async_get(hass)
|
|
||||||
device_registry.async_get_or_create(
|
|
||||||
config_entry_id=entry.entry_id,
|
|
||||||
identifiers={(DOMAIN, entry.unique_id)},
|
|
||||||
manufacturer="Netgear",
|
|
||||||
name=router.device_name,
|
|
||||||
model=router.model,
|
|
||||||
sw_version=router.firmware_version,
|
|
||||||
hw_version=router.hardware_version,
|
|
||||||
configuration_url=configuration_url,
|
|
||||||
)
|
|
||||||
|
|
||||||
async def async_update_devices() -> bool:
|
async def async_update_devices() -> bool:
|
||||||
"""Fetch data from the router."""
|
"""Fetch data from the router."""
|
||||||
if router.track_devices:
|
if router.track_devices:
|
||||||
|
@ -15,7 +15,8 @@ from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
|
|
||||||
from .const import DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
from .const import DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
||||||
from .router import NetgearRouter, NetgearRouterCoordinatorEntity
|
from .entity import NetgearRouterCoordinatorEntity
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
@ -35,7 +36,6 @@ class NetgearButtonEntityDescription(
|
|||||||
BUTTONS = [
|
BUTTONS = [
|
||||||
NetgearButtonEntityDescription(
|
NetgearButtonEntityDescription(
|
||||||
key="reboot",
|
key="reboot",
|
||||||
name="Reboot",
|
|
||||||
device_class=ButtonDeviceClass.RESTART,
|
device_class=ButtonDeviceClass.RESTART,
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
action=lambda router: router.async_reboot,
|
action=lambda router: router.async_reboot,
|
||||||
@ -69,8 +69,7 @@ class NetgearRouterButtonEntity(NetgearRouterCoordinatorEntity, ButtonEntity):
|
|||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(coordinator, router)
|
super().__init__(coordinator, router)
|
||||||
self.entity_description = entity_description
|
self.entity_description = entity_description
|
||||||
self._name = f"{router.device_name} {entity_description.name}"
|
self._attr_unique_id = f"{router.serial_number}-{entity_description.key}"
|
||||||
self._unique_id = f"{router.serial_number}-{entity_description.key}"
|
|
||||||
|
|
||||||
async def async_press(self) -> None:
|
async def async_press(self) -> None:
|
||||||
"""Triggers the button press service."""
|
"""Triggers the button press service."""
|
||||||
|
@ -10,7 +10,8 @@ from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
|
|
||||||
from .const import DEVICE_ICONS, DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
from .const import DEVICE_ICONS, DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
||||||
from .router import NetgearBaseEntity, NetgearRouter
|
from .entity import NetgearDeviceEntity
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -46,9 +47,11 @@ async def async_setup_entry(
|
|||||||
new_device_callback()
|
new_device_callback()
|
||||||
|
|
||||||
|
|
||||||
class NetgearScannerEntity(NetgearBaseEntity, ScannerEntity):
|
class NetgearScannerEntity(NetgearDeviceEntity, ScannerEntity):
|
||||||
"""Representation of a device connected to a Netgear router."""
|
"""Representation of a device connected to a Netgear router."""
|
||||||
|
|
||||||
|
_attr_has_entity_name = False
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
self, coordinator: DataUpdateCoordinator, router: NetgearRouter, device: dict
|
self, coordinator: DataUpdateCoordinator, router: NetgearRouter, device: dict
|
||||||
) -> None:
|
) -> None:
|
||||||
@ -56,6 +59,7 @@ class NetgearScannerEntity(NetgearBaseEntity, ScannerEntity):
|
|||||||
super().__init__(coordinator, router, device)
|
super().__init__(coordinator, router, device)
|
||||||
self._hostname = self.get_hostname()
|
self._hostname = self.get_hostname()
|
||||||
self._icon = DEVICE_ICONS.get(device["device_type"], "mdi:help-network")
|
self._icon = DEVICE_ICONS.get(device["device_type"], "mdi:help-network")
|
||||||
|
self._attr_name = self._device_name
|
||||||
|
|
||||||
def get_hostname(self) -> str | None:
|
def get_hostname(self) -> str | None:
|
||||||
"""Return the hostname of the given device or None if we don't know."""
|
"""Return the hostname of the given device or None if we don't know."""
|
||||||
|
107
homeassistant/components/netgear/entity.py
Normal file
107
homeassistant/components/netgear/entity.py
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
"""Represent the Netgear router and its devices."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from abc import abstractmethod
|
||||||
|
|
||||||
|
from homeassistant.const import CONF_HOST
|
||||||
|
from homeassistant.core import callback
|
||||||
|
from homeassistant.helpers import device_registry as dr
|
||||||
|
from homeassistant.helpers.device_registry import DeviceInfo
|
||||||
|
from homeassistant.helpers.entity import Entity
|
||||||
|
from homeassistant.helpers.update_coordinator import (
|
||||||
|
CoordinatorEntity,
|
||||||
|
DataUpdateCoordinator,
|
||||||
|
)
|
||||||
|
|
||||||
|
from .const import DOMAIN
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
|
|
||||||
|
class NetgearDeviceEntity(CoordinatorEntity):
|
||||||
|
"""Base class for a device connected to a Netgear router."""
|
||||||
|
|
||||||
|
_attr_has_entity_name = True
|
||||||
|
|
||||||
|
def __init__(
|
||||||
|
self, coordinator: DataUpdateCoordinator, router: NetgearRouter, device: dict
|
||||||
|
) -> None:
|
||||||
|
"""Initialize a Netgear device."""
|
||||||
|
super().__init__(coordinator)
|
||||||
|
self._router = router
|
||||||
|
self._device = device
|
||||||
|
self._mac = device["mac"]
|
||||||
|
self._device_name = self.get_device_name()
|
||||||
|
self._active = device["active"]
|
||||||
|
self._attr_unique_id = self._mac
|
||||||
|
self._attr_device_info = DeviceInfo(
|
||||||
|
connections={(dr.CONNECTION_NETWORK_MAC, self._mac)},
|
||||||
|
default_name=self._device_name,
|
||||||
|
default_model=device["device_model"],
|
||||||
|
via_device=(DOMAIN, router.unique_id),
|
||||||
|
)
|
||||||
|
|
||||||
|
def get_device_name(self):
|
||||||
|
"""Return the name of the given device or the MAC if we don't know."""
|
||||||
|
name = self._device["name"]
|
||||||
|
if not name or name == "--":
|
||||||
|
name = self._mac
|
||||||
|
|
||||||
|
return name
|
||||||
|
|
||||||
|
@abstractmethod
|
||||||
|
@callback
|
||||||
|
def async_update_device(self) -> None:
|
||||||
|
"""Update the Netgear device."""
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def _handle_coordinator_update(self) -> None:
|
||||||
|
"""Handle updated data from the coordinator."""
|
||||||
|
self.async_update_device()
|
||||||
|
super()._handle_coordinator_update()
|
||||||
|
|
||||||
|
|
||||||
|
class NetgearRouterEntity(Entity):
|
||||||
|
"""Base class for a Netgear router entity without coordinator."""
|
||||||
|
|
||||||
|
_attr_has_entity_name = True
|
||||||
|
|
||||||
|
def __init__(self, router: NetgearRouter) -> None:
|
||||||
|
"""Initialize a Netgear device."""
|
||||||
|
self._router = router
|
||||||
|
|
||||||
|
configuration_url = None
|
||||||
|
if host := router.entry.data[CONF_HOST]:
|
||||||
|
configuration_url = f"http://{host}/"
|
||||||
|
|
||||||
|
self._attr_unique_id = router.serial_number
|
||||||
|
self._attr_device_info = DeviceInfo(
|
||||||
|
identifiers={(DOMAIN, router.unique_id)},
|
||||||
|
manufacturer="Netgear",
|
||||||
|
name=router.device_name,
|
||||||
|
model=router.model,
|
||||||
|
sw_version=router.firmware_version,
|
||||||
|
hw_version=router.hardware_version,
|
||||||
|
configuration_url=configuration_url,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class NetgearRouterCoordinatorEntity(NetgearRouterEntity, CoordinatorEntity):
|
||||||
|
"""Base class for a Netgear router entity."""
|
||||||
|
|
||||||
|
def __init__(
|
||||||
|
self, coordinator: DataUpdateCoordinator, router: NetgearRouter
|
||||||
|
) -> None:
|
||||||
|
"""Initialize a Netgear device."""
|
||||||
|
CoordinatorEntity.__init__(self, coordinator)
|
||||||
|
NetgearRouterEntity.__init__(self, router)
|
||||||
|
|
||||||
|
@abstractmethod
|
||||||
|
@callback
|
||||||
|
def async_update_device(self) -> None:
|
||||||
|
"""Update the Netgear device."""
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def _handle_coordinator_update(self) -> None:
|
||||||
|
"""Handle updated data from the coordinator."""
|
||||||
|
self.async_update_device()
|
||||||
|
super()._handle_coordinator_update()
|
@ -1,7 +1,6 @@
|
|||||||
"""Represent the Netgear router and its devices."""
|
"""Represent the Netgear router and its devices."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from abc import abstractmethod
|
|
||||||
import asyncio
|
import asyncio
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
import logging
|
import logging
|
||||||
@ -17,14 +16,8 @@ from homeassistant.const import (
|
|||||||
CONF_SSL,
|
CONF_SSL,
|
||||||
CONF_USERNAME,
|
CONF_USERNAME,
|
||||||
)
|
)
|
||||||
from homeassistant.core import HomeAssistant, callback
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import device_registry as dr
|
from homeassistant.helpers import device_registry as dr
|
||||||
from homeassistant.helpers.device_registry import DeviceInfo
|
|
||||||
from homeassistant.helpers.entity import Entity
|
|
||||||
from homeassistant.helpers.update_coordinator import (
|
|
||||||
CoordinatorEntity,
|
|
||||||
DataUpdateCoordinator,
|
|
||||||
)
|
|
||||||
from homeassistant.util import dt as dt_util
|
from homeassistant.util import dt as dt_util
|
||||||
|
|
||||||
from .const import (
|
from .const import (
|
||||||
@ -275,137 +268,3 @@ class NetgearRouter:
|
|||||||
def ssl(self) -> bool:
|
def ssl(self) -> bool:
|
||||||
"""SSL used by the API."""
|
"""SSL used by the API."""
|
||||||
return self.api.ssl
|
return self.api.ssl
|
||||||
|
|
||||||
|
|
||||||
class NetgearBaseEntity(CoordinatorEntity):
|
|
||||||
"""Base class for a device connected to a Netgear router."""
|
|
||||||
|
|
||||||
def __init__(
|
|
||||||
self, coordinator: DataUpdateCoordinator, router: NetgearRouter, device: dict
|
|
||||||
) -> None:
|
|
||||||
"""Initialize a Netgear device."""
|
|
||||||
super().__init__(coordinator)
|
|
||||||
self._router = router
|
|
||||||
self._device = device
|
|
||||||
self._mac = device["mac"]
|
|
||||||
self._name = self.get_device_name()
|
|
||||||
self._device_name = self._name
|
|
||||||
self._active = device["active"]
|
|
||||||
|
|
||||||
def get_device_name(self):
|
|
||||||
"""Return the name of the given device or the MAC if we don't know."""
|
|
||||||
name = self._device["name"]
|
|
||||||
if not name or name == "--":
|
|
||||||
name = self._mac
|
|
||||||
|
|
||||||
return name
|
|
||||||
|
|
||||||
@abstractmethod
|
|
||||||
@callback
|
|
||||||
def async_update_device(self) -> None:
|
|
||||||
"""Update the Netgear device."""
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _handle_coordinator_update(self) -> None:
|
|
||||||
"""Handle updated data from the coordinator."""
|
|
||||||
self.async_update_device()
|
|
||||||
super()._handle_coordinator_update()
|
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self) -> str:
|
|
||||||
"""Return the name."""
|
|
||||||
return self._name
|
|
||||||
|
|
||||||
|
|
||||||
class NetgearDeviceEntity(NetgearBaseEntity):
|
|
||||||
"""Base class for a device connected to a Netgear router."""
|
|
||||||
|
|
||||||
def __init__(
|
|
||||||
self, coordinator: DataUpdateCoordinator, router: NetgearRouter, device: dict
|
|
||||||
) -> None:
|
|
||||||
"""Initialize a Netgear device."""
|
|
||||||
super().__init__(coordinator, router, device)
|
|
||||||
self._unique_id = self._mac
|
|
||||||
|
|
||||||
@property
|
|
||||||
def unique_id(self) -> str:
|
|
||||||
"""Return a unique ID."""
|
|
||||||
return self._unique_id
|
|
||||||
|
|
||||||
@property
|
|
||||||
def device_info(self) -> DeviceInfo:
|
|
||||||
"""Return the device information."""
|
|
||||||
return DeviceInfo(
|
|
||||||
connections={(dr.CONNECTION_NETWORK_MAC, self._mac)},
|
|
||||||
default_name=self._device_name,
|
|
||||||
default_model=self._device["device_model"],
|
|
||||||
via_device=(DOMAIN, self._router.unique_id),
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class NetgearRouterCoordinatorEntity(CoordinatorEntity):
|
|
||||||
"""Base class for a Netgear router entity."""
|
|
||||||
|
|
||||||
def __init__(
|
|
||||||
self, coordinator: DataUpdateCoordinator, router: NetgearRouter
|
|
||||||
) -> None:
|
|
||||||
"""Initialize a Netgear device."""
|
|
||||||
super().__init__(coordinator)
|
|
||||||
self._router = router
|
|
||||||
self._name = router.device_name
|
|
||||||
self._unique_id = router.serial_number
|
|
||||||
|
|
||||||
@abstractmethod
|
|
||||||
@callback
|
|
||||||
def async_update_device(self) -> None:
|
|
||||||
"""Update the Netgear device."""
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _handle_coordinator_update(self) -> None:
|
|
||||||
"""Handle updated data from the coordinator."""
|
|
||||||
self.async_update_device()
|
|
||||||
super()._handle_coordinator_update()
|
|
||||||
|
|
||||||
@property
|
|
||||||
def unique_id(self) -> str:
|
|
||||||
"""Return a unique ID."""
|
|
||||||
return self._unique_id
|
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self) -> str:
|
|
||||||
"""Return the name."""
|
|
||||||
return self._name
|
|
||||||
|
|
||||||
@property
|
|
||||||
def device_info(self) -> DeviceInfo:
|
|
||||||
"""Return the device information."""
|
|
||||||
return DeviceInfo(
|
|
||||||
identifiers={(DOMAIN, self._router.unique_id)},
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class NetgearRouterEntity(Entity):
|
|
||||||
"""Base class for a Netgear router entity without coordinator."""
|
|
||||||
|
|
||||||
def __init__(self, router: NetgearRouter) -> None:
|
|
||||||
"""Initialize a Netgear device."""
|
|
||||||
self._router = router
|
|
||||||
self._name = router.device_name
|
|
||||||
self._unique_id = router.serial_number
|
|
||||||
|
|
||||||
@property
|
|
||||||
def unique_id(self) -> str:
|
|
||||||
"""Return a unique ID."""
|
|
||||||
return self._unique_id
|
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self) -> str:
|
|
||||||
"""Return the name."""
|
|
||||||
return self._name
|
|
||||||
|
|
||||||
@property
|
|
||||||
def device_info(self) -> DeviceInfo:
|
|
||||||
"""Return the device information."""
|
|
||||||
return DeviceInfo(
|
|
||||||
identifiers={(DOMAIN, self._router.unique_id)},
|
|
||||||
)
|
|
||||||
|
@ -36,7 +36,8 @@ from .const import (
|
|||||||
KEY_COORDINATOR_UTIL,
|
KEY_COORDINATOR_UTIL,
|
||||||
KEY_ROUTER,
|
KEY_ROUTER,
|
||||||
)
|
)
|
||||||
from .router import NetgearDeviceEntity, NetgearRouter, NetgearRouterCoordinatorEntity
|
from .entity import NetgearDeviceEntity, NetgearRouterCoordinatorEntity
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -379,10 +380,9 @@ class NetgearSensorEntity(NetgearDeviceEntity, SensorEntity):
|
|||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(coordinator, router, device)
|
super().__init__(coordinator, router, device)
|
||||||
self._attribute = attribute
|
self._attribute = attribute
|
||||||
self.entity_description = SENSOR_TYPES[self._attribute]
|
self.entity_description = SENSOR_TYPES[attribute]
|
||||||
self._name = f"{self.get_device_name()} {self.entity_description.name}"
|
self._attr_unique_id = f"{self._mac}-{attribute}"
|
||||||
self._unique_id = f"{self._mac}-{self._attribute}"
|
self._state = device.get(attribute)
|
||||||
self._state = self._device.get(self._attribute)
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def native_value(self):
|
def native_value(self):
|
||||||
@ -413,8 +413,7 @@ class NetgearRouterSensorEntity(NetgearRouterCoordinatorEntity, RestoreSensor):
|
|||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(coordinator, router)
|
super().__init__(coordinator, router)
|
||||||
self.entity_description = entity_description
|
self.entity_description = entity_description
|
||||||
self._name = f"{router.device_name} {entity_description.name}"
|
self._attr_unique_id = f"{router.serial_number}-{entity_description.key}-{entity_description.index}"
|
||||||
self._unique_id = f"{router.serial_number}-{entity_description.key}-{entity_description.index}"
|
|
||||||
|
|
||||||
self._value: StateType | date | datetime | Decimal = None
|
self._value: StateType | date | datetime | Decimal = None
|
||||||
self.async_update_device()
|
self.async_update_device()
|
||||||
|
@ -15,7 +15,8 @@ from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
|
|
||||||
from .const import DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
from .const import DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
||||||
from .router import NetgearDeviceEntity, NetgearRouter, NetgearRouterEntity
|
from .entity import NetgearDeviceEntity, NetgearRouterEntity
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -166,9 +167,7 @@ class NetgearAllowBlock(NetgearDeviceEntity, SwitchEntity):
|
|||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(coordinator, router, device)
|
super().__init__(coordinator, router, device)
|
||||||
self.entity_description = entity_description
|
self.entity_description = entity_description
|
||||||
self._name = f"{self.get_device_name()} {self.entity_description.name}"
|
self._attr_unique_id = f"{self._mac}-{entity_description.key}"
|
||||||
self._unique_id = f"{self._mac}-{self.entity_description.key}"
|
|
||||||
self._attr_is_on = None
|
|
||||||
self.async_update_device()
|
self.async_update_device()
|
||||||
|
|
||||||
async def async_turn_on(self, **kwargs: Any) -> None:
|
async def async_turn_on(self, **kwargs: Any) -> None:
|
||||||
@ -206,8 +205,7 @@ class NetgearRouterSwitchEntity(NetgearRouterEntity, SwitchEntity):
|
|||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(router)
|
super().__init__(router)
|
||||||
self.entity_description = entity_description
|
self.entity_description = entity_description
|
||||||
self._name = f"{router.device_name} {entity_description.name}"
|
self._attr_unique_id = f"{router.serial_number}-{entity_description.key}"
|
||||||
self._unique_id = f"{router.serial_number}-{entity_description.key}"
|
|
||||||
|
|
||||||
self._attr_is_on = None
|
self._attr_is_on = None
|
||||||
self._attr_available = False
|
self._attr_available = False
|
||||||
|
@ -15,7 +15,8 @@ from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
|
|
||||||
from .const import DOMAIN, KEY_COORDINATOR_FIRMWARE, KEY_ROUTER
|
from .const import DOMAIN, KEY_COORDINATOR_FIRMWARE, KEY_ROUTER
|
||||||
from .router import NetgearRouter, NetgearRouterCoordinatorEntity
|
from .entity import NetgearRouterCoordinatorEntity
|
||||||
|
from .router import NetgearRouter
|
||||||
|
|
||||||
LOGGER = logging.getLogger(__name__)
|
LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -44,8 +45,7 @@ class NetgearUpdateEntity(NetgearRouterCoordinatorEntity, UpdateEntity):
|
|||||||
) -> None:
|
) -> None:
|
||||||
"""Initialize a Netgear device."""
|
"""Initialize a Netgear device."""
|
||||||
super().__init__(coordinator, router)
|
super().__init__(coordinator, router)
|
||||||
self._name = f"{router.device_name} Update"
|
self._attr_unique_id = f"{router.serial_number}-update"
|
||||||
self._unique_id = f"{router.serial_number}-update"
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def installed_version(self) -> str | None:
|
def installed_version(self) -> str | None:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user