2020-01-06 15:35:10 +00:00
|
|
|
"""Support for HomeKit Controller air quality sensors."""
|
2021-08-17 14:29:52 +00:00
|
|
|
import logging
|
|
|
|
|
2020-02-24 09:55:33 +00:00
|
|
|
from aiohomekit.model.characteristics import CharacteristicsTypes
|
2020-11-16 23:11:39 +00:00
|
|
|
from aiohomekit.model.services import ServicesTypes
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
from homeassistant.components.air_quality import AirQualityEntity
|
2020-01-29 21:59:45 +00:00
|
|
|
from homeassistant.core import callback
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
from . import KNOWN_DEVICES, HomeKitEntity
|
|
|
|
|
2021-08-17 14:29:52 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2020-01-06 15:35:10 +00:00
|
|
|
AIR_QUALITY_TEXT = {
|
|
|
|
0: "unknown",
|
|
|
|
1: "excellent",
|
|
|
|
2: "good",
|
|
|
|
3: "fair",
|
|
|
|
4: "inferior",
|
|
|
|
5: "poor",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class HomeAirQualitySensor(HomeKitEntity, AirQualityEntity):
|
|
|
|
"""Representation of a HomeKit Controller Air Quality sensor."""
|
|
|
|
|
2021-08-17 14:29:52 +00:00
|
|
|
async def async_added_to_hass(self):
|
|
|
|
"""Call when entity is added to hass."""
|
|
|
|
_LOGGER.warning(
|
|
|
|
"The homekit_controller air_quality entity has been "
|
|
|
|
"deprecated and will be removed in 2021.12.0"
|
|
|
|
)
|
|
|
|
await super().async_added_to_hass()
|
|
|
|
|
|
|
|
@property
|
|
|
|
def entity_registry_enabled_default(self) -> bool:
|
|
|
|
"""Whether or not to enable this entity by default."""
|
|
|
|
# This entity is deprecated, so don't enable by default
|
|
|
|
return False
|
|
|
|
|
2020-01-06 15:35:10 +00:00
|
|
|
def get_characteristic_types(self):
|
|
|
|
"""Define the homekit characteristics the entity cares about."""
|
|
|
|
return [
|
|
|
|
CharacteristicsTypes.AIR_QUALITY,
|
|
|
|
CharacteristicsTypes.DENSITY_PM25,
|
|
|
|
CharacteristicsTypes.DENSITY_PM10,
|
|
|
|
CharacteristicsTypes.DENSITY_OZONE,
|
|
|
|
CharacteristicsTypes.DENSITY_NO2,
|
|
|
|
CharacteristicsTypes.DENSITY_SO2,
|
|
|
|
CharacteristicsTypes.DENSITY_VOC,
|
|
|
|
]
|
|
|
|
|
|
|
|
@property
|
|
|
|
def particulate_matter_2_5(self):
|
|
|
|
"""Return the particulate matter 2.5 level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_PM25)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def particulate_matter_10(self):
|
|
|
|
"""Return the particulate matter 10 level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_PM10)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def ozone(self):
|
|
|
|
"""Return the O3 (ozone) level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_OZONE)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def sulphur_dioxide(self):
|
|
|
|
"""Return the SO2 (sulphur dioxide) level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_SO2)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def nitrogen_dioxide(self):
|
|
|
|
"""Return the NO2 (nitrogen dioxide) level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_NO2)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def air_quality_text(self):
|
|
|
|
"""Return the Air Quality Index (AQI)."""
|
2020-03-11 11:40:47 +00:00
|
|
|
air_quality = self.service.value(CharacteristicsTypes.AIR_QUALITY)
|
2020-01-06 15:35:10 +00:00
|
|
|
return AIR_QUALITY_TEXT.get(air_quality, "unknown")
|
|
|
|
|
|
|
|
@property
|
|
|
|
def volatile_organic_compounds(self):
|
|
|
|
"""Return the volatile organic compounds (VOC) level."""
|
2020-03-11 11:40:47 +00:00
|
|
|
return self.service.value(CharacteristicsTypes.DENSITY_VOC)
|
2020-01-06 15:35:10 +00:00
|
|
|
|
|
|
|
@property
|
2021-03-11 15:57:47 +00:00
|
|
|
def extra_state_attributes(self):
|
2020-01-06 15:35:10 +00:00
|
|
|
"""Return the device state attributes."""
|
|
|
|
data = {"air_quality_text": self.air_quality_text}
|
|
|
|
|
2021-10-17 18:05:11 +00:00
|
|
|
if voc := self.volatile_organic_compounds:
|
2020-01-06 15:35:10 +00:00
|
|
|
data["volatile_organic_compounds"] = voc
|
|
|
|
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(hass, config_entry, async_add_entities):
|
|
|
|
"""Set up Homekit air quality sensor."""
|
|
|
|
hkid = config_entry.data["AccessoryPairingID"]
|
|
|
|
conn = hass.data[KNOWN_DEVICES][hkid]
|
|
|
|
|
2020-01-29 21:59:45 +00:00
|
|
|
@callback
|
2020-11-16 23:11:39 +00:00
|
|
|
def async_add_service(service):
|
|
|
|
if service.short_type != ServicesTypes.AIR_QUALITY_SENSOR:
|
2020-01-06 15:35:10 +00:00
|
|
|
return False
|
2020-11-16 23:11:39 +00:00
|
|
|
info = {"aid": service.accessory.aid, "iid": service.iid}
|
2020-01-06 15:35:10 +00:00
|
|
|
async_add_entities([HomeAirQualitySensor(conn, info)], True)
|
|
|
|
return True
|
|
|
|
|
|
|
|
conn.add_listener(async_add_service)
|