mirror of https://github.com/home-assistant/core
76 lines
2.4 KiB
Python
76 lines
2.4 KiB
Python
"""Diagnostics support for AndroidTV."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from typing import Any
|
|
|
|
import attr
|
|
|
|
from homeassistant.components.diagnostics import async_redact_data
|
|
from homeassistant.const import ATTR_CONNECTIONS, ATTR_IDENTIFIERS, CONF_UNIQUE_ID
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
|
|
|
from . import AndroidTVConfigEntry
|
|
from .const import DOMAIN, PROP_ETHMAC, PROP_SERIALNO, PROP_WIFIMAC
|
|
|
|
TO_REDACT = {CONF_UNIQUE_ID} # UniqueID contain MAC Address
|
|
TO_REDACT_DEV = {ATTR_CONNECTIONS, ATTR_IDENTIFIERS}
|
|
TO_REDACT_DEV_PROP = {PROP_ETHMAC, PROP_SERIALNO, PROP_WIFIMAC}
|
|
|
|
|
|
async def async_get_config_entry_diagnostics(
|
|
hass: HomeAssistant, entry: AndroidTVConfigEntry
|
|
) -> dict[str, dict[str, Any]]:
|
|
"""Return diagnostics for a config entry."""
|
|
data = {"entry": async_redact_data(entry.as_dict(), TO_REDACT)}
|
|
|
|
# Get information from AndroidTV library
|
|
aftv = entry.runtime_data.aftv
|
|
data["device_properties"] = {
|
|
**async_redact_data(aftv.device_properties, TO_REDACT_DEV_PROP),
|
|
"device_class": aftv.DEVICE_CLASS,
|
|
}
|
|
|
|
# Gather information how this AndroidTV device is represented in Home Assistant
|
|
device_registry = dr.async_get(hass)
|
|
entity_registry = er.async_get(hass)
|
|
hass_device = device_registry.async_get_device(
|
|
identifiers={(DOMAIN, str(entry.unique_id))}
|
|
)
|
|
if not hass_device:
|
|
return data
|
|
|
|
data["device"] = {
|
|
**async_redact_data(attr.asdict(hass_device), TO_REDACT_DEV),
|
|
"entities": {},
|
|
}
|
|
|
|
hass_entities = er.async_entries_for_device(
|
|
entity_registry,
|
|
device_id=hass_device.id,
|
|
include_disabled_entities=True,
|
|
)
|
|
|
|
for entity_entry in hass_entities:
|
|
state = hass.states.get(entity_entry.entity_id)
|
|
state_dict = None
|
|
if state:
|
|
state_dict = dict(state.as_dict())
|
|
# The entity_id is already provided at root level.
|
|
state_dict.pop("entity_id", None)
|
|
# The context doesn't provide useful information in this case.
|
|
state_dict.pop("context", None)
|
|
|
|
data["device"]["entities"][entity_entry.entity_id] = {
|
|
**async_redact_data(
|
|
attr.asdict(
|
|
entity_entry, filter=lambda attr, value: attr.name != "entity_id"
|
|
),
|
|
TO_REDACT,
|
|
),
|
|
"state": state_dict,
|
|
}
|
|
|
|
return data
|