* Add remote platform to hue integration supporting ZGPSwitch, ZLLSwitch and ZLLRotary switches. * Ported from custom component Hue-remotes-HASS from @robmarkcole * Add options flow for hue, to toggle handling of sensors and remotes * Sensors are enabled by default, and remotes are disabled, to not generate any breaking change for existent users. Also, when linking a new bridge these defaults are used, so unless going explicitly to the Options menu, the old behavior is preserved. * SensorManager stores the enabled platforms and ignores everything else. * Bridge is created with flags for `add_sensors` and `add_remotes`, and uses them to forward entry setup to only the enabled platforms. * Update listener removes disabled kinds of devices when options are changed, so device list is in sync with options, and disabled kinds disappear from HA, leaving the enable/disable entity option for individual devices. * Fix hue bridge mock with new parameters * Revert changes in hue bridge mock * Remove OptionsFlow and platform flags * Extract `GenericHueDevice` from `GenericHueSensor` to use it as base class for all hue devices, including those without any entity, like remotes without battery. * Add `HueBattery` sensor for battery powered remotes and generate entities for TYPE_ZLL_ROTARY and TYPE_ZLL_SWITCH remotes. * Remove remote platform * Add HueEvent class to fire events for button presses * Use `sensor.lastupdated` string to control state changes * Event data includes: - "id", as pretty name of the remote - "unique_id" of the remote device - "event", with the raw code of the pressed button ('buttonevent' or 'rotaryevent' property) - "last_updated", with the bridge timestamp for the button press * Register ZGP_SWITCH, ZLL_SWITCH, ZLL_ROTARY remotes * fix removal * Exclude W0611 * Extract GenericHueDevice to its own module and solve import tree, also fixing lint in CI * Store registered events to do not repeat device reg * Minor cleaning * Add tests for hue_event and battery entities for hue remotes
53 lines
1.7 KiB
Python
53 lines
1.7 KiB
Python
"""Support for the Philips Hue sensor devices."""
|
|
from .const import DOMAIN as HUE_DOMAIN
|
|
|
|
|
|
class GenericHueDevice:
|
|
"""Representation of a Hue device."""
|
|
|
|
def __init__(self, sensor, name, bridge, primary_sensor=None):
|
|
"""Initialize the sensor."""
|
|
self.sensor = sensor
|
|
self._name = name
|
|
self._primary_sensor = primary_sensor
|
|
self.bridge = bridge
|
|
|
|
@property
|
|
def primary_sensor(self):
|
|
"""Return the primary sensor entity of the physical device."""
|
|
return self._primary_sensor or self.sensor
|
|
|
|
@property
|
|
def device_id(self):
|
|
"""Return the ID of the physical device this sensor is part of."""
|
|
return self.unique_id[:23]
|
|
|
|
@property
|
|
def unique_id(self):
|
|
"""Return the ID of this Hue sensor."""
|
|
return self.sensor.uniqueid
|
|
|
|
@property
|
|
def name(self):
|
|
"""Return a friendly name for the sensor."""
|
|
return self._name
|
|
|
|
@property
|
|
def swupdatestate(self):
|
|
"""Return detail of available software updates for this device."""
|
|
return self.primary_sensor.raw.get("swupdate", {}).get("state")
|
|
|
|
@property
|
|
def device_info(self):
|
|
"""Return the device info.
|
|
|
|
Links individual entities together in the hass device registry.
|
|
"""
|
|
return {
|
|
"identifiers": {(HUE_DOMAIN, self.device_id)},
|
|
"name": self.primary_sensor.name,
|
|
"manufacturer": self.primary_sensor.manufacturername,
|
|
"model": (self.primary_sensor.productname or self.primary_sensor.modelid),
|
|
"sw_version": self.primary_sensor.swversion,
|
|
"via_device": (HUE_DOMAIN, self.bridge.api.config.bridgeid),
|
|
}
|