mirror of
https://github.com/home-assistant/core.git
synced 2025-07-24 21:57:51 +00:00
Add unique_id to Xiaomi Aqara (#12372)
* Add unique_id to Xiaomi Aqara * Slugify the unique ID * Use the domain instead of a separate string * Add underscore * Remove unique ID from attributes * Re-add removed attributes * Remove domain from the unique ID * Use type or data key * Also make sure that the data key is not None * Yes, it does have that member, if that check passes. Thanks pylint.
This commit is contained in:
parent
4d7fb2c7de
commit
2a4971dec7
@ -21,6 +21,7 @@ import homeassistant.helpers.config_validation as cv
|
|||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
from homeassistant.helpers.event import async_track_point_in_utc_time
|
from homeassistant.helpers.event import async_track_point_in_utc_time
|
||||||
from homeassistant.util.dt import utcnow
|
from homeassistant.util.dt import utcnow
|
||||||
|
from homeassistant.util import slugify
|
||||||
|
|
||||||
REQUIREMENTS = ['PyXiaomiGateway==0.8.1']
|
REQUIREMENTS = ['PyXiaomiGateway==0.8.1']
|
||||||
|
|
||||||
@ -203,12 +204,13 @@ def setup(hass, config):
|
|||||||
class XiaomiDevice(Entity):
|
class XiaomiDevice(Entity):
|
||||||
"""Representation a base Xiaomi device."""
|
"""Representation a base Xiaomi device."""
|
||||||
|
|
||||||
def __init__(self, device, name, xiaomi_hub):
|
def __init__(self, device, device_type, xiaomi_hub):
|
||||||
"""Initialize the Xiaomi device."""
|
"""Initialize the Xiaomi device."""
|
||||||
self._state = None
|
self._state = None
|
||||||
self._is_available = True
|
self._is_available = True
|
||||||
self._sid = device['sid']
|
self._sid = device['sid']
|
||||||
self._name = '{}_{}'.format(name, self._sid)
|
self._name = '{}_{}'.format(device_type, self._sid)
|
||||||
|
self._type = device_type
|
||||||
self._write_to_hub = xiaomi_hub.write_to_hub
|
self._write_to_hub = xiaomi_hub.write_to_hub
|
||||||
self._get_from_hub = xiaomi_hub.get_from_hub
|
self._get_from_hub = xiaomi_hub.get_from_hub
|
||||||
self._device_state_attributes = {}
|
self._device_state_attributes = {}
|
||||||
@ -217,6 +219,14 @@ class XiaomiDevice(Entity):
|
|||||||
self.parse_data(device['data'], device['raw_data'])
|
self.parse_data(device['data'], device['raw_data'])
|
||||||
self.parse_voltage(device['data'])
|
self.parse_voltage(device['data'])
|
||||||
|
|
||||||
|
if hasattr(self, '_data_key') \
|
||||||
|
and self._data_key: # pylint: disable=no-member
|
||||||
|
self._unique_id = slugify("{}-{}".format(
|
||||||
|
self._data_key, # pylint: disable=no-member
|
||||||
|
self._sid))
|
||||||
|
else:
|
||||||
|
self._unique_id = slugify("{}-{}".format(self._type, self._sid))
|
||||||
|
|
||||||
def _add_push_data_job(self, *args):
|
def _add_push_data_job(self, *args):
|
||||||
self.hass.add_job(self.push_data, *args)
|
self.hass.add_job(self.push_data, *args)
|
||||||
|
|
||||||
@ -230,6 +240,11 @@ class XiaomiDevice(Entity):
|
|||||||
"""Return the name of the device."""
|
"""Return the name of the device."""
|
||||||
return self._name
|
return self._name
|
||||||
|
|
||||||
|
@property
|
||||||
|
def unique_id(self) -> str:
|
||||||
|
"""Return an unique ID."""
|
||||||
|
return self._unique_id
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def available(self):
|
def available(self):
|
||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user