2019-09-22 21:49:09 +00:00
|
|
|
"""Support for Kaiterra Air Quality Sensors."""
|
2022-01-03 11:07:05 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2019-09-22 21:49:09 +00:00
|
|
|
from homeassistant.components.air_quality import AirQualityEntity
|
|
|
|
from homeassistant.const import CONF_DEVICE_ID, CONF_NAME
|
2022-01-03 11:07:05 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2019-10-14 05:01:40 +00:00
|
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
2022-01-03 11:07:05 +00:00
|
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|
|
|
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
|
2019-09-22 21:49:09 +00:00
|
|
|
|
|
|
|
from .const import (
|
|
|
|
ATTR_AQI_LEVEL,
|
|
|
|
ATTR_AQI_POLLUTANT,
|
2019-10-14 05:01:40 +00:00
|
|
|
ATTR_VOC,
|
2019-09-22 21:49:09 +00:00
|
|
|
DISPATCHER_KAITERRA,
|
2019-10-14 05:01:40 +00:00
|
|
|
DOMAIN,
|
2019-09-22 21:49:09 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2022-01-03 11:07:05 +00:00
|
|
|
async def async_setup_platform(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
config: ConfigType,
|
|
|
|
async_add_entities: AddEntitiesCallback,
|
|
|
|
discovery_info: DiscoveryInfoType | None = None,
|
|
|
|
) -> None:
|
2019-09-22 21:49:09 +00:00
|
|
|
"""Set up the air_quality kaiterra sensor."""
|
|
|
|
if discovery_info is None:
|
|
|
|
return
|
|
|
|
|
|
|
|
api = hass.data[DOMAIN]
|
|
|
|
name = discovery_info[CONF_NAME]
|
|
|
|
device_id = discovery_info[CONF_DEVICE_ID]
|
|
|
|
|
|
|
|
async_add_entities([KaiterraAirQuality(api, name, device_id)])
|
|
|
|
|
|
|
|
|
|
|
|
class KaiterraAirQuality(AirQualityEntity):
|
|
|
|
"""Implementation of a Kaittera air quality sensor."""
|
|
|
|
|
2022-08-26 19:19:37 +00:00
|
|
|
_attr_should_poll = False
|
|
|
|
|
2019-09-22 21:49:09 +00:00
|
|
|
def __init__(self, api, name, device_id):
|
|
|
|
"""Initialize the sensor."""
|
|
|
|
self._api = api
|
|
|
|
self._name = f"{name} Air Quality"
|
|
|
|
self._device_id = device_id
|
|
|
|
|
|
|
|
def _data(self, key):
|
|
|
|
return self._device.get(key, {}).get("value")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def _device(self):
|
|
|
|
return self._api.data.get(self._device_id, {})
|
|
|
|
|
|
|
|
@property
|
|
|
|
def available(self):
|
|
|
|
"""Return the availability of the sensor."""
|
|
|
|
return self._api.data.get(self._device_id) is not None
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of the sensor."""
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def air_quality_index(self):
|
|
|
|
"""Return the Air Quality Index (AQI)."""
|
|
|
|
return self._data("aqi")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def air_quality_index_level(self):
|
|
|
|
"""Return the Air Quality Index level."""
|
|
|
|
return self._data("aqi_level")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def air_quality_index_pollutant(self):
|
|
|
|
"""Return the Air Quality Index level."""
|
|
|
|
return self._data("aqi_pollutant")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def particulate_matter_2_5(self):
|
|
|
|
"""Return the particulate matter 2.5 level."""
|
|
|
|
return self._data("rpm25c")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def particulate_matter_10(self):
|
|
|
|
"""Return the particulate matter 10 level."""
|
|
|
|
return self._data("rpm10c")
|
|
|
|
|
2019-09-27 15:42:32 +00:00
|
|
|
@property
|
|
|
|
def carbon_dioxide(self):
|
|
|
|
"""Return the CO2 (carbon dioxide) level."""
|
|
|
|
return self._data("rco2")
|
|
|
|
|
2019-09-22 21:49:09 +00:00
|
|
|
@property
|
|
|
|
def volatile_organic_compounds(self):
|
|
|
|
"""Return the VOC (Volatile Organic Compounds) level."""
|
|
|
|
return self._data("rtvoc")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self):
|
|
|
|
"""Return the sensor's unique id."""
|
|
|
|
return f"{self._device_id}_air_quality"
|
|
|
|
|
|
|
|
@property
|
2021-03-11 19:11:25 +00:00
|
|
|
def extra_state_attributes(self):
|
2019-09-22 21:49:09 +00:00
|
|
|
"""Return the device state attributes."""
|
|
|
|
data = {}
|
|
|
|
attributes = [
|
|
|
|
(ATTR_VOC, self.volatile_organic_compounds),
|
|
|
|
(ATTR_AQI_LEVEL, self.air_quality_index_level),
|
|
|
|
(ATTR_AQI_POLLUTANT, self.air_quality_index_pollutant),
|
|
|
|
]
|
|
|
|
|
|
|
|
for attr, value in attributes:
|
|
|
|
if value is not None:
|
|
|
|
data[attr] = value
|
|
|
|
|
|
|
|
return data
|
|
|
|
|
|
|
|
async def async_added_to_hass(self):
|
|
|
|
"""Register callback."""
|
2020-04-02 16:25:33 +00:00
|
|
|
self.async_on_remove(
|
|
|
|
async_dispatcher_connect(
|
|
|
|
self.hass, DISPATCHER_KAITERRA, self.async_write_ha_state
|
|
|
|
)
|
2019-09-22 21:49:09 +00:00
|
|
|
)
|