Add arest switch
parent
53b43dc4db
commit
d719dd72fe
|
@ -0,0 +1,116 @@
|
||||||
|
"""
|
||||||
|
homeassistant.components.switch.arest
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
The arest switch can control the digital pins of a device running with the
|
||||||
|
aREST RESTful framework for Arduino, the ESP8266, and the Raspberry Pi.
|
||||||
|
Only tested with Arduino boards so far.
|
||||||
|
|
||||||
|
Configuration:
|
||||||
|
|
||||||
|
To use the arest switch you will need to add something like the following
|
||||||
|
to your configuration.yaml file.
|
||||||
|
|
||||||
|
sensor:
|
||||||
|
platform: arest
|
||||||
|
resource: http://IP_ADDRESS
|
||||||
|
pins:
|
||||||
|
11:
|
||||||
|
name: Fan Office
|
||||||
|
12:
|
||||||
|
name: Light Desk
|
||||||
|
|
||||||
|
Variables:
|
||||||
|
|
||||||
|
resource:
|
||||||
|
*Required
|
||||||
|
IP address of the device that is exposing an aREST API.
|
||||||
|
|
||||||
|
pins:
|
||||||
|
The number of the digital pin to switch.
|
||||||
|
|
||||||
|
These are the variables for the pins array:
|
||||||
|
|
||||||
|
name
|
||||||
|
*Required
|
||||||
|
The name for the pin that will be used in the frontend.
|
||||||
|
|
||||||
|
Details for the API: http://arest.io
|
||||||
|
"""
|
||||||
|
import logging
|
||||||
|
from requests import get, exceptions
|
||||||
|
|
||||||
|
from homeassistant.components.switch import SwitchDevice
|
||||||
|
from homeassistant.const import DEVICE_DEFAULT_NAME
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
||||||
|
""" Get the aREST switches. """
|
||||||
|
|
||||||
|
resource = config.get('resource', None)
|
||||||
|
|
||||||
|
try:
|
||||||
|
response = get(resource)
|
||||||
|
except exceptions.MissingSchema:
|
||||||
|
_LOGGER.error("Missing resource or schema in configuration. "
|
||||||
|
"Add http:// to your URL.")
|
||||||
|
return False
|
||||||
|
except exceptions.ConnectionError:
|
||||||
|
_LOGGER.error("No route to device. "
|
||||||
|
"Please check the IP address in the configuration file.")
|
||||||
|
return False
|
||||||
|
|
||||||
|
dev = []
|
||||||
|
pins = config.get('pins')
|
||||||
|
for pinnum, pin in pins.items():
|
||||||
|
dev.append(ArestSwitch(resource,
|
||||||
|
response.json()['name'],
|
||||||
|
pin.get('name'),
|
||||||
|
pinnum))
|
||||||
|
add_devices(dev)
|
||||||
|
|
||||||
|
|
||||||
|
class ArestSwitch(SwitchDevice):
|
||||||
|
""" Implements an aREST switch. """
|
||||||
|
|
||||||
|
def __init__(self, resource, location, name, pin):
|
||||||
|
self._resource = resource
|
||||||
|
self._name = '{} {}'.format(location.title(), name.title())\
|
||||||
|
or DEVICE_DEFAULT_NAME
|
||||||
|
self._pin = pin
|
||||||
|
self._state = None
|
||||||
|
|
||||||
|
request = get('{}/mode/{}/o'.format(self._resource, self._pin))
|
||||||
|
if request.status_code is not 200:
|
||||||
|
_LOGGER.error("Can't set mode. Is device offline?")
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
""" The name of the switch. """
|
||||||
|
return self._name
|
||||||
|
|
||||||
|
@property
|
||||||
|
def is_on(self):
|
||||||
|
""" True if device is on. """
|
||||||
|
request = get('{}/digital/{}'.format(self._resource, self._pin))
|
||||||
|
if request.json()['return_value'] == 0:
|
||||||
|
self._state = False
|
||||||
|
else:
|
||||||
|
self._state = True
|
||||||
|
|
||||||
|
return self._state
|
||||||
|
|
||||||
|
def turn_on(self, **kwargs):
|
||||||
|
""" Turn the device on. """
|
||||||
|
request = get('{}/digital/{}/1'.format(self._resource, self._pin))
|
||||||
|
if request.status_code is not 200:
|
||||||
|
_LOGGER.error("Can't turn on the pin. Is device offline?")
|
||||||
|
self._state = True
|
||||||
|
|
||||||
|
def turn_off(self, **kwargs):
|
||||||
|
""" Turn the device off. """
|
||||||
|
request = get('{}/digital/{}/0'.format(self._resource, self._pin))
|
||||||
|
if request.status_code is not 200:
|
||||||
|
_LOGGER.error("Can't turn off the pin. Is device offline?")
|
||||||
|
self._state = False
|
Loading…
Reference in New Issue