* Upgrade pylint to 1.8.1 * Fix no-else-return * Fix bad-whitespace * Fix too-many-nested-blocks * Fix raising-format-tuple See https://github.com/PyCQA/pylint/blob/master/doc/whatsnew/1.8.rst * Fix len-as-condition * Fix logging-not-lazy Not sure about that TEMP_CELSIUS though, but internally it's probably just like if you concatenated any other (variable) string * Fix stop-iteration-return * Fix useless-super-delegation * Fix trailing-comma-tuple Both of these seem to simply be bugs: * Nest: The value of self._humidity never seems to be used anywhere * Dovado: The called API method seems to expect a "normal" number * Fix redefined-argument-from-local * Fix consider-using-enumerate * Fix wrong-import-order * Fix arguments-differ * Fix missed no-else-return * Fix no-member and related * Fix signatures-differ * Revert "Upgrade pylint to 1.8.1" This reverts commit af78aa00f125a7d34add97b9d50c14db48412211. * Fix arguments-differ * except for device_tracker * Cleanup * Fix test using positional argument * Fix line too long I forgot to run flake8 - shame on me... 🙃 * Fix bad-option-value for 1.6.5 * Fix arguments-differ for device_tracker * Upgrade pylint to 1.8.2 * 👕 Fix missed no-member
84 lines
2.8 KiB
Python
84 lines
2.8 KiB
Python
"""IHC sensor platform.
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
https://home-assistant.io/components/sensor.ihc/
|
|
"""
|
|
from xml.etree.ElementTree import Element
|
|
|
|
import voluptuous as vol
|
|
|
|
from homeassistant.components.ihc import (
|
|
validate_name, IHC_DATA, IHC_CONTROLLER, IHC_INFO)
|
|
from homeassistant.components.ihc.ihcdevice import IHCDevice
|
|
from homeassistant.components.sensor import PLATFORM_SCHEMA
|
|
from homeassistant.const import (
|
|
CONF_ID, CONF_NAME, CONF_UNIT_OF_MEASUREMENT, CONF_SENSORS,
|
|
TEMP_CELSIUS)
|
|
import homeassistant.helpers.config_validation as cv
|
|
from homeassistant.helpers.entity import Entity
|
|
|
|
DEPENDENCIES = ['ihc']
|
|
|
|
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
|
vol.Optional(CONF_SENSORS, default=[]):
|
|
vol.All(cv.ensure_list, [
|
|
vol.All({
|
|
vol.Required(CONF_ID): cv.positive_int,
|
|
vol.Optional(CONF_NAME): cv.string,
|
|
vol.Optional(CONF_UNIT_OF_MEASUREMENT,
|
|
default=TEMP_CELSIUS): cv.string
|
|
}, validate_name)
|
|
])
|
|
})
|
|
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
|
"""Setup the ihc sensor platform."""
|
|
ihc_controller = hass.data[IHC_DATA][IHC_CONTROLLER]
|
|
info = hass.data[IHC_DATA][IHC_INFO]
|
|
devices = []
|
|
if discovery_info:
|
|
for name, device in discovery_info.items():
|
|
ihc_id = device['ihc_id']
|
|
product_cfg = device['product_cfg']
|
|
product = device['product']
|
|
sensor = IHCSensor(ihc_controller, name, ihc_id, info,
|
|
product_cfg[CONF_UNIT_OF_MEASUREMENT],
|
|
product)
|
|
devices.append(sensor)
|
|
else:
|
|
sensors = config[CONF_SENSORS]
|
|
for sensor_cfg in sensors:
|
|
ihc_id = sensor_cfg[CONF_ID]
|
|
name = sensor_cfg[CONF_NAME]
|
|
unit = sensor_cfg[CONF_UNIT_OF_MEASUREMENT]
|
|
sensor = IHCSensor(ihc_controller, name, ihc_id, info, unit)
|
|
devices.append(sensor)
|
|
|
|
add_devices(devices)
|
|
|
|
|
|
class IHCSensor(IHCDevice, Entity):
|
|
"""Implementation of the IHC sensor."""
|
|
|
|
def __init__(self, ihc_controller, name, ihc_id: int, info: bool,
|
|
unit, product: Element = None) -> None:
|
|
"""Initialize the IHC sensor."""
|
|
super().__init__(ihc_controller, name, ihc_id, info, product)
|
|
self._state = None
|
|
self._unit_of_measurement = unit
|
|
|
|
@property
|
|
def state(self):
|
|
"""Return the state of the sensor."""
|
|
return self._state
|
|
|
|
@property
|
|
def unit_of_measurement(self):
|
|
"""Return the unit of measurement of this entity, if any."""
|
|
return self._unit_of_measurement
|
|
|
|
def on_ihc_change(self, ihc_id, value):
|
|
"""Callback when ihc resource changes."""
|
|
self._state = value
|
|
self.schedule_update_ha_state()
|