2022-03-21 10:02:48 +00:00
|
|
|
"""Demo platform that offers fake update entities."""
|
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
import asyncio
|
|
|
|
from typing import Any
|
|
|
|
|
|
|
|
from homeassistant.components.update import UpdateDeviceClass, UpdateEntity
|
|
|
|
from homeassistant.components.update.const import UpdateEntityFeature
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
|
|
|
from homeassistant.const import DEVICE_DEFAULT_NAME
|
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from homeassistant.helpers.entity import DeviceInfo
|
|
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|
|
|
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
|
|
|
|
|
|
|
|
from . import DOMAIN
|
|
|
|
|
|
|
|
FAKE_INSTALL_SLEEP_TIME = 0.5
|
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_platform(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
config: ConfigType,
|
|
|
|
async_add_entities: AddEntitiesCallback,
|
|
|
|
discovery_info: DiscoveryInfoType | None = None,
|
|
|
|
) -> None:
|
|
|
|
"""Set up demo update entities."""
|
|
|
|
async_add_entities(
|
|
|
|
[
|
|
|
|
DemoUpdate(
|
|
|
|
unique_id="update_no_install",
|
|
|
|
name="Demo Update No Install",
|
|
|
|
title="Awesomesoft Inc.",
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version="1.0.0",
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version="1.0.1",
|
|
|
|
release_summary="Awesome update, fixing everything!",
|
|
|
|
release_url="https://www.example.com/release/1.0.1",
|
|
|
|
support_install=False,
|
|
|
|
),
|
|
|
|
DemoUpdate(
|
|
|
|
unique_id="update_2_date",
|
|
|
|
name="Demo No Update",
|
|
|
|
title="AdGuard Home",
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version="1.0.0",
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version="1.0.0",
|
|
|
|
),
|
|
|
|
DemoUpdate(
|
|
|
|
unique_id="update_addon",
|
|
|
|
name="Demo add-on",
|
|
|
|
title="AdGuard Home",
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version="1.0.0",
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version="1.0.1",
|
|
|
|
release_summary="Awesome update, fixing everything!",
|
|
|
|
release_url="https://www.example.com/release/1.0.1",
|
|
|
|
),
|
|
|
|
DemoUpdate(
|
|
|
|
unique_id="update_light_bulb",
|
|
|
|
name="Demo Living Room Bulb Update",
|
|
|
|
title="Philips Lamps Firmware",
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version="1.93.3",
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version="1.94.2",
|
|
|
|
release_summary="Added support for effects",
|
|
|
|
release_url="https://www.example.com/release/1.93.3",
|
|
|
|
device_class=UpdateDeviceClass.FIRMWARE,
|
|
|
|
),
|
|
|
|
DemoUpdate(
|
|
|
|
unique_id="update_support_progress",
|
|
|
|
name="Demo Update with Progress",
|
|
|
|
title="Philips Lamps Firmware",
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version="1.93.3",
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version="1.94.2",
|
|
|
|
support_progress=True,
|
|
|
|
release_summary="Added support for effects",
|
2022-03-30 00:38:56 +00:00
|
|
|
support_release_notes=True,
|
2022-03-21 10:02:48 +00:00
|
|
|
release_url="https://www.example.com/release/1.93.3",
|
|
|
|
device_class=UpdateDeviceClass.FIRMWARE,
|
|
|
|
),
|
|
|
|
]
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
config_entry: ConfigEntry,
|
|
|
|
async_add_entities: AddEntitiesCallback,
|
|
|
|
) -> None:
|
|
|
|
"""Set up the Demo config entry."""
|
|
|
|
await async_setup_platform(hass, {}, async_add_entities)
|
|
|
|
|
|
|
|
|
|
|
|
async def _fake_install() -> None:
|
|
|
|
"""Fake install an update."""
|
|
|
|
await asyncio.sleep(FAKE_INSTALL_SLEEP_TIME)
|
|
|
|
|
|
|
|
|
|
|
|
class DemoUpdate(UpdateEntity):
|
|
|
|
"""Representation of a demo update entity."""
|
|
|
|
|
|
|
|
_attr_should_poll = False
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
*,
|
|
|
|
unique_id: str,
|
|
|
|
name: str,
|
|
|
|
title: str | None,
|
2022-04-01 18:11:17 +00:00
|
|
|
installed_version: str | None,
|
2022-03-21 10:02:48 +00:00
|
|
|
latest_version: str | None,
|
|
|
|
release_summary: str | None = None,
|
|
|
|
release_url: str | None = None,
|
|
|
|
support_progress: bool = False,
|
|
|
|
support_install: bool = True,
|
2022-03-30 00:38:56 +00:00
|
|
|
support_release_notes: bool = False,
|
2022-03-21 10:02:48 +00:00
|
|
|
device_class: UpdateDeviceClass | None = None,
|
|
|
|
) -> None:
|
|
|
|
"""Initialize the Demo select entity."""
|
2022-04-01 18:11:17 +00:00
|
|
|
self._attr_installed_version = installed_version
|
2022-03-21 10:02:48 +00:00
|
|
|
self._attr_device_class = device_class
|
|
|
|
self._attr_latest_version = latest_version
|
|
|
|
self._attr_name = name or DEVICE_DEFAULT_NAME
|
|
|
|
self._attr_release_summary = release_summary
|
|
|
|
self._attr_release_url = release_url
|
|
|
|
self._attr_title = title
|
|
|
|
self._attr_unique_id = unique_id
|
|
|
|
self._attr_device_info = DeviceInfo(
|
|
|
|
identifiers={(DOMAIN, unique_id)},
|
|
|
|
name=name,
|
|
|
|
)
|
|
|
|
if support_install:
|
|
|
|
self._attr_supported_features |= (
|
|
|
|
UpdateEntityFeature.INSTALL
|
|
|
|
| UpdateEntityFeature.BACKUP
|
|
|
|
| UpdateEntityFeature.SPECIFIC_VERSION
|
|
|
|
)
|
|
|
|
if support_progress:
|
|
|
|
self._attr_supported_features |= UpdateEntityFeature.PROGRESS
|
|
|
|
|
2022-03-30 00:38:56 +00:00
|
|
|
if support_release_notes:
|
|
|
|
self._attr_supported_features |= UpdateEntityFeature.RELEASE_NOTES
|
|
|
|
|
2022-03-21 10:02:48 +00:00
|
|
|
async def async_install(
|
2022-03-23 10:20:04 +00:00
|
|
|
self, version: str | None, backup: bool, **kwargs: Any
|
2022-03-21 10:02:48 +00:00
|
|
|
) -> None:
|
|
|
|
"""Install an update."""
|
|
|
|
if self.supported_features & UpdateEntityFeature.PROGRESS:
|
|
|
|
for progress in range(0, 100, 10):
|
|
|
|
self._attr_in_progress = progress
|
|
|
|
self.async_write_ha_state()
|
|
|
|
await _fake_install()
|
|
|
|
|
|
|
|
self._attr_in_progress = False
|
2022-04-01 18:11:17 +00:00
|
|
|
self._attr_installed_version = (
|
2022-03-21 10:02:48 +00:00
|
|
|
version if version is not None else self.latest_version
|
|
|
|
)
|
|
|
|
self.async_write_ha_state()
|
2022-03-30 00:38:56 +00:00
|
|
|
|
|
|
|
def release_notes(self) -> str | None:
|
|
|
|
"""Return the release notes."""
|
|
|
|
return (
|
|
|
|
"Long release notes.\n\n**With** "
|
|
|
|
f"markdown support!\n\n***\n\n{self.release_summary}"
|
|
|
|
)
|