core/homeassistant/components/dexcom/__init__.py

75 lines
2.4 KiB
Python
Raw Normal View History

2020-07-02 00:14:54 +00:00
"""The Dexcom integration."""
2020-07-02 00:14:54 +00:00
from datetime import timedelta
import logging
from pydexcom import AccountError, Dexcom, GlucoseReading, SessionError
2020-07-02 00:14:54 +00:00
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import CONF_PASSWORD, CONF_UNIT_OF_MEASUREMENT, CONF_USERNAME
from homeassistant.core import HomeAssistant
from homeassistant.exceptions import ConfigEntryNotReady
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator, UpdateFailed
2024-03-05 20:36:11 +00:00
from .const import CONF_SERVER, DOMAIN, MG_DL, PLATFORMS, SERVER_OUS
2020-07-02 00:14:54 +00:00
_LOGGER = logging.getLogger(__name__)
SCAN_INTERVAL = timedelta(seconds=180)
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
2020-07-02 00:14:54 +00:00
"""Set up Dexcom from a config entry."""
try:
dexcom = await hass.async_add_executor_job(
Dexcom,
entry.data[CONF_USERNAME],
entry.data[CONF_PASSWORD],
entry.data[CONF_SERVER] == SERVER_OUS,
)
except AccountError:
return False
except SessionError as error:
raise ConfigEntryNotReady from error
2020-07-02 00:14:54 +00:00
if not entry.options:
hass.config_entries.async_update_entry(
entry, options={CONF_UNIT_OF_MEASUREMENT: MG_DL}
)
async def async_update_data():
try:
return await hass.async_add_executor_job(dexcom.get_current_glucose_reading)
except SessionError as error:
raise UpdateFailed(error) from error
2020-07-02 00:14:54 +00:00
coordinator = DataUpdateCoordinator[GlucoseReading](
hass,
_LOGGER,
config_entry=entry,
name=DOMAIN,
update_method=async_update_data,
update_interval=SCAN_INTERVAL,
)
await coordinator.async_config_entry_first_refresh()
2024-03-05 20:36:11 +00:00
hass.data.setdefault(DOMAIN, {})[entry.entry_id] = coordinator
entry.async_on_unload(entry.add_update_listener(update_listener))
2020-07-02 00:14:54 +00:00
await hass.config_entries.async_forward_entry_setups(entry, PLATFORMS)
2020-07-02 00:14:54 +00:00
return True
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
2020-07-02 00:14:54 +00:00
"""Unload a config entry."""
2024-03-05 20:36:11 +00:00
if unload_ok := await hass.config_entries.async_unload_platforms(entry, PLATFORMS):
2020-07-02 00:14:54 +00:00
hass.data[DOMAIN].pop(entry.entry_id)
return unload_ok
async def update_listener(hass: HomeAssistant, entry: ConfigEntry) -> None:
2020-07-02 00:14:54 +00:00
"""Handle options update."""
await hass.config_entries.async_reload(entry.entry_id)