2020-04-30 12:23:30 +00:00
|
|
|
"""Switch platform integration for Numato USB GPIO expanders."""
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from numato_gpio import NumatoGpioError
|
|
|
|
|
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_DEVICES,
|
|
|
|
CONF_ID,
|
|
|
|
CONF_SWITCHES,
|
|
|
|
DEVICE_DEFAULT_NAME,
|
|
|
|
)
|
|
|
|
from homeassistant.helpers.entity import ToggleEntity
|
|
|
|
|
|
|
|
from . import CONF_INVERT_LOGIC, CONF_PORTS, DATA_API, DOMAIN
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_platform(hass, config, add_entities, discovery_info=None):
|
|
|
|
"""Set up the configured Numato USB GPIO switch ports."""
|
|
|
|
if discovery_info is None:
|
|
|
|
return
|
|
|
|
|
|
|
|
api = hass.data[DOMAIN][DATA_API]
|
|
|
|
switches = []
|
|
|
|
devices = hass.data[DOMAIN][CONF_DEVICES]
|
|
|
|
for device in [d for d in devices if CONF_SWITCHES in d]:
|
|
|
|
device_id = device[CONF_ID]
|
|
|
|
platform = device[CONF_SWITCHES]
|
|
|
|
invert_logic = platform[CONF_INVERT_LOGIC]
|
|
|
|
ports = platform[CONF_PORTS]
|
|
|
|
for port, port_name in ports.items():
|
|
|
|
try:
|
|
|
|
api.setup_output(device_id, port)
|
|
|
|
api.write_output(device_id, port, 1 if invert_logic else 0)
|
|
|
|
except NumatoGpioError as err:
|
|
|
|
_LOGGER.error(
|
|
|
|
"Failed to initialize switch '%s' on Numato device %s port %s: %s",
|
|
|
|
port_name,
|
|
|
|
device_id,
|
|
|
|
port,
|
|
|
|
err,
|
|
|
|
)
|
|
|
|
continue
|
|
|
|
switches.append(
|
2020-08-27 11:56:20 +00:00
|
|
|
NumatoGpioSwitch(
|
|
|
|
port_name,
|
|
|
|
device_id,
|
|
|
|
port,
|
|
|
|
invert_logic,
|
|
|
|
api,
|
|
|
|
)
|
2020-04-30 12:23:30 +00:00
|
|
|
)
|
|
|
|
add_entities(switches, True)
|
|
|
|
|
|
|
|
|
|
|
|
class NumatoGpioSwitch(ToggleEntity):
|
|
|
|
"""Representation of a Numato USB GPIO switch port."""
|
|
|
|
|
|
|
|
def __init__(self, name, device_id, port, invert_logic, api):
|
|
|
|
"""Initialize the port."""
|
|
|
|
self._name = name or DEVICE_DEFAULT_NAME
|
|
|
|
self._device_id = device_id
|
|
|
|
self._port = port
|
|
|
|
self._invert_logic = invert_logic
|
|
|
|
self._state = False
|
|
|
|
self._api = api
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of the switch."""
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def should_poll(self):
|
|
|
|
"""No polling needed."""
|
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
"""Return true if port is turned on."""
|
|
|
|
return self._state
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
"""Turn the port on."""
|
|
|
|
try:
|
|
|
|
self._api.write_output(
|
|
|
|
self._device_id, self._port, 0 if self._invert_logic else 1
|
|
|
|
)
|
|
|
|
self._state = True
|
|
|
|
self.schedule_update_ha_state()
|
|
|
|
except NumatoGpioError as err:
|
|
|
|
_LOGGER.error(
|
|
|
|
"Failed to turn on Numato device %s port %s: %s",
|
|
|
|
self._device_id,
|
|
|
|
self._port,
|
|
|
|
err,
|
|
|
|
)
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
|
|
|
"""Turn the port off."""
|
|
|
|
try:
|
|
|
|
self._api.write_output(
|
|
|
|
self._device_id, self._port, 1 if self._invert_logic else 0
|
|
|
|
)
|
|
|
|
self._state = False
|
|
|
|
self.schedule_update_ha_state()
|
|
|
|
except NumatoGpioError as err:
|
|
|
|
_LOGGER.error(
|
|
|
|
"Failed to turn off Numato device %s port %s: %s",
|
|
|
|
self._device_id,
|
|
|
|
self._port,
|
|
|
|
err,
|
|
|
|
)
|