2016-02-23 19:20:54 +00:00
|
|
|
"""
|
2016-09-20 07:05:54 +00:00
|
|
|
Support for Wink binary sensors.
|
2016-02-23 19:20:54 +00:00
|
|
|
|
|
|
|
For more details about this platform, please refer to the documentation at
|
2016-09-20 07:05:54 +00:00
|
|
|
at https://home-assistant.io/components/binary_sensor.wink/
|
2016-02-23 19:20:54 +00:00
|
|
|
"""
|
2017-05-13 18:09:00 +00:00
|
|
|
import asyncio
|
2017-02-02 06:43:12 +00:00
|
|
|
import logging
|
2016-02-23 19:20:54 +00:00
|
|
|
|
|
|
|
from homeassistant.components.binary_sensor import BinarySensorDevice
|
2018-01-21 06:35:38 +00:00
|
|
|
from homeassistant.components.wink import DOMAIN, WinkDevice
|
2016-02-23 19:20:54 +00:00
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2016-09-20 07:05:54 +00:00
|
|
|
DEPENDENCIES = ['wink']
|
2016-02-23 19:20:54 +00:00
|
|
|
|
|
|
|
# These are the available sensors mapped to binary_sensor class
|
|
|
|
SENSOR_TYPES = {
|
2017-04-30 05:04:49 +00:00
|
|
|
'brightness': 'light',
|
|
|
|
'capturing_audio': 'sound',
|
2018-01-21 06:35:38 +00:00
|
|
|
'capturing_video': None,
|
|
|
|
'co_detected': 'gas',
|
2017-04-30 05:04:49 +00:00
|
|
|
'liquid_detected': 'moisture',
|
2018-01-21 06:35:38 +00:00
|
|
|
'loudness': 'sound',
|
2017-04-30 05:04:49 +00:00
|
|
|
'motion': 'motion',
|
2018-01-21 06:35:38 +00:00
|
|
|
'noise': 'sound',
|
|
|
|
'opened': 'opening',
|
2017-04-30 05:04:49 +00:00
|
|
|
'presence': 'occupancy',
|
|
|
|
'smoke_detected': 'smoke',
|
2018-01-21 06:35:38 +00:00
|
|
|
'vibration': 'vibration',
|
2016-02-23 19:20:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Set up the Wink binary sensor platform."""
|
2016-02-23 19:20:54 +00:00
|
|
|
import pywink
|
|
|
|
|
|
|
|
for sensor in pywink.get_sensors():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = sensor.object_id() + sensor.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
if sensor.capability() in SENSOR_TYPES:
|
|
|
|
add_devices([WinkBinarySensorDevice(sensor, hass)])
|
2016-02-23 19:20:54 +00:00
|
|
|
|
2016-07-14 20:31:16 +00:00
|
|
|
for key in pywink.get_keys():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = key.object_id() + key.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkBinarySensorDevice(key, hass)])
|
2016-07-14 20:31:16 +00:00
|
|
|
|
2016-10-04 08:07:50 +00:00
|
|
|
for sensor in pywink.get_smoke_and_co_detectors():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = sensor.object_id() + sensor.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkSmokeDetector(sensor, hass)])
|
2016-10-04 08:07:50 +00:00
|
|
|
|
2016-12-04 05:39:48 +00:00
|
|
|
for hub in pywink.get_hubs():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = hub.object_id() + hub.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkHub(hub, hass)])
|
2016-12-04 05:39:48 +00:00
|
|
|
|
2017-01-25 05:11:18 +00:00
|
|
|
for remote in pywink.get_remotes():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = remote.object_id() + remote.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkRemote(remote, hass)])
|
2017-01-25 05:11:18 +00:00
|
|
|
|
|
|
|
for button in pywink.get_buttons():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = button.object_id() + button.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkButton(button, hass)])
|
2017-01-25 05:11:18 +00:00
|
|
|
|
|
|
|
for gang in pywink.get_gangs():
|
2017-02-02 06:43:12 +00:00
|
|
|
_id = gang.object_id() + gang.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkGang(gang, hass)])
|
|
|
|
|
|
|
|
for door_bell_sensor in pywink.get_door_bells():
|
|
|
|
_id = door_bell_sensor.object_id() + door_bell_sensor.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
add_devices([WinkBinarySensorDevice(door_bell_sensor, hass)])
|
|
|
|
|
|
|
|
for camera_sensor in pywink.get_cameras():
|
|
|
|
_id = camera_sensor.object_id() + camera_sensor.name()
|
|
|
|
if _id not in hass.data[DOMAIN]['unique_ids']:
|
|
|
|
try:
|
|
|
|
if camera_sensor.capability() in SENSOR_TYPES:
|
|
|
|
add_devices([WinkBinarySensorDevice(camera_sensor, hass)])
|
|
|
|
except AttributeError:
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.info("Device isn't a sensor, skipping")
|
2017-01-25 05:11:18 +00:00
|
|
|
|
2016-02-23 19:20:54 +00:00
|
|
|
|
2017-10-16 12:58:23 +00:00
|
|
|
class WinkBinarySensorDevice(WinkDevice, BinarySensorDevice):
|
2016-07-13 12:47:29 +00:00
|
|
|
"""Representation of a Wink binary sensor."""
|
2016-02-23 19:20:54 +00:00
|
|
|
|
2016-11-30 21:12:26 +00:00
|
|
|
def __init__(self, wink, hass):
|
2016-03-07 19:21:08 +00:00
|
|
|
"""Initialize the Wink binary sensor."""
|
2016-11-30 21:12:26 +00:00
|
|
|
super().__init__(wink, hass)
|
2017-02-19 04:00:27 +00:00
|
|
|
if hasattr(self.wink, 'unit'):
|
2017-02-02 06:43:12 +00:00
|
|
|
self._unit_of_measurement = self.wink.unit()
|
2017-02-19 04:00:27 +00:00
|
|
|
else:
|
2017-02-02 06:43:12 +00:00
|
|
|
self._unit_of_measurement = None
|
2017-02-19 04:00:27 +00:00
|
|
|
if hasattr(self.wink, 'capability'):
|
2017-02-02 06:43:12 +00:00
|
|
|
self.capability = self.wink.capability()
|
2017-02-19 04:00:27 +00:00
|
|
|
else:
|
2017-02-02 06:43:12 +00:00
|
|
|
self.capability = None
|
2016-02-23 19:20:54 +00:00
|
|
|
|
2017-05-13 18:09:00 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def async_added_to_hass(self):
|
2018-01-21 06:35:38 +00:00
|
|
|
"""Call when entity is added to hass."""
|
2017-05-13 18:09:00 +00:00
|
|
|
self.hass.data[DOMAIN]['entities']['binary_sensor'].append(self)
|
|
|
|
|
2016-02-23 19:20:54 +00:00
|
|
|
@property
|
|
|
|
def is_on(self):
|
2016-03-07 19:21:08 +00:00
|
|
|
"""Return true if the binary sensor is on."""
|
2017-01-25 05:11:18 +00:00
|
|
|
return self.wink.state()
|
2016-02-23 19:20:54 +00:00
|
|
|
|
|
|
|
@property
|
2017-02-11 04:46:15 +00:00
|
|
|
def device_class(self):
|
|
|
|
"""Return the class of this sensor, from DEVICE_CLASSES."""
|
2016-02-23 19:20:54 +00:00
|
|
|
return SENSOR_TYPES.get(self.capability)
|
2016-12-04 05:39:48 +00:00
|
|
|
|
2017-10-16 12:58:23 +00:00
|
|
|
@property
|
|
|
|
def device_state_attributes(self):
|
2018-01-21 06:35:38 +00:00
|
|
|
"""Return the device state attributes."""
|
2017-10-16 12:58:23 +00:00
|
|
|
return super().device_state_attributes
|
|
|
|
|
2016-12-04 05:39:48 +00:00
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
class WinkSmokeDetector(WinkBinarySensorDevice):
|
|
|
|
"""Representation of a Wink Smoke detector."""
|
2016-12-04 05:39:48 +00:00
|
|
|
|
2017-01-25 05:11:18 +00:00
|
|
|
@property
|
2017-02-02 06:43:12 +00:00
|
|
|
def device_state_attributes(self):
|
2018-01-21 06:35:38 +00:00
|
|
|
"""Return the device state attributes."""
|
2017-10-16 12:58:23 +00:00
|
|
|
_attributes = super().device_state_attributes
|
|
|
|
_attributes['test_activated'] = self.wink.test_activated()
|
|
|
|
return _attributes
|
2017-02-02 06:43:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
class WinkHub(WinkBinarySensorDevice):
|
|
|
|
"""Representation of a Wink Hub."""
|
|
|
|
|
2016-12-04 05:39:48 +00:00
|
|
|
@property
|
|
|
|
def device_state_attributes(self):
|
2018-01-21 06:35:38 +00:00
|
|
|
"""Return the device state attributes."""
|
2017-10-16 12:58:23 +00:00
|
|
|
_attributes = super().device_state_attributes
|
|
|
|
_attributes['update_needed'] = self.wink.update_needed()
|
|
|
|
_attributes['firmware_version'] = self.wink.firmware_version()
|
|
|
|
_attributes['pairing_mode'] = self.wink.pairing_mode()
|
2018-01-25 16:31:38 +00:00
|
|
|
_kidde_code = self.wink.kidde_radio_code()
|
|
|
|
if _kidde_code is not None:
|
|
|
|
# The service call to set the Kidde code
|
|
|
|
# takes a string of 1s and 0s so it makes
|
|
|
|
# sense to display it to the user that way
|
|
|
|
_formatted_kidde_code = "{:b}".format(_kidde_code).zfill(8)
|
|
|
|
_attributes['kidde_radio_code'] = _formatted_kidde_code
|
2017-10-16 12:58:23 +00:00
|
|
|
return _attributes
|
2016-12-04 05:39:48 +00:00
|
|
|
|
2017-01-25 05:11:18 +00:00
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
class WinkRemote(WinkBinarySensorDevice):
|
2017-01-25 05:11:18 +00:00
|
|
|
"""Representation of a Wink Lutron Connected bulb remote."""
|
|
|
|
|
|
|
|
@property
|
|
|
|
def device_state_attributes(self):
|
|
|
|
"""Return the state attributes."""
|
2017-10-16 12:58:23 +00:00
|
|
|
_attributes = super().device_state_attributes
|
|
|
|
_attributes['button_on_pressed'] = self.wink.button_on_pressed()
|
|
|
|
_attributes['button_off_pressed'] = self.wink.button_off_pressed()
|
|
|
|
_attributes['button_up_pressed'] = self.wink.button_up_pressed()
|
|
|
|
_attributes['button_down_pressed'] = self.wink.button_down_pressed()
|
|
|
|
return _attributes
|
2017-01-25 05:11:18 +00:00
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
@property
|
2017-02-11 04:46:15 +00:00
|
|
|
def device_class(self):
|
|
|
|
"""Return the class of this sensor, from DEVICE_CLASSES."""
|
2017-02-02 06:43:12 +00:00
|
|
|
return None
|
2017-01-25 05:11:18 +00:00
|
|
|
|
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
class WinkButton(WinkBinarySensorDevice):
|
|
|
|
"""Representation of a Wink Relay button."""
|
2017-01-25 05:11:18 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def device_state_attributes(self):
|
2018-01-21 06:35:38 +00:00
|
|
|
"""Return the device state attributes."""
|
2017-10-16 12:58:23 +00:00
|
|
|
_attributes = super().device_state_attributes
|
|
|
|
_attributes['pressed'] = self.wink.pressed()
|
|
|
|
_attributes['long_pressed'] = self.wink.long_pressed()
|
|
|
|
return _attributes
|
2017-01-25 05:11:18 +00:00
|
|
|
|
|
|
|
|
2017-02-02 06:43:12 +00:00
|
|
|
class WinkGang(WinkBinarySensorDevice):
|
2017-01-25 05:11:18 +00:00
|
|
|
"""Representation of a Wink Relay gang."""
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
"""Return true if the gang is connected."""
|
|
|
|
return self.wink.state()
|