2015-03-08 14:14:44 +00:00
|
|
|
"""
|
2015-08-08 17:09:37 +00:00
|
|
|
homeassistant.components.switch.vera
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-03-08 14:14:44 +00:00
|
|
|
Support for Vera switches.
|
2015-03-07 03:49:20 +00:00
|
|
|
|
2015-10-20 20:08:20 +00:00
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/switch.vera.html
|
2015-03-07 03:49:20 +00:00
|
|
|
"""
|
2015-03-02 10:09:00 +00:00
|
|
|
import logging
|
|
|
|
import time
|
2015-03-08 21:45:20 +00:00
|
|
|
from requests.exceptions import RequestException
|
2015-05-18 08:54:25 +00:00
|
|
|
import homeassistant.util.dt as dt_util
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-22 02:16:13 +00:00
|
|
|
from homeassistant.helpers.entity import ToggleEntity
|
2015-03-08 21:10:31 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
ATTR_BATTERY_LEVEL, ATTR_TRIPPED, ATTR_ARMED, ATTR_LAST_TRIP_TIME)
|
2015-09-09 03:11:25 +00:00
|
|
|
|
2015-10-27 23:43:06 +00:00
|
|
|
REQUIREMENTS = ['https://github.com/pavoni/home-assistant-vera-api/archive/'
|
2015-10-30 09:30:22 +00:00
|
|
|
'efdba4e63d58a30bc9b36d9e01e69858af9130b8.zip'
|
2015-10-27 23:43:06 +00:00
|
|
|
'#python-vera==0.1.1']
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-08 12:52:50 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-08 14:58:11 +00:00
|
|
|
|
2015-03-08 14:14:44 +00:00
|
|
|
# pylint: disable=unused-argument
|
2015-03-02 10:09:00 +00:00
|
|
|
def get_devices(hass, config):
|
|
|
|
""" Find and return Vera switches. """
|
2015-09-09 03:11:25 +00:00
|
|
|
import pyvera as veraApi
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-08 20:03:56 +00:00
|
|
|
base_url = config.get('vera_controller_url')
|
|
|
|
if not base_url:
|
|
|
|
_LOGGER.error(
|
|
|
|
"The required parameter 'vera_controller_url'"
|
|
|
|
" was not found in config"
|
|
|
|
)
|
|
|
|
return False
|
2015-03-08 12:52:50 +00:00
|
|
|
|
2015-03-08 21:34:06 +00:00
|
|
|
device_data = config.get('device_data', {})
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-08 20:03:56 +00:00
|
|
|
vera_controller = veraApi.VeraController(base_url)
|
|
|
|
devices = []
|
|
|
|
try:
|
2015-05-18 08:54:25 +00:00
|
|
|
devices = vera_controller.get_devices([
|
|
|
|
'Switch', 'Armable Sensor', 'On/Off Switch'])
|
2015-03-08 22:11:59 +00:00
|
|
|
except RequestException:
|
2015-08-08 17:09:37 +00:00
|
|
|
# There was a network related error connecting to the vera controller.
|
2015-03-08 22:11:59 +00:00
|
|
|
_LOGGER.exception("Error communicating with Vera API")
|
2015-03-02 10:09:00 +00:00
|
|
|
return False
|
|
|
|
|
2015-03-08 20:03:56 +00:00
|
|
|
vera_switches = []
|
|
|
|
for device in devices:
|
2015-03-08 22:11:59 +00:00
|
|
|
extra_data = device_data.get(device.deviceId, {})
|
|
|
|
exclude = extra_data.get('exclude', False)
|
2015-03-08 20:03:56 +00:00
|
|
|
|
|
|
|
if exclude is not True:
|
|
|
|
vera_switches.append(VeraSwitch(device, extra_data))
|
|
|
|
|
2015-03-02 10:09:00 +00:00
|
|
|
return vera_switches
|
|
|
|
|
2015-03-08 14:58:11 +00:00
|
|
|
|
2015-03-07 01:59:13 +00:00
|
|
|
def setup_platform(hass, config, add_devices, discovery_info=None):
|
2015-03-08 14:14:44 +00:00
|
|
|
""" Find and return Vera lights. """
|
2015-03-07 01:59:13 +00:00
|
|
|
add_devices(get_devices(hass, config))
|
2015-03-02 10:09:00 +00:00
|
|
|
|
2015-03-08 14:58:11 +00:00
|
|
|
|
2015-03-22 02:16:13 +00:00
|
|
|
class VeraSwitch(ToggleEntity):
|
2015-08-08 17:09:37 +00:00
|
|
|
""" Represents a Vera Switch. """
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
def __init__(self, vera_device, extra_data=None):
|
|
|
|
self.vera_device = vera_device
|
|
|
|
self.extra_data = extra_data
|
2015-03-08 20:15:41 +00:00
|
|
|
if self.extra_data and self.extra_data.get('name'):
|
|
|
|
self._name = self.extra_data.get('name')
|
2015-03-08 21:34:06 +00:00
|
|
|
else:
|
|
|
|
self._name = self.vera_device.name
|
2015-03-09 04:16:02 +00:00
|
|
|
self.is_on_status = False
|
|
|
|
# for debouncing status check after command is sent
|
|
|
|
self.last_command_send = 0
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
""" Get the mame of the switch. """
|
2015-03-08 20:15:41 +00:00
|
|
|
return self._name
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def state_attributes(self):
|
2015-09-27 16:06:49 +00:00
|
|
|
attr = super().state_attributes or {}
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
if self.vera_device.has_battery:
|
2015-03-08 20:11:35 +00:00
|
|
|
attr[ATTR_BATTERY_LEVEL] = self.vera_device.battery_level + '%'
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
if self.vera_device.is_armable:
|
|
|
|
armed = self.vera_device.refresh_value('Armed')
|
2015-03-08 21:10:31 +00:00
|
|
|
attr[ATTR_ARMED] = 'True' if armed == '1' else 'False'
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
if self.vera_device.is_trippable:
|
2015-03-08 14:14:44 +00:00
|
|
|
last_tripped = self.vera_device.refresh_value('LastTrip')
|
2015-05-18 08:54:25 +00:00
|
|
|
if last_tripped is not None:
|
|
|
|
utc_time = dt_util.utc_from_timestamp(int(last_tripped))
|
2015-05-18 14:31:59 +00:00
|
|
|
attr[ATTR_LAST_TRIP_TIME] = dt_util.datetime_to_str(
|
2015-05-18 08:54:25 +00:00
|
|
|
utc_time)
|
|
|
|
else:
|
|
|
|
attr[ATTR_LAST_TRIP_TIME] = None
|
2015-03-02 10:09:00 +00:00
|
|
|
tripped = self.vera_device.refresh_value('Tripped')
|
2015-03-08 21:10:31 +00:00
|
|
|
attr[ATTR_TRIPPED] = 'True' if tripped == '1' else 'False'
|
2015-03-02 10:09:00 +00:00
|
|
|
|
|
|
|
attr['Vera Device Id'] = self.vera_device.vera_device_id
|
|
|
|
|
|
|
|
return attr
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
self.last_command_send = time.time()
|
|
|
|
self.vera_device.switch_on()
|
|
|
|
self.is_on_status = True
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
|
|
|
self.last_command_send = time.time()
|
|
|
|
self.vera_device.switch_off()
|
|
|
|
self.is_on_status = False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
""" True if device is on. """
|
|
|
|
return self.is_on_status
|
|
|
|
|
|
|
|
def update(self):
|
2015-03-08 14:14:44 +00:00
|
|
|
# We need to debounce the status call after turning switch on or off
|
2015-03-02 10:09:00 +00:00
|
|
|
# because the vera has some lag in updating the device status
|
|
|
|
if (self.last_command_send + 5) < time.time():
|
|
|
|
self.is_on_status = self.vera_device.is_switched_on()
|