Home Assistant Unofficial Reference 2024.12.1
update.py
Go to the documentation of this file.
1 """Support for update entities of a Pi-hole system."""
2 
3 from __future__ import annotations
4 
5 from collections.abc import Callable
6 from dataclasses import dataclass
7 
8 from hole import Hole
9 
10 from homeassistant.components.update import UpdateEntity, UpdateEntityDescription
11 from homeassistant.const import CONF_NAME, EntityCategory
12 from homeassistant.core import HomeAssistant
13 from homeassistant.helpers.entity_platform import AddEntitiesCallback
14 from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
15 
16 from . import PiHoleConfigEntry
17 from .entity import PiHoleEntity
18 
19 
20 @dataclass(frozen=True)
22  """Describes PiHole update entity."""
23 
24  installed_version: Callable[[dict], str | None] = lambda api: None
25  latest_version: Callable[[dict], str | None] = lambda api: None
26  has_update: Callable[[dict], bool | None] = lambda api: None
27  release_base_url: str | None = None
28  title: str | None = None
29 
30 
31 UPDATE_ENTITY_TYPES: tuple[PiHoleUpdateEntityDescription, ...] = (
33  key="core_update_available",
34  translation_key="core_update_available",
35  title="Pi-hole Core",
36  entity_category=EntityCategory.DIAGNOSTIC,
37  installed_version=lambda versions: versions.get("core_current"),
38  latest_version=lambda versions: versions.get("core_latest"),
39  has_update=lambda versions: versions.get("core_update"),
40  release_base_url="https://github.com/pi-hole/pi-hole/releases/tag",
41  ),
43  key="web_update_available",
44  translation_key="web_update_available",
45  title="Pi-hole Web interface",
46  entity_category=EntityCategory.DIAGNOSTIC,
47  installed_version=lambda versions: versions.get("web_current"),
48  latest_version=lambda versions: versions.get("web_latest"),
49  has_update=lambda versions: versions.get("web_update"),
50  release_base_url="https://github.com/pi-hole/AdminLTE/releases/tag",
51  ),
53  key="ftl_update_available",
54  translation_key="ftl_update_available",
55  title="Pi-hole FTL DNS",
56  entity_category=EntityCategory.DIAGNOSTIC,
57  installed_version=lambda versions: versions.get("FTL_current"),
58  latest_version=lambda versions: versions.get("FTL_latest"),
59  has_update=lambda versions: versions.get("FTL_update"),
60  release_base_url="https://github.com/pi-hole/FTL/releases/tag",
61  ),
62 )
63 
64 
66  hass: HomeAssistant,
67  entry: PiHoleConfigEntry,
68  async_add_entities: AddEntitiesCallback,
69 ) -> None:
70  """Set up the Pi-hole update entities."""
71  name = entry.data[CONF_NAME]
72  hole_data = entry.runtime_data
73 
76  hole_data.api,
77  hole_data.coordinator,
78  name,
79  entry.entry_id,
80  description,
81  )
82  for description in UPDATE_ENTITY_TYPES
83  )
84 
85 
87  """Representation of a Pi-hole update entity."""
88 
89  entity_description: PiHoleUpdateEntityDescription
90  _attr_has_entity_name = True
91 
92  def __init__(
93  self,
94  api: Hole,
95  coordinator: DataUpdateCoordinator[None],
96  name: str,
97  server_unique_id: str,
98  description: PiHoleUpdateEntityDescription,
99  ) -> None:
100  """Initialize a Pi-hole update entity."""
101  super().__init__(api, coordinator, name, server_unique_id)
102  self.entity_descriptionentity_description = description
103 
104  self._attr_unique_id_attr_unique_id = f"{self._server_unique_id}/{description.key}"
105  self._attr_title_attr_title = description.title
106 
107  @property
108  def installed_version(self) -> str | None:
109  """Version installed and in use."""
110  if isinstance(self.apiapi.versions, dict):
111  return self.entity_descriptionentity_description.installed_version(self.apiapi.versions)
112  return None
113 
114  @property
115  def latest_version(self) -> str | None:
116  """Latest version available for install."""
117  if isinstance(self.apiapi.versions, dict):
118  if self.entity_descriptionentity_description.has_update(self.apiapi.versions):
119  return self.entity_descriptionentity_description.latest_version(self.apiapi.versions)
120  return self.installed_versioninstalled_versioninstalled_versioninstalled_version
121  return None
122 
123  @property
124  def release_url(self) -> str | None:
125  """URL to the full release notes of the latest version available."""
126  if self.latest_versionlatest_versionlatest_version:
127  return f"{self.entity_description.release_base_url}/{self.latest_version}"
128  return None
None __init__(self, Hole api, DataUpdateCoordinator[None] coordinator, str name, str server_unique_id, PiHoleUpdateEntityDescription description)
Definition: update.py:99
None async_setup_entry(HomeAssistant hass, PiHoleConfigEntry entry, AddEntitiesCallback async_add_entities)
Definition: update.py:69