* 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
83 lines
2.6 KiB
Python
83 lines
2.6 KiB
Python
"""
|
|
Support for Envisalink zone states- represented as binary sensors.
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
https://home-assistant.io/components/binary_sensor.envisalink/
|
|
"""
|
|
import asyncio
|
|
import logging
|
|
|
|
from homeassistant.core import callback
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
|
from homeassistant.components.binary_sensor import BinarySensorDevice
|
|
from homeassistant.components.envisalink import (
|
|
DATA_EVL, ZONE_SCHEMA, CONF_ZONENAME, CONF_ZONETYPE, EnvisalinkDevice,
|
|
SIGNAL_ZONE_UPDATE)
|
|
from homeassistant.const import ATTR_LAST_TRIP_TIME
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
DEPENDENCIES = ['envisalink']
|
|
|
|
|
|
@asyncio.coroutine
|
|
def async_setup_platform(hass, config, async_add_devices, discovery_info=None):
|
|
"""Set up the Envisalink binary sensor devices."""
|
|
configured_zones = discovery_info['zones']
|
|
|
|
devices = []
|
|
for zone_num in configured_zones:
|
|
device_config_data = ZONE_SCHEMA(configured_zones[zone_num])
|
|
device = EnvisalinkBinarySensor(
|
|
hass,
|
|
zone_num,
|
|
device_config_data[CONF_ZONENAME],
|
|
device_config_data[CONF_ZONETYPE],
|
|
hass.data[DATA_EVL].alarm_state['zone'][zone_num],
|
|
hass.data[DATA_EVL]
|
|
)
|
|
devices.append(device)
|
|
|
|
async_add_devices(devices)
|
|
|
|
|
|
class EnvisalinkBinarySensor(EnvisalinkDevice, BinarySensorDevice):
|
|
"""Representation of an Envisalink binary sensor."""
|
|
|
|
def __init__(self, hass, zone_number, zone_name, zone_type, info,
|
|
controller):
|
|
"""Initialize the binary_sensor."""
|
|
self._zone_type = zone_type
|
|
self._zone_number = zone_number
|
|
|
|
_LOGGER.debug('Setting up zone: %s', zone_name)
|
|
super().__init__(zone_name, info, controller)
|
|
|
|
@asyncio.coroutine
|
|
def async_added_to_hass(self):
|
|
"""Register callbacks."""
|
|
async_dispatcher_connect(
|
|
self.hass, SIGNAL_ZONE_UPDATE, self._update_callback)
|
|
|
|
@property
|
|
def device_state_attributes(self):
|
|
"""Return the state attributes."""
|
|
attr = {}
|
|
attr[ATTR_LAST_TRIP_TIME] = self._info['last_fault']
|
|
return attr
|
|
|
|
@property
|
|
def is_on(self):
|
|
"""Return true if sensor is on."""
|
|
return self._info['status']['open']
|
|
|
|
@property
|
|
def device_class(self):
|
|
"""Return the class of this sensor, from DEVICE_CLASSES."""
|
|
return self._zone_type
|
|
|
|
@callback
|
|
def _update_callback(self, zone):
|
|
"""Update the zone's state, if needed."""
|
|
if zone is None or int(zone) == self._zone_number:
|
|
self.async_schedule_update_ha_state()
|