Add additional data to HomeKit diagnostics (#80980)

This commit is contained in:
J. Nick Koston 2022-10-26 03:05:33 -05:00 committed by GitHub
parent 7dd1f58d04
commit a90ef3a575
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 182 additions and 2 deletions

View file

@ -6,12 +6,16 @@ from typing import Any
from pyhap.accessory_driver import AccessoryDriver
from pyhap.state import State
from homeassistant.components.diagnostics import async_redact_data
from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant
from . import HomeKit
from .accessories import HomeAccessory, HomeBridge
from .const import DOMAIN, HOMEKIT
TO_REDACT = {"access_token", "entity_picture"}
async def async_get_config_entry_diagnostics(
hass: HomeAssistant, entry: ConfigEntry
@ -30,6 +34,11 @@ async def async_get_config_entry_diagnostics(
if not homekit.driver: # not started yet or startup failed
return data
driver: AccessoryDriver = homekit.driver
if driver.accessory:
if isinstance(driver.accessory, HomeBridge):
data["bridge"] = _get_bridge_diagnostics(hass, driver.accessory)
else:
data["accessory"] = _get_accessory_diagnostics(hass, driver.accessory)
data.update(driver.get_accessories())
state: State = driver.state
data.update(
@ -42,3 +51,27 @@ async def async_get_config_entry_diagnostics(
}
)
return data
def _get_bridge_diagnostics(hass: HomeAssistant, bridge: HomeBridge) -> dict[int, Any]:
"""Return diagnostics for a bridge."""
return {
aid: _get_accessory_diagnostics(hass, accessory)
for aid, accessory in bridge.accessories.items()
}
def _get_accessory_diagnostics(
hass: HomeAssistant, accessory: HomeAccessory
) -> dict[str, Any]:
"""Return diagnostics for an accessory."""
return {
"aid": accessory.aid,
"config": accessory.config,
"category": accessory.category,
"name": accessory.display_name,
"entity_id": accessory.entity_id,
"entity_state": async_redact_data(
hass.states.get(accessory.entity_id), TO_REDACT
),
}