mirror of
https://github.com/home-assistant/core.git
synced 2025-07-25 06:07:17 +00:00
Add Netgear allow/block switch (#65705)
* add allow/block switch * keep api private * typing * change default to None * retain None state * change default to None
This commit is contained in:
parent
bd31cfbd40
commit
d81139377c
@ -733,6 +733,7 @@ omit =
|
|||||||
homeassistant/components/netgear/device_tracker.py
|
homeassistant/components/netgear/device_tracker.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_lte/*
|
homeassistant/components/netgear_lte/*
|
||||||
homeassistant/components/netio/switch.py
|
homeassistant/components/netio/switch.py
|
||||||
homeassistant/components/neurio_energy/sensor.py
|
homeassistant/components/neurio_energy/sensor.py
|
||||||
|
@ -5,14 +5,14 @@ from homeassistant.const import Platform
|
|||||||
|
|
||||||
DOMAIN = "netgear"
|
DOMAIN = "netgear"
|
||||||
|
|
||||||
|
PLATFORMS = [Platform.DEVICE_TRACKER, Platform.SENSOR, Platform.SWITCH]
|
||||||
|
|
||||||
CONF_CONSIDER_HOME = "consider_home"
|
CONF_CONSIDER_HOME = "consider_home"
|
||||||
|
|
||||||
KEY_ROUTER = "router"
|
KEY_ROUTER = "router"
|
||||||
KEY_COORDINATOR = "coordinator"
|
KEY_COORDINATOR = "coordinator"
|
||||||
KEY_COORDINATOR_TRAFFIC = "coordinator_traffic"
|
KEY_COORDINATOR_TRAFFIC = "coordinator_traffic"
|
||||||
|
|
||||||
PLATFORMS = [Platform.DEVICE_TRACKER, Platform.SENSOR]
|
|
||||||
|
|
||||||
DEFAULT_CONSIDER_HOME = timedelta(seconds=180)
|
DEFAULT_CONSIDER_HOME = timedelta(seconds=180)
|
||||||
DEFAULT_NAME = "Netgear router"
|
DEFAULT_NAME = "Netgear router"
|
||||||
|
|
||||||
|
@ -147,6 +147,7 @@ class NetgearRouter:
|
|||||||
"ip": None,
|
"ip": None,
|
||||||
"ssid": None,
|
"ssid": None,
|
||||||
"conn_ap_mac": None,
|
"conn_ap_mac": None,
|
||||||
|
"allow_or_block": None,
|
||||||
}
|
}
|
||||||
|
|
||||||
return True
|
return True
|
||||||
@ -200,6 +201,13 @@ class NetgearRouter:
|
|||||||
async with self._api_lock:
|
async with self._api_lock:
|
||||||
return await self.hass.async_add_executor_job(self._api.get_traffic_meter)
|
return await self.hass.async_add_executor_job(self._api.get_traffic_meter)
|
||||||
|
|
||||||
|
async def async_allow_block_device(self, mac: str, allow_block: str) -> None:
|
||||||
|
"""Allow or block a device connected to the router."""
|
||||||
|
async with self._api_lock:
|
||||||
|
await self.hass.async_add_executor_job(
|
||||||
|
self._api.allow_block_device, mac, allow_block
|
||||||
|
)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def port(self) -> int:
|
def port(self) -> int:
|
||||||
"""Port used by the API."""
|
"""Port used by the API."""
|
||||||
|
106
homeassistant/components/netgear/switch.py
Normal file
106
homeassistant/components/netgear/switch.py
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
"""Support for Netgear switches."""
|
||||||
|
import logging
|
||||||
|
|
||||||
|
from pynetgear import ALLOW, BLOCK
|
||||||
|
|
||||||
|
from homeassistant.components.switch import SwitchEntity, SwitchEntityDescription
|
||||||
|
from homeassistant.config_entries import ConfigEntry
|
||||||
|
from homeassistant.core import HomeAssistant, callback
|
||||||
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
|
|
||||||
|
from .const import DOMAIN, KEY_COORDINATOR, KEY_ROUTER
|
||||||
|
from .router import NetgearDeviceEntity, NetgearRouter
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
SWITCH_TYPES = [
|
||||||
|
SwitchEntityDescription(
|
||||||
|
key="allow_or_block",
|
||||||
|
name="Allowed on network",
|
||||||
|
icon="mdi:block-helper",
|
||||||
|
entity_category=EntityCategory.CONFIG,
|
||||||
|
)
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
async def async_setup_entry(
|
||||||
|
hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
|
||||||
|
) -> None:
|
||||||
|
"""Set up switches for Netgear component."""
|
||||||
|
router = hass.data[DOMAIN][entry.entry_id][KEY_ROUTER]
|
||||||
|
coordinator = hass.data[DOMAIN][entry.entry_id][KEY_COORDINATOR]
|
||||||
|
tracked = set()
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def new_device_callback() -> None:
|
||||||
|
"""Add new devices if needed."""
|
||||||
|
new_entities = []
|
||||||
|
if not coordinator.data:
|
||||||
|
return
|
||||||
|
|
||||||
|
for mac, device in router.devices.items():
|
||||||
|
if mac in tracked:
|
||||||
|
continue
|
||||||
|
|
||||||
|
new_entities.extend(
|
||||||
|
[
|
||||||
|
NetgearAllowBlock(coordinator, router, device, entity_description)
|
||||||
|
for entity_description in SWITCH_TYPES
|
||||||
|
]
|
||||||
|
)
|
||||||
|
tracked.add(mac)
|
||||||
|
|
||||||
|
if new_entities:
|
||||||
|
async_add_entities(new_entities)
|
||||||
|
|
||||||
|
entry.async_on_unload(coordinator.async_add_listener(new_device_callback))
|
||||||
|
|
||||||
|
coordinator.data = True
|
||||||
|
new_device_callback()
|
||||||
|
|
||||||
|
|
||||||
|
class NetgearAllowBlock(NetgearDeviceEntity, SwitchEntity):
|
||||||
|
"""Allow or Block a device from the network."""
|
||||||
|
|
||||||
|
_attr_entity_registry_enabled_default = False
|
||||||
|
|
||||||
|
def __init__(
|
||||||
|
self,
|
||||||
|
coordinator: DataUpdateCoordinator,
|
||||||
|
router: NetgearRouter,
|
||||||
|
device: dict,
|
||||||
|
entity_description: SwitchEntityDescription,
|
||||||
|
) -> None:
|
||||||
|
"""Initialize a Netgear device."""
|
||||||
|
super().__init__(coordinator, router, device)
|
||||||
|
self.entity_description = entity_description
|
||||||
|
self._name = f"{self.get_device_name()} {self.entity_description.name}"
|
||||||
|
self._unique_id = f"{self._mac}-{self.entity_description.key}"
|
||||||
|
self._state = None
|
||||||
|
self.async_update_device()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def is_on(self):
|
||||||
|
"""Return true if switch is on."""
|
||||||
|
return self._state
|
||||||
|
|
||||||
|
async def async_turn_on(self, **kwargs):
|
||||||
|
"""Turn the switch on."""
|
||||||
|
await self._router.async_allow_block_device(self._mac, ALLOW)
|
||||||
|
|
||||||
|
async def async_turn_off(self, **kwargs):
|
||||||
|
"""Turn the switch off."""
|
||||||
|
await self._router.async_allow_block_device(self._mac, BLOCK)
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def async_update_device(self) -> None:
|
||||||
|
"""Update the Netgear device."""
|
||||||
|
self._device = self._router.devices[self._mac]
|
||||||
|
self._active = self._device["active"]
|
||||||
|
if self._device[self.entity_description.key] is None:
|
||||||
|
self._state = None
|
||||||
|
else:
|
||||||
|
self._state = self._device[self.entity_description.key] == "Allow"
|
Loading…
x
Reference in New Issue
Block a user