core/homeassistant/components/arest/binary_sensor.py

105 lines
3.3 KiB
Python
Raw Normal View History

"""Support for an exposed aREST RESTful API of a device."""
2015-11-20 22:39:39 +00:00
import logging
2016-02-19 05:27:50 +00:00
from datetime import timedelta
2015-11-29 21:49:05 +00:00
2015-11-20 22:39:39 +00:00
import requests
import voluptuous as vol
2015-11-20 22:39:39 +00:00
2016-09-11 07:24:07 +00:00
from homeassistant.components.binary_sensor import (
BinarySensorDevice, PLATFORM_SCHEMA, DEVICE_CLASSES_SCHEMA)
from homeassistant.const import (
CONF_RESOURCE, CONF_PIN, CONF_NAME, CONF_DEVICE_CLASS)
2016-02-19 05:27:50 +00:00
from homeassistant.util import Throttle
import homeassistant.helpers.config_validation as cv
2015-11-20 22:39:39 +00:00
_LOGGER = logging.getLogger(__name__)
MIN_TIME_BETWEEN_UPDATES = timedelta(seconds=30)
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_RESOURCE): cv.url,
vol.Optional(CONF_NAME): cv.string,
vol.Required(CONF_PIN): cv.string,
vol.Optional(CONF_DEVICE_CLASS): DEVICE_CLASSES_SCHEMA,
})
2015-11-20 22:39:39 +00:00
def setup_platform(hass, config, add_entities, discovery_info=None):
"""Set up the aREST binary sensor."""
2015-11-20 22:39:39 +00:00
resource = config.get(CONF_RESOURCE)
pin = config.get(CONF_PIN)
device_class = config.get(CONF_DEVICE_CLASS)
2015-11-20 22:39:39 +00:00
try:
response = requests.get(resource, timeout=10).json()
except requests.exceptions.MissingSchema:
_LOGGER.error("Missing resource or schema in configuration. "
"Add http:// to your URL")
2015-11-20 22:39:39 +00:00
return False
except requests.exceptions.ConnectionError:
_LOGGER.error("No route to device at %s", resource)
2015-11-20 22:39:39 +00:00
return False
arest = ArestData(resource, pin)
add_entities([ArestBinarySensor(
arest, resource, config.get(CONF_NAME, response[CONF_NAME]),
device_class, pin)], True)
2015-11-20 22:39:39 +00:00
class ArestBinarySensor(BinarySensorDevice):
2016-03-07 19:21:08 +00:00
"""Implement an aREST binary sensor for a pin."""
2015-11-20 22:39:39 +00:00
def __init__(self, arest, resource, name, device_class, pin):
2016-03-07 19:21:08 +00:00
"""Initialize the aREST device."""
2015-11-20 22:39:39 +00:00
self.arest = arest
self._resource = resource
self._name = name
self._device_class = device_class
2015-11-20 22:39:39 +00:00
self._pin = pin
if self._pin is not None:
request = requests.get(
'{}/mode/{}/i'.format(self._resource, self._pin), timeout=10)
if request.status_code != 200:
_LOGGER.error("Can't set mode of %s", self._resource)
2015-11-20 22:39:39 +00:00
@property
def name(self):
2016-03-07 19:21:08 +00:00
"""Return the name of the binary sensor."""
2015-11-20 22:39:39 +00:00
return self._name
@property
def is_on(self):
2016-03-07 19:21:08 +00:00
"""Return true if the binary sensor is on."""
2015-11-20 22:39:39 +00:00
return bool(self.arest.data.get('state'))
2016-03-26 22:39:56 +00:00
@property
def device_class(self):
2016-03-26 22:39:56 +00:00
"""Return the class of this sensor."""
return self._device_class
2016-03-26 22:39:56 +00:00
2015-11-20 22:39:39 +00:00
def update(self):
2016-03-07 19:21:08 +00:00
"""Get the latest data from aREST API."""
2015-11-20 22:39:39 +00:00
self.arest.update()
class ArestData:
"""Class for handling the data retrieval for pins."""
2016-03-07 19:21:08 +00:00
2015-11-20 22:39:39 +00:00
def __init__(self, resource, pin):
2016-03-07 19:21:08 +00:00
"""Initialize the aREST data object."""
2015-11-20 22:39:39 +00:00
self._resource = resource
self._pin = pin
self.data = {}
@Throttle(MIN_TIME_BETWEEN_UPDATES)
def update(self):
2016-03-07 19:21:08 +00:00
"""Get the latest data from aREST device."""
2015-11-20 22:39:39 +00:00
try:
response = requests.get('{}/digital/{}'.format(
self._resource, self._pin), timeout=10)
self.data = {'state': response.json()['return_value']}
except requests.exceptions.ConnectionError:
_LOGGER.error("No route to device '%s'", self._resource)