* Huge ISY994 platform cleanup, fixes support for 5.0.10 firmware # * No more globals - store on hass.data # * Parent ISY994 component handles categorizing nodes in to Hass components, rather than each individual domain filtering all nodes themselves # * Remove hidden string, replace with ignore string. Hidden should be done via the customize block; ignore fully prevents the node from getting a Hass entity # * Removed a few unused methods in the ISYDevice class # * Cleaned up the hostname parsing # * Removed broken logic in the fan Program component. It was setting properties that have no setters # * Added the missing SUPPORTED_FEATURES to the fan component to indicate that it can set speed # * Added better error handling and a log warning when an ISY994 program entity fails to initialize # * Cleaned up a few instances of unecessarily complicated logic paths, and other cases of unnecessary logic that is already handled by base classes * Use `super()` instead of explicit base class calls * Move `hass` argument to first position * Use str.format instead of string addition * Move program structure building and validation to component Removes the need for a bunch of duplicate exception handling in each individual platform * Fix climate nodes, fix climate names, add config to disable climate Sensor platform was crashing when the ISY reported climate nodes. Logic has been fixed. Also added a config option to prevent climate sensors from getting imported from the ISY. Also replace the underscore from climate node names with spaces so they default to friendly names. * Space missing in error message * Fix string comparison to use `==` * Explicitly check for attributes rather than catch AttributeError Also removes two stray debug lines * Remove null checks on hass.data, as they are always null at this point
78 lines
2.6 KiB
Python
78 lines
2.6 KiB
Python
"""
|
|
Support for ISY994 switches.
|
|
|
|
For more details about this platform, please refer to the documentation at
|
|
https://home-assistant.io/components/switch.isy994/
|
|
"""
|
|
import logging
|
|
from typing import Callable # noqa
|
|
|
|
from homeassistant.components.switch import SwitchDevice, DOMAIN
|
|
from homeassistant.components.isy994 import (ISY994_NODES, ISY994_PROGRAMS,
|
|
ISYDevice)
|
|
from homeassistant.helpers.typing import ConfigType # noqa
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
# pylint: disable=unused-argument
|
|
def setup_platform(hass, config: ConfigType,
|
|
add_devices: Callable[[list], None], discovery_info=None):
|
|
"""Set up the ISY994 switch platform."""
|
|
devices = []
|
|
for node in hass.data[ISY994_NODES][DOMAIN]:
|
|
if not node.dimmable:
|
|
devices.append(ISYSwitchDevice(node))
|
|
|
|
for name, status, actions in hass.data[ISY994_PROGRAMS][DOMAIN]:
|
|
devices.append(ISYSwitchProgram(name, status, actions))
|
|
|
|
add_devices(devices)
|
|
|
|
|
|
class ISYSwitchDevice(ISYDevice, SwitchDevice):
|
|
"""Representation of an ISY994 switch device."""
|
|
|
|
def __init__(self, node) -> None:
|
|
"""Initialize the ISY994 switch device."""
|
|
super().__init__(node)
|
|
|
|
@property
|
|
def is_on(self) -> bool:
|
|
"""Get whether the ISY994 device is in the on state."""
|
|
return bool(self.value)
|
|
|
|
def turn_off(self, **kwargs) -> None:
|
|
"""Send the turn on command to the ISY994 switch."""
|
|
if not self._node.off():
|
|
_LOGGER.debug('Unable to turn on switch.')
|
|
|
|
def turn_on(self, **kwargs) -> None:
|
|
"""Send the turn off command to the ISY994 switch."""
|
|
if not self._node.on():
|
|
_LOGGER.debug('Unable to turn on switch.')
|
|
|
|
|
|
class ISYSwitchProgram(ISYSwitchDevice):
|
|
"""A representation of an ISY994 program switch."""
|
|
|
|
def __init__(self, name: str, node, actions) -> None:
|
|
"""Initialize the ISY994 switch program."""
|
|
super().__init__(node)
|
|
self._name = name
|
|
self._actions = actions
|
|
|
|
@property
|
|
def is_on(self) -> bool:
|
|
"""Get whether the ISY994 switch program is on."""
|
|
return bool(self.value)
|
|
|
|
def turn_on(self, **kwargs) -> None:
|
|
"""Send the turn on command to the ISY994 switch program."""
|
|
if not self._actions.runThen():
|
|
_LOGGER.error('Unable to turn on switch')
|
|
|
|
def turn_off(self, **kwargs) -> None:
|
|
"""Send the turn off command to the ISY994 switch program."""
|
|
if not self._actions.runElse():
|
|
_LOGGER.error('Unable to turn off switch')
|