2019-02-14 04:35:12 +00:00
|
|
|
"""Support for Lutron Caseta switches."""
|
2017-03-23 00:18:14 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
from homeassistant.components.lutron_caseta import (
|
|
|
|
LUTRON_CASETA_SMARTBRIDGE, LutronCasetaDevice)
|
2017-09-05 09:30:36 +00:00
|
|
|
from homeassistant.components.switch import SwitchDevice, DOMAIN
|
2017-03-23 00:18:14 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
DEPENDENCIES = ['lutron_caseta']
|
|
|
|
|
|
|
|
|
2019-02-14 04:35:12 +00:00
|
|
|
async def async_setup_platform(
|
|
|
|
hass, config, async_add_entities, discovery_info=None):
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Set up Lutron switch."""
|
2017-03-23 00:18:14 +00:00
|
|
|
devs = []
|
|
|
|
bridge = hass.data[LUTRON_CASETA_SMARTBRIDGE]
|
2017-09-05 09:30:36 +00:00
|
|
|
switch_devices = bridge.get_devices_by_domain(DOMAIN)
|
2017-03-23 00:18:14 +00:00
|
|
|
|
|
|
|
for switch_device in switch_devices:
|
|
|
|
dev = LutronCasetaLight(switch_device, bridge)
|
|
|
|
devs.append(dev)
|
|
|
|
|
2018-08-24 14:37:30 +00:00
|
|
|
async_add_entities(devs, True)
|
2017-03-23 00:18:14 +00:00
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
class LutronCasetaLight(LutronCasetaDevice, SwitchDevice):
|
|
|
|
"""Representation of a Lutron Caseta switch."""
|
|
|
|
|
2018-10-01 06:55:00 +00:00
|
|
|
async def async_turn_on(self, **kwargs):
|
2017-03-23 00:18:14 +00:00
|
|
|
"""Turn the switch on."""
|
|
|
|
self._smartbridge.turn_on(self._device_id)
|
|
|
|
|
2018-10-01 06:55:00 +00:00
|
|
|
async def async_turn_off(self, **kwargs):
|
2017-03-23 00:18:14 +00:00
|
|
|
"""Turn the switch off."""
|
|
|
|
self._smartbridge.turn_off(self._device_id)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
"""Return true if device is on."""
|
|
|
|
return self._state["current_state"] > 0
|
|
|
|
|
2018-10-01 06:55:00 +00:00
|
|
|
async def async_update(self):
|
2017-05-02 20:47:20 +00:00
|
|
|
"""Update when forcing a refresh of the device."""
|
2017-03-23 00:18:14 +00:00
|
|
|
self._state = self._smartbridge.get_device_by_id(self._device_id)
|
|
|
|
_LOGGER.debug(self._state)
|