2016-01-09 13:51:49 +00:00
|
|
|
"""
|
|
|
|
Support for SCSGate lights.
|
|
|
|
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
|
|
https://home-assistant.io/components/light.scsgate/
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
|
2016-02-19 05:27:50 +00:00
|
|
|
import homeassistant.components.scsgate as scsgate
|
2016-01-09 13:51:49 +00:00
|
|
|
from homeassistant.components.light import Light
|
|
|
|
from homeassistant.const import ATTR_ENTITY_ID
|
|
|
|
|
|
|
|
DEPENDENCIES = ['scsgate']
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_devices_callback, discovery_info=None):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Add the SCSGate swiches defined inside of the configuration file."""
|
2016-01-09 13:51:49 +00:00
|
|
|
devices = config.get('devices')
|
|
|
|
lights = []
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
if devices:
|
|
|
|
for _, entity_info in devices.items():
|
|
|
|
if entity_info['scs_id'] in scsgate.SCSGATE.devices:
|
|
|
|
continue
|
|
|
|
|
|
|
|
logger.info("Adding %s scsgate.light", entity_info['name'])
|
|
|
|
|
|
|
|
name = entity_info['name']
|
|
|
|
scs_id = entity_info['scs_id']
|
|
|
|
light = SCSGateLight(
|
|
|
|
name=name,
|
|
|
|
scs_id=scs_id,
|
|
|
|
logger=logger)
|
|
|
|
lights.append(light)
|
|
|
|
|
|
|
|
add_devices_callback(lights)
|
|
|
|
scsgate.SCSGATE.add_devices_to_register(lights)
|
|
|
|
|
|
|
|
|
|
|
|
class SCSGateLight(Light):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""representation of a SCSGate light."""
|
|
|
|
|
2016-01-09 13:51:49 +00:00
|
|
|
def __init__(self, scs_id, name, logger):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Initialize the light."""
|
2016-01-09 13:51:49 +00:00
|
|
|
self._name = name
|
|
|
|
self._scs_id = scs_id
|
|
|
|
self._toggled = False
|
|
|
|
self._logger = logger
|
|
|
|
|
|
|
|
@property
|
|
|
|
def scs_id(self):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Return the SCS ID."""
|
2016-01-09 13:51:49 +00:00
|
|
|
return self._scs_id
|
|
|
|
|
|
|
|
@property
|
|
|
|
def should_poll(self):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""No polling needed for a SCSGate light."""
|
2016-01-09 13:51:49 +00:00
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Return the name of the device if any."""
|
2016-01-09 13:51:49 +00:00
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Return true if light is on."""
|
2016-01-09 13:51:49 +00:00
|
|
|
return self._toggled
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Turn the device on."""
|
2016-01-09 13:51:49 +00:00
|
|
|
from scsgate.tasks import ToggleStatusTask
|
|
|
|
|
|
|
|
scsgate.SCSGATE.append_task(
|
|
|
|
ToggleStatusTask(
|
|
|
|
target=self._scs_id,
|
|
|
|
toggled=True))
|
|
|
|
|
|
|
|
self._toggled = True
|
|
|
|
self.update_ha_state()
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Turn the device off."""
|
2016-01-09 13:51:49 +00:00
|
|
|
from scsgate.tasks import ToggleStatusTask
|
|
|
|
|
|
|
|
scsgate.SCSGATE.append_task(
|
|
|
|
ToggleStatusTask(
|
|
|
|
target=self._scs_id,
|
|
|
|
toggled=False))
|
|
|
|
|
|
|
|
self._toggled = False
|
|
|
|
self.update_ha_state()
|
|
|
|
|
|
|
|
def process_event(self, message):
|
2016-03-07 21:08:21 +00:00
|
|
|
"""Handle a SCSGate message related with this light."""
|
2016-01-09 13:51:49 +00:00
|
|
|
if self._toggled == message.toggled:
|
|
|
|
self._logger.info(
|
|
|
|
"Light %s, ignoring message %s because state already active",
|
|
|
|
self._scs_id, message)
|
|
|
|
# Nothing changed, ignoring
|
|
|
|
return
|
|
|
|
|
|
|
|
self._toggled = message.toggled
|
|
|
|
self.update_ha_state()
|
|
|
|
|
|
|
|
command = "off"
|
|
|
|
if self._toggled:
|
|
|
|
command = "on"
|
|
|
|
|
|
|
|
self.hass.bus.fire(
|
|
|
|
'button_pressed', {
|
|
|
|
ATTR_ENTITY_ID: self._scs_id,
|
|
|
|
'state': command
|
|
|
|
}
|
|
|
|
)
|