2016-03-04 16:35:46 +00:00
|
|
|
"""
|
|
|
|
Support for WeMo sensors.
|
|
|
|
|
|
|
|
For more details about this component, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/binary_sensor.wemo/
|
|
|
|
"""
|
|
|
|
import logging
|
2018-08-16 14:14:54 +00:00
|
|
|
import requests
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
from homeassistant.components.binary_sensor import BinarySensorDevice
|
2018-08-16 14:14:54 +00:00
|
|
|
from homeassistant.exceptions import PlatformNotReady
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
DEPENDENCIES = ['wemo']
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
|
|
|
"""Register discovered WeMo binary sensors."""
|
2018-07-18 09:54:27 +00:00
|
|
|
from pywemo import discovery
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
if discovery_info is not None:
|
2017-04-20 04:25:45 +00:00
|
|
|
location = discovery_info['ssdp_description']
|
|
|
|
mac = discovery_info['mac_address']
|
2018-08-16 14:14:54 +00:00
|
|
|
|
|
|
|
try:
|
|
|
|
device = discovery.device_from_description(location, mac)
|
|
|
|
except (requests.exceptions.ConnectionError,
|
|
|
|
requests.exceptions.Timeout) as err:
|
|
|
|
_LOGGER.error('Unable to access %s (%s)', location, err)
|
|
|
|
raise PlatformNotReady
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
if device:
|
2018-05-01 18:57:30 +00:00
|
|
|
add_devices_callback([WemoBinarySensor(hass, device)])
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
class WemoBinarySensor(BinarySensorDevice):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Representation a WeMo binary sensor."""
|
2016-03-04 16:35:46 +00:00
|
|
|
|
2018-05-01 18:57:30 +00:00
|
|
|
def __init__(self, hass, device):
|
2016-03-04 16:35:46 +00:00
|
|
|
"""Initialize the WeMo sensor."""
|
|
|
|
self.wemo = device
|
|
|
|
self._state = None
|
|
|
|
|
2018-05-01 18:57:30 +00:00
|
|
|
wemo = hass.components.wemo
|
2016-03-04 16:35:46 +00:00
|
|
|
wemo.SUBSCRIPTION_REGISTRY.register(self.wemo)
|
|
|
|
wemo.SUBSCRIPTION_REGISTRY.on(self.wemo, None, self._update_callback)
|
|
|
|
|
2017-04-18 16:11:08 +00:00
|
|
|
def _update_callback(self, _device, _type, _params):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Handle state changes."""
|
|
|
|
_LOGGER.info("Subscription update for %s", _device)
|
2017-04-18 16:11:08 +00:00
|
|
|
updated = self.wemo.subscription_update(_type, _params)
|
|
|
|
self._update(force_update=(not updated))
|
|
|
|
|
2016-03-14 10:29:12 +00:00
|
|
|
if not hasattr(self, 'hass'):
|
|
|
|
return
|
2016-11-17 15:34:46 +00:00
|
|
|
self.schedule_update_ha_state()
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def should_poll(self):
|
|
|
|
"""No polling needed with subscriptions."""
|
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self):
|
|
|
|
"""Return the id of this WeMo device."""
|
2018-01-30 09:39:39 +00:00
|
|
|
return self.wemo.serialnumber
|
2016-03-04 16:35:46 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2018-01-27 19:58:27 +00:00
|
|
|
"""Return the name of the service if any."""
|
2016-03-04 16:35:46 +00:00
|
|
|
return self.wemo.name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Return true if sensor is on."""
|
2016-03-04 16:35:46 +00:00
|
|
|
return self._state
|
|
|
|
|
|
|
|
def update(self):
|
|
|
|
"""Update WeMo state."""
|
2017-04-18 16:11:08 +00:00
|
|
|
self._update(force_update=True)
|
|
|
|
|
|
|
|
def _update(self, force_update=True):
|
2016-03-04 16:35:46 +00:00
|
|
|
try:
|
2017-04-18 16:11:08 +00:00
|
|
|
self._state = self.wemo.get_state(force_update)
|
|
|
|
except AttributeError as err:
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.warning(
|
|
|
|
"Could not update status for %s (%s)", self.name, err)
|