136 lines
4.3 KiB
Python
136 lines
4.3 KiB
Python
"""The Glances component."""
|
|
from datetime import timedelta
|
|
import logging
|
|
|
|
from glances_api import Glances, exceptions
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
|
from homeassistant.const import (
|
|
CONF_HOST,
|
|
CONF_NAME,
|
|
CONF_SCAN_INTERVAL,
|
|
CONF_VERIFY_SSL,
|
|
Platform,
|
|
)
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.exceptions import ConfigEntryNotReady
|
|
import homeassistant.helpers.config_validation as cv
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
|
from homeassistant.helpers.event import async_track_time_interval
|
|
from homeassistant.helpers.httpx_client import get_async_client
|
|
|
|
from .const import DATA_UPDATED, DEFAULT_SCAN_INTERVAL, DOMAIN
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
PLATFORMS = [Platform.SENSOR]
|
|
|
|
CONFIG_SCHEMA = cv.removed(DOMAIN, raise_if_present=False)
|
|
|
|
|
|
async def async_setup_entry(hass: HomeAssistant, config_entry: ConfigEntry) -> bool:
|
|
"""Set up Glances from config entry."""
|
|
client = GlancesData(hass, config_entry)
|
|
hass.data.setdefault(DOMAIN, {})[config_entry.entry_id] = client
|
|
if not await client.async_setup():
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
|
"""Unload a config entry."""
|
|
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
|
if unload_ok:
|
|
hass.data[DOMAIN].pop(entry.entry_id)
|
|
return unload_ok
|
|
|
|
|
|
class GlancesData:
|
|
"""Get the latest data from Glances api."""
|
|
|
|
def __init__(self, hass, config_entry):
|
|
"""Initialize the Glances data."""
|
|
self.hass = hass
|
|
self.config_entry = config_entry
|
|
self.api = None
|
|
self.unsub_timer = None
|
|
self.available = False
|
|
|
|
@property
|
|
def host(self):
|
|
"""Return client host."""
|
|
return self.config_entry.data[CONF_HOST]
|
|
|
|
async def async_update(self):
|
|
"""Get the latest data from the Glances REST API."""
|
|
try:
|
|
await self.api.get_data("all")
|
|
self.available = True
|
|
except exceptions.GlancesApiError:
|
|
_LOGGER.error("Unable to fetch data from Glances")
|
|
self.available = False
|
|
_LOGGER.debug("Glances data updated")
|
|
async_dispatcher_send(self.hass, DATA_UPDATED)
|
|
|
|
async def async_setup(self):
|
|
"""Set up the Glances client."""
|
|
try:
|
|
self.api = get_api(self.hass, self.config_entry.data)
|
|
await self.api.get_data("all")
|
|
self.available = True
|
|
_LOGGER.debug("Successfully connected to Glances")
|
|
|
|
except exceptions.GlancesApiConnectionError as err:
|
|
_LOGGER.debug("Can not connect to Glances")
|
|
raise ConfigEntryNotReady from err
|
|
|
|
self.add_options()
|
|
self.set_scan_interval(self.config_entry.options[CONF_SCAN_INTERVAL])
|
|
self.config_entry.async_on_unload(
|
|
self.config_entry.add_update_listener(self.async_options_updated)
|
|
)
|
|
|
|
await self.hass.config_entries.async_forward_entry_setups(
|
|
self.config_entry, PLATFORMS
|
|
)
|
|
|
|
return True
|
|
|
|
def add_options(self):
|
|
"""Add options for Glances integration."""
|
|
if not self.config_entry.options:
|
|
options = {CONF_SCAN_INTERVAL: DEFAULT_SCAN_INTERVAL}
|
|
self.hass.config_entries.async_update_entry(
|
|
self.config_entry, options=options
|
|
)
|
|
|
|
def set_scan_interval(self, scan_interval):
|
|
"""Update scan interval."""
|
|
|
|
async def refresh(event_time):
|
|
"""Get the latest data from Glances api."""
|
|
await self.async_update()
|
|
|
|
if self.unsub_timer is not None:
|
|
self.unsub_timer()
|
|
self.unsub_timer = async_track_time_interval(
|
|
self.hass, refresh, timedelta(seconds=scan_interval)
|
|
)
|
|
|
|
@staticmethod
|
|
async def async_options_updated(hass: HomeAssistant, entry: ConfigEntry) -> None:
|
|
"""Triggered by config entry options updates."""
|
|
hass.data[DOMAIN][entry.entry_id].set_scan_interval(
|
|
entry.options[CONF_SCAN_INTERVAL]
|
|
)
|
|
|
|
|
|
def get_api(hass, entry):
|
|
"""Return the api from glances_api."""
|
|
params = entry.copy()
|
|
params.pop(CONF_NAME, None)
|
|
verify_ssl = params.pop(CONF_VERIFY_SSL, True)
|
|
httpx_client = get_async_client(hass, verify_ssl=verify_ssl)
|
|
return Glances(httpx_client=httpx_client, **params)
|