mirror of
https://github.com/home-assistant/core.git
synced 2025-07-18 10:47:10 +00:00
Use entity class attributes for arlo (#52681)
* Use entity class attributes for arlo * revert sensor
This commit is contained in:
parent
9b577e830d
commit
c865a1876e
@ -14,6 +14,7 @@ from homeassistant.components.alarm_control_panel.const import (
|
|||||||
)
|
)
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
ATTR_ATTRIBUTION,
|
ATTR_ATTRIBUTION,
|
||||||
|
ATTR_DEVICE_ID,
|
||||||
STATE_ALARM_ARMED_AWAY,
|
STATE_ALARM_ARMED_AWAY,
|
||||||
STATE_ALARM_ARMED_HOME,
|
STATE_ALARM_ARMED_HOME,
|
||||||
STATE_ALARM_ARMED_NIGHT,
|
STATE_ALARM_ARMED_NIGHT,
|
||||||
@ -33,8 +34,6 @@ CONF_HOME_MODE_NAME = "home_mode_name"
|
|||||||
CONF_AWAY_MODE_NAME = "away_mode_name"
|
CONF_AWAY_MODE_NAME = "away_mode_name"
|
||||||
CONF_NIGHT_MODE_NAME = "night_mode_name"
|
CONF_NIGHT_MODE_NAME = "night_mode_name"
|
||||||
|
|
||||||
DISARMED = "disarmed"
|
|
||||||
|
|
||||||
ICON = "mdi:security"
|
ICON = "mdi:security"
|
||||||
|
|
||||||
PLATFORM_SCHEMA = PARENT_PLATFORM_SCHEMA.extend(
|
PLATFORM_SCHEMA = PARENT_PLATFORM_SCHEMA.extend(
|
||||||
@ -69,18 +68,22 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
|
|||||||
class ArloBaseStation(AlarmControlPanelEntity):
|
class ArloBaseStation(AlarmControlPanelEntity):
|
||||||
"""Representation of an Arlo Alarm Control Panel."""
|
"""Representation of an Arlo Alarm Control Panel."""
|
||||||
|
|
||||||
|
_attr_supported_features = (
|
||||||
|
SUPPORT_ALARM_ARM_HOME | SUPPORT_ALARM_ARM_AWAY | SUPPORT_ALARM_ARM_NIGHT
|
||||||
|
)
|
||||||
|
_attr_icon = ICON
|
||||||
|
|
||||||
def __init__(self, data, home_mode_name, away_mode_name, night_mode_name):
|
def __init__(self, data, home_mode_name, away_mode_name, night_mode_name):
|
||||||
"""Initialize the alarm control panel."""
|
"""Initialize the alarm control panel."""
|
||||||
self._base_station = data
|
self._base_station = data
|
||||||
self._home_mode_name = home_mode_name
|
self._home_mode_name = home_mode_name
|
||||||
self._away_mode_name = away_mode_name
|
self._away_mode_name = away_mode_name
|
||||||
self._night_mode_name = night_mode_name
|
self._night_mode_name = night_mode_name
|
||||||
self._state = None
|
self._attr_name = data.name
|
||||||
|
self._attr_extra_state_attributes = {
|
||||||
@property
|
ATTR_ATTRIBUTION: ATTRIBUTION,
|
||||||
def icon(self):
|
ATTR_DEVICE_ID: data.device_id,
|
||||||
"""Return icon."""
|
}
|
||||||
return ICON
|
|
||||||
|
|
||||||
async def async_added_to_hass(self):
|
async def async_added_to_hass(self):
|
||||||
"""Register callbacks."""
|
"""Register callbacks."""
|
||||||
@ -95,28 +98,15 @@ class ArloBaseStation(AlarmControlPanelEntity):
|
|||||||
"""Call update method."""
|
"""Call update method."""
|
||||||
self.async_schedule_update_ha_state(True)
|
self.async_schedule_update_ha_state(True)
|
||||||
|
|
||||||
@property
|
|
||||||
def state(self):
|
|
||||||
"""Return the state of the device."""
|
|
||||||
return self._state
|
|
||||||
|
|
||||||
@property
|
|
||||||
def supported_features(self) -> int:
|
|
||||||
"""Return the list of supported features."""
|
|
||||||
return SUPPORT_ALARM_ARM_HOME | SUPPORT_ALARM_ARM_AWAY | SUPPORT_ALARM_ARM_NIGHT
|
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""Update the state of the device."""
|
"""Update the state of the device."""
|
||||||
_LOGGER.debug("Updating Arlo Alarm Control Panel %s", self.name)
|
_LOGGER.debug("Updating Arlo Alarm Control Panel %s", self.name)
|
||||||
mode = self._base_station.mode
|
mode = self._base_station.mode
|
||||||
if mode:
|
self._attr_state = self._get_state_from_mode(mode) if mode else None
|
||||||
self._state = self._get_state_from_mode(mode)
|
|
||||||
else:
|
|
||||||
self._state = None
|
|
||||||
|
|
||||||
def alarm_disarm(self, code=None):
|
def alarm_disarm(self, code=None):
|
||||||
"""Send disarm command."""
|
"""Send disarm command."""
|
||||||
self._base_station.mode = DISARMED
|
self._base_station.mode = STATE_ALARM_DISARMED
|
||||||
|
|
||||||
def alarm_arm_away(self, code=None):
|
def alarm_arm_away(self, code=None):
|
||||||
"""Send arm away command. Uses custom mode."""
|
"""Send arm away command. Uses custom mode."""
|
||||||
@ -130,24 +120,11 @@ class ArloBaseStation(AlarmControlPanelEntity):
|
|||||||
"""Send arm night command. Uses custom mode."""
|
"""Send arm night command. Uses custom mode."""
|
||||||
self._base_station.mode = self._night_mode_name
|
self._base_station.mode = self._night_mode_name
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self):
|
|
||||||
"""Return the name of the base station."""
|
|
||||||
return self._base_station.name
|
|
||||||
|
|
||||||
@property
|
|
||||||
def extra_state_attributes(self):
|
|
||||||
"""Return the state attributes."""
|
|
||||||
return {
|
|
||||||
ATTR_ATTRIBUTION: ATTRIBUTION,
|
|
||||||
"device_id": self._base_station.device_id,
|
|
||||||
}
|
|
||||||
|
|
||||||
def _get_state_from_mode(self, mode):
|
def _get_state_from_mode(self, mode):
|
||||||
"""Convert Arlo mode to Home Assistant state."""
|
"""Convert Arlo mode to Home Assistant state."""
|
||||||
if mode == ARMED:
|
if mode == ARMED:
|
||||||
return STATE_ALARM_ARMED_AWAY
|
return STATE_ALARM_ARMED_AWAY
|
||||||
if mode == DISARMED:
|
if mode == STATE_ALARM_DISARMED:
|
||||||
return STATE_ALARM_DISARMED
|
return STATE_ALARM_DISARMED
|
||||||
if mode == self._home_mode_name:
|
if mode == self._home_mode_name:
|
||||||
return STATE_ALARM_ARMED_HOME
|
return STATE_ALARM_ARMED_HOME
|
||||||
|
@ -55,7 +55,7 @@ class ArloCam(Camera):
|
|||||||
"""Initialize an Arlo camera."""
|
"""Initialize an Arlo camera."""
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self._camera = camera
|
self._camera = camera
|
||||||
self._name = self._camera.name
|
self._attr_name = camera.name
|
||||||
self._motion_status = False
|
self._motion_status = False
|
||||||
self._ffmpeg = hass.data[DATA_FFMPEG]
|
self._ffmpeg = hass.data[DATA_FFMPEG]
|
||||||
self._ffmpeg_arguments = device_info.get(CONF_FFMPEG_ARGUMENTS)
|
self._ffmpeg_arguments = device_info.get(CONF_FFMPEG_ARGUMENTS)
|
||||||
@ -102,11 +102,6 @@ class ArloCam(Camera):
|
|||||||
finally:
|
finally:
|
||||||
await stream.close()
|
await stream.close()
|
||||||
|
|
||||||
@property
|
|
||||||
def name(self):
|
|
||||||
"""Return the name of this camera."""
|
|
||||||
return self._name
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def extra_state_attributes(self):
|
def extra_state_attributes(self):
|
||||||
"""Return the state attributes."""
|
"""Return the state attributes."""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user