2020-10-27 14:20:01 +00:00
|
|
|
"""Library for extracting device specific information common to entities."""
|
|
|
|
|
2021-07-26 23:43:52 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2020-10-27 14:20:01 +00:00
|
|
|
from google_nest_sdm.device import Device
|
|
|
|
from google_nest_sdm.device_traits import InfoTrait
|
|
|
|
|
2021-07-26 23:43:52 +00:00
|
|
|
from homeassistant.helpers.entity import DeviceInfo
|
|
|
|
|
2020-10-27 14:20:01 +00:00
|
|
|
from .const import DOMAIN
|
|
|
|
|
2021-07-26 23:43:52 +00:00
|
|
|
DEVICE_TYPE_MAP: dict[str, str] = {
|
2020-10-27 14:20:01 +00:00
|
|
|
"sdm.devices.types.CAMERA": "Camera",
|
|
|
|
"sdm.devices.types.DISPLAY": "Display",
|
|
|
|
"sdm.devices.types.DOORBELL": "Doorbell",
|
|
|
|
"sdm.devices.types.THERMOSTAT": "Thermostat",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-07-26 23:43:52 +00:00
|
|
|
class NestDeviceInfo:
|
2020-10-27 14:20:01 +00:00
|
|
|
"""Provide device info from the SDM device, shared across platforms."""
|
|
|
|
|
|
|
|
device_brand = "Google Nest"
|
|
|
|
|
2021-05-20 12:06:44 +00:00
|
|
|
def __init__(self, device: Device) -> None:
|
2020-10-27 14:20:01 +00:00
|
|
|
"""Initialize the DeviceInfo."""
|
|
|
|
self._device = device
|
|
|
|
|
|
|
|
@property
|
2021-07-26 23:43:52 +00:00
|
|
|
def device_info(self) -> DeviceInfo:
|
2020-10-27 14:20:01 +00:00
|
|
|
"""Return device specific attributes."""
|
2021-07-26 23:43:52 +00:00
|
|
|
return DeviceInfo(
|
|
|
|
{
|
|
|
|
# The API "name" field is a unique device identifier.
|
|
|
|
"identifiers": {(DOMAIN, self._device.name)},
|
|
|
|
"name": self.device_name,
|
|
|
|
"manufacturer": self.device_brand,
|
|
|
|
"model": self.device_model,
|
|
|
|
}
|
|
|
|
)
|
2020-10-27 14:20:01 +00:00
|
|
|
|
|
|
|
@property
|
2021-08-09 02:24:36 +00:00
|
|
|
def device_name(self) -> str | None:
|
2020-10-27 14:20:01 +00:00
|
|
|
"""Return the name of the physical device that includes the sensor."""
|
|
|
|
if InfoTrait.NAME in self._device.traits:
|
2021-07-26 23:43:52 +00:00
|
|
|
trait: InfoTrait = self._device.traits[InfoTrait.NAME]
|
2020-10-27 14:20:01 +00:00
|
|
|
if trait.custom_name:
|
|
|
|
return trait.custom_name
|
|
|
|
# Build a name from the room/structure. Note: This room/structure name
|
|
|
|
# is not associated with a home assistant Area.
|
|
|
|
parent_relations = self._device.parent_relations
|
|
|
|
if parent_relations:
|
|
|
|
items = sorted(parent_relations.items())
|
|
|
|
names = [name for id, name in items]
|
|
|
|
return " ".join(names)
|
|
|
|
return self.device_model
|
|
|
|
|
|
|
|
@property
|
2021-08-09 02:24:36 +00:00
|
|
|
def device_model(self) -> str | None:
|
2020-10-27 14:20:01 +00:00
|
|
|
"""Return device model information."""
|
|
|
|
# The API intentionally returns minimal information about specific
|
|
|
|
# devices, instead relying on traits, but we can infer a generic model
|
|
|
|
# name based on the type
|
2021-08-09 02:24:36 +00:00
|
|
|
return DEVICE_TYPE_MAP.get(self._device.type)
|