Home Assistant Unofficial Reference 2024.12.1
__init__.py
Go to the documentation of this file.
1 """The emoncms component."""
2 
3 from pyemoncms import EmoncmsClient
4 
5 from homeassistant.config_entries import ConfigEntry
6 from homeassistant.const import CONF_API_KEY, CONF_URL, Platform
7 from homeassistant.core import HomeAssistant
8 from homeassistant.helpers import entity_registry as er
9 from homeassistant.helpers.aiohttp_client import async_get_clientsession
10 from homeassistant.helpers.issue_registry import IssueSeverity, async_create_issue
11 
12 from .const import DOMAIN, EMONCMS_UUID_DOC_URL, LOGGER
13 from .coordinator import EmoncmsCoordinator
14 
15 PLATFORMS: list[Platform] = [Platform.SENSOR]
16 
17 type EmonCMSConfigEntry = ConfigEntry[EmoncmsCoordinator]
18 
19 
21  hass: HomeAssistant, entry: EmonCMSConfigEntry, emoncms_unique_id: str
22 ) -> None:
23  """Migrate to emoncms unique id if needed."""
24  ent_reg = er.async_get(hass)
25  entry_entities = ent_reg.entities.get_entries_for_config_entry_id(entry.entry_id)
26  for entity in entry_entities:
27  if entity.unique_id.split("-")[0] == entry.entry_id:
28  feed_id = entity.unique_id.split("-")[-1]
29  LOGGER.debug(f"moving feed {feed_id} to hardware uuid")
30  ent_reg.async_update_entity(
31  entity.entity_id, new_unique_id=f"{emoncms_unique_id}-{feed_id}"
32  )
33  hass.config_entries.async_update_entry(
34  entry,
35  unique_id=emoncms_unique_id,
36  )
37 
38 
40  hass: HomeAssistant, entry: EmonCMSConfigEntry, emoncms_client: EmoncmsClient
41 ) -> None:
42  """Check if we can migrate to the emoncms uuid."""
43  emoncms_unique_id = await emoncms_client.async_get_uuid()
44  if emoncms_unique_id:
45  if entry.unique_id != emoncms_unique_id:
46  _migrate_unique_id(hass, entry, emoncms_unique_id)
47  else:
49  hass,
50  DOMAIN,
51  "migrate database",
52  is_fixable=False,
53  issue_domain=DOMAIN,
54  severity=IssueSeverity.WARNING,
55  translation_key="migrate_database",
56  translation_placeholders={
57  "url": entry.data[CONF_URL],
58  "doc_url": EMONCMS_UUID_DOC_URL,
59  },
60  )
61 
62 
63 async def async_setup_entry(hass: HomeAssistant, entry: EmonCMSConfigEntry) -> bool:
64  """Load a config entry."""
65  emoncms_client = EmoncmsClient(
66  entry.data[CONF_URL],
67  entry.data[CONF_API_KEY],
68  session=async_get_clientsession(hass),
69  )
70  await _check_unique_id_migration(hass, entry, emoncms_client)
71  coordinator = EmoncmsCoordinator(hass, emoncms_client)
72  await coordinator.async_config_entry_first_refresh()
73  entry.runtime_data = coordinator
74 
75  entry.async_on_unload(entry.add_update_listener(update_listener))
76  await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
77  return True
78 
79 
80 async def update_listener(hass: HomeAssistant, entry: ConfigEntry):
81  """Handle options update."""
82  await hass.config_entries.async_reload(entry.entry_id)
83 
84 
85 async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
86  """Unload a config entry."""
87  return await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
bool async_unload_entry(HomeAssistant hass, ConfigEntry entry)
Definition: __init__.py:85
None _check_unique_id_migration(HomeAssistant hass, EmonCMSConfigEntry entry, EmoncmsClient emoncms_client)
Definition: __init__.py:41
def update_listener(HomeAssistant hass, ConfigEntry entry)
Definition: __init__.py:80
None _migrate_unique_id(HomeAssistant hass, EmonCMSConfigEntry entry, str emoncms_unique_id)
Definition: __init__.py:22
bool async_setup_entry(HomeAssistant hass, EmonCMSConfigEntry entry)
Definition: __init__.py:63
None async_create_issue(HomeAssistant hass, str entry_id)
Definition: repairs.py:69
aiohttp.ClientSession async_get_clientsession(HomeAssistant hass, bool verify_ssl=True, socket.AddressFamily family=socket.AF_UNSPEC, ssl_util.SSLCipherList ssl_cipher=ssl_util.SSLCipherList.PYTHON_DEFAULT)