Home Assistant Unofficial Reference 2024.12.1
sensor.py
Go to the documentation of this file.
1 """A sensor for incoming calls using a USB modem that supports caller ID."""
2 
3 from __future__ import annotations
4 
5 from phone_modem import PhoneModem
6 
7 from homeassistant.components.sensor import SensorEntity
8 from homeassistant.config_entries import ConfigEntry
9 from homeassistant.const import EVENT_HOMEASSISTANT_STOP, STATE_IDLE
10 from homeassistant.core import Event, HomeAssistant, callback
11 from homeassistant.helpers.device_registry import DeviceInfo
12 from homeassistant.helpers.entity_platform import AddEntitiesCallback
13 
14 from .const import CID, DATA_KEY_API, DOMAIN
15 
16 
18  hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
19 ) -> None:
20  """Set up the Modem Caller ID sensor."""
21  api = hass.data[DOMAIN][entry.entry_id][DATA_KEY_API]
23  [
25  api,
26  entry.entry_id,
27  )
28  ]
29  )
30 
31  async def _async_on_hass_stop(event: Event) -> None:
32  """HA is shutting down, close modem port."""
33  if hass.data[DOMAIN][entry.entry_id][DATA_KEY_API]:
34  await hass.data[DOMAIN][entry.entry_id][DATA_KEY_API].close()
35 
36  entry.async_on_unload(
37  hass.bus.async_listen_once(EVENT_HOMEASSISTANT_STOP, _async_on_hass_stop)
38  )
39 
40 
42  """Implementation of USB modem caller ID sensor."""
43 
44  _attr_should_poll = False
45  _attr_has_entity_name = True
46  _attr_name = None
47  _attr_translation_key = "incoming_call"
48 
49  def __init__(self, api: PhoneModem, server_unique_id: str) -> None:
50  """Initialize the sensor."""
51  self.apiapi = api
52  self._attr_unique_id_attr_unique_id = server_unique_id
53  self._attr_native_value_attr_native_value = STATE_IDLE
54  self._attr_extra_state_attributes_attr_extra_state_attributes = {
55  CID.CID_TIME: 0,
56  CID.CID_NUMBER: "",
57  CID.CID_NAME: "",
58  }
59  self._attr_device_info_attr_device_info = DeviceInfo(identifiers={(DOMAIN, server_unique_id)})
60 
61  async def async_added_to_hass(self) -> None:
62  """Call when the modem sensor is added to Home Assistant."""
63  self.apiapi.registercallback(self._async_incoming_call_async_incoming_call)
64  await super().async_added_to_hass()
65 
66  @callback
67  def _async_incoming_call(self, new_state: str) -> None:
68  """Handle new states."""
69  self._attr_extra_state_attributes_attr_extra_state_attributes = {}
70  if self.apiapi.cid_name:
71  self._attr_extra_state_attributes_attr_extra_state_attributes[CID.CID_NAME] = self.apiapi.cid_name
72  if self.apiapi.cid_number:
73  self._attr_extra_state_attributes_attr_extra_state_attributes[CID.CID_NUMBER] = self.apiapi.cid_number
74  if self.apiapi.cid_time:
75  self._attr_extra_state_attributes_attr_extra_state_attributes[CID.CID_TIME] = self.apiapi.cid_time
76  self._attr_native_value_attr_native_value = self.apiapi.state
77  self.async_write_ha_stateasync_write_ha_state()
None __init__(self, PhoneModem api, str server_unique_id)
Definition: sensor.py:49
None async_setup_entry(HomeAssistant hass, ConfigEntry entry, AddEntitiesCallback async_add_entities)
Definition: sensor.py:19