mirror of
https://github.com/home-assistant/core.git
synced 2025-04-24 09:17:53 +00:00
Clean up freedompro (#52992)
This commit is contained in:
parent
82256b2588
commit
5ff9c3e611
@ -6,9 +6,7 @@ from homeassistant.components.binary_sensor import (
|
||||
DEVICE_CLASS_SMOKE,
|
||||
BinarySensorEntity,
|
||||
)
|
||||
from homeassistant.const import CONF_API_KEY
|
||||
from homeassistant.core import callback
|
||||
from homeassistant.helpers import aiohttp_client
|
||||
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
||||
|
||||
from .const import DOMAIN
|
||||
@ -32,10 +30,9 @@ SUPPORTED_SENSORS = {"smokeSensor", "occupancySensor", "motionSensor", "contactS
|
||||
|
||||
async def async_setup_entry(hass, entry, async_add_entities):
|
||||
"""Set up Freedompro binary_sensor."""
|
||||
api_key = entry.data[CONF_API_KEY]
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
async_add_entities(
|
||||
Device(hass, api_key, device, coordinator)
|
||||
Device(device, coordinator)
|
||||
for device in coordinator.data
|
||||
if device["type"] in SUPPORTED_SENSORS
|
||||
)
|
||||
@ -44,25 +41,21 @@ async def async_setup_entry(hass, entry, async_add_entities):
|
||||
class Device(CoordinatorEntity, BinarySensorEntity):
|
||||
"""Representation of an Freedompro binary_sensor."""
|
||||
|
||||
def __init__(self, hass, api_key, device, coordinator):
|
||||
def __init__(self, device, coordinator):
|
||||
"""Initialize the Freedompro binary_sensor."""
|
||||
super().__init__(coordinator)
|
||||
self._hass = hass
|
||||
self._session = aiohttp_client.async_get_clientsession(self._hass)
|
||||
self._api_key = api_key
|
||||
self._attr_name = device["name"]
|
||||
self._attr_unique_id = device["uid"]
|
||||
self._type = device["type"]
|
||||
self._characteristics = device["characteristics"]
|
||||
self._attr_device_info = {
|
||||
"name": self.name,
|
||||
"identifiers": {
|
||||
(DOMAIN, self.unique_id),
|
||||
},
|
||||
"model": self._type,
|
||||
"model": device["type"],
|
||||
"manufacturer": "Freedompro",
|
||||
}
|
||||
self._attr_device_class = DEVICE_CLASS_MAP[self._type]
|
||||
self._attr_device_class = DEVICE_CLASS_MAP[device["type"]]
|
||||
|
||||
@callback
|
||||
def _handle_coordinator_update(self) -> None:
|
||||
|
@ -36,27 +36,24 @@ class Device(CoordinatorEntity, LightEntity):
|
||||
def __init__(self, hass, api_key, device, coordinator):
|
||||
"""Initialize the Freedompro light."""
|
||||
super().__init__(coordinator)
|
||||
self._hass = hass
|
||||
self._session = aiohttp_client.async_get_clientsession(self._hass)
|
||||
self._session = aiohttp_client.async_get_clientsession(hass)
|
||||
self._api_key = api_key
|
||||
self._attr_name = device["name"]
|
||||
self._attr_unique_id = device["uid"]
|
||||
self._type = device["type"]
|
||||
self._characteristics = device["characteristics"]
|
||||
self._attr_device_info = {
|
||||
"name": self.name,
|
||||
"identifiers": {
|
||||
(DOMAIN, self.unique_id),
|
||||
},
|
||||
"model": self._type,
|
||||
"model": device["type"],
|
||||
"manufacturer": "Freedompro",
|
||||
}
|
||||
self._attr_is_on = False
|
||||
self._attr_brightness = 0
|
||||
color_mode = COLOR_MODE_ONOFF
|
||||
if "hue" in self._characteristics:
|
||||
if "hue" in device["characteristics"]:
|
||||
color_mode = COLOR_MODE_HS
|
||||
elif "brightness" in self._characteristics:
|
||||
elif "brightness" in device["characteristics"]:
|
||||
color_mode = COLOR_MODE_BRIGHTNESS
|
||||
self._attr_color_mode = color_mode
|
||||
self._attr_supported_color_modes = {color_mode}
|
||||
|
@ -6,9 +6,8 @@ from homeassistant.components.sensor import (
|
||||
STATE_CLASS_MEASUREMENT,
|
||||
SensorEntity,
|
||||
)
|
||||
from homeassistant.const import CONF_API_KEY, LIGHT_LUX, PERCENTAGE, TEMP_CELSIUS
|
||||
from homeassistant.const import LIGHT_LUX, PERCENTAGE, TEMP_CELSIUS
|
||||
from homeassistant.core import callback
|
||||
from homeassistant.helpers import aiohttp_client
|
||||
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
||||
|
||||
from .const import DOMAIN
|
||||
@ -38,10 +37,9 @@ SUPPORTED_SENSORS = {"temperatureSensor", "humiditySensor", "lightSensor"}
|
||||
|
||||
async def async_setup_entry(hass, entry, async_add_entities):
|
||||
"""Set up Freedompro sensor."""
|
||||
api_key = entry.data[CONF_API_KEY]
|
||||
coordinator = hass.data[DOMAIN][entry.entry_id]
|
||||
async_add_entities(
|
||||
Device(hass, api_key, device, coordinator)
|
||||
Device(device, coordinator)
|
||||
for device in coordinator.data
|
||||
if device["type"] in SUPPORTED_SENSORS
|
||||
)
|
||||
@ -50,27 +48,23 @@ async def async_setup_entry(hass, entry, async_add_entities):
|
||||
class Device(CoordinatorEntity, SensorEntity):
|
||||
"""Representation of an Freedompro sensor."""
|
||||
|
||||
def __init__(self, hass, api_key, device, coordinator):
|
||||
def __init__(self, device, coordinator):
|
||||
"""Initialize the Freedompro sensor."""
|
||||
super().__init__(coordinator)
|
||||
self._hass = hass
|
||||
self._session = aiohttp_client.async_get_clientsession(self._hass)
|
||||
self._api_key = api_key
|
||||
self._attr_name = device["name"]
|
||||
self._attr_unique_id = device["uid"]
|
||||
self._type = device["type"]
|
||||
self._characteristics = device["characteristics"]
|
||||
self._attr_device_info = {
|
||||
"name": self.name,
|
||||
"identifiers": {
|
||||
(DOMAIN, self.unique_id),
|
||||
},
|
||||
"model": self._type,
|
||||
"model": device["type"],
|
||||
"manufacturer": "Freedompro",
|
||||
}
|
||||
self._attr_device_class = DEVICE_CLASS_MAP[self._type]
|
||||
self._attr_state_class = STATE_CLASS_MAP[self._type]
|
||||
self._attr_unit_of_measurement = UNIT_MAP[self._type]
|
||||
self._attr_device_class = DEVICE_CLASS_MAP[device["type"]]
|
||||
self._attr_state_class = STATE_CLASS_MAP[device["type"]]
|
||||
self._attr_unit_of_measurement = UNIT_MAP[device["type"]]
|
||||
self._attr_state = 0
|
||||
|
||||
@callback
|
||||
|
@ -29,19 +29,16 @@ class Device(CoordinatorEntity, SwitchEntity):
|
||||
def __init__(self, hass, api_key, device, coordinator):
|
||||
"""Initialize the Freedompro switch."""
|
||||
super().__init__(coordinator)
|
||||
self._hass = hass
|
||||
self._session = aiohttp_client.async_get_clientsession(self._hass)
|
||||
self._session = aiohttp_client.async_get_clientsession(hass)
|
||||
self._api_key = api_key
|
||||
self._attr_name = device["name"]
|
||||
self._attr_unique_id = device["uid"]
|
||||
self._type = device["type"]
|
||||
self._characteristics = device["characteristics"]
|
||||
self._attr_device_info = {
|
||||
"name": self._attr_name,
|
||||
"name": self.name,
|
||||
"identifiers": {
|
||||
(DOMAIN, self._attr_unique_id),
|
||||
(DOMAIN, self.unique_id),
|
||||
},
|
||||
"model": self._type,
|
||||
"model": device["type"],
|
||||
"manufacturer": "Freedompro",
|
||||
}
|
||||
self._attr_is_on = False
|
||||
@ -53,7 +50,7 @@ class Device(CoordinatorEntity, SwitchEntity):
|
||||
(
|
||||
device
|
||||
for device in self.coordinator.data
|
||||
if device["uid"] == self._attr_unique_id
|
||||
if device["uid"] == self.unique_id
|
||||
),
|
||||
None,
|
||||
)
|
||||
@ -75,7 +72,7 @@ class Device(CoordinatorEntity, SwitchEntity):
|
||||
await put_state(
|
||||
self._session,
|
||||
self._api_key,
|
||||
self._attr_unique_id,
|
||||
self.unique_id,
|
||||
payload,
|
||||
)
|
||||
await self.coordinator.async_request_refresh()
|
||||
@ -87,7 +84,7 @@ class Device(CoordinatorEntity, SwitchEntity):
|
||||
await put_state(
|
||||
self._session,
|
||||
self._api_key,
|
||||
self._attr_unique_id,
|
||||
self.unique_id,
|
||||
payload,
|
||||
)
|
||||
await self.coordinator.async_request_refresh()
|
||||
|
Loading…
x
Reference in New Issue
Block a user