1
0
mirror of https://github.com/home-assistant/core.git synced 2025-12-26 22:18:40 +00:00
Files
core/homeassistant/components/niko_home_control/light.py
Dries De Peuter 45e5f5de78 Fix niko_home_control integration (#23093)
Update base library and only pull for state once.
2019-04-16 11:47:16 -07:00

144 lines
4.6 KiB
Python

"""Support for Niko Home Control."""
from datetime import timedelta
import logging
import voluptuous as vol
# Import the device class from the component that you want to support
from homeassistant.components.light import (
ATTR_BRIGHTNESS, PLATFORM_SCHEMA, Light)
from homeassistant.const import CONF_HOST, CONF_SCAN_INTERVAL
from homeassistant.exceptions import PlatformNotReady
import homeassistant.helpers.config_validation as cv
from homeassistant.util import Throttle
_LOGGER = logging.getLogger(__name__)
MIN_TIME_BETWEEN_UPDATES = timedelta(seconds=1)
SCAN_INTERVAL = timedelta(seconds=30)
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Required(CONF_HOST): cv.string,
vol.Optional(CONF_SCAN_INTERVAL, default=SCAN_INTERVAL): cv.time_period,
})
async def async_setup_platform(
hass, config, async_add_entities, discovery_info=None):
"""Set up the Niko Home Control light platform."""
import nikohomecontrol
host = config[CONF_HOST]
try:
nhc = nikohomecontrol.NikoHomeControl({
'ip': host,
'port': 8000,
'timeout': 20000
})
niko_data = NikoHomeControlData(hass, nhc)
await niko_data.async_update()
except OSError as err:
_LOGGER.error("Unable to access %s (%s)", host, err)
raise PlatformNotReady
async_add_entities([
NikoHomeControlLight(light, niko_data) for light in nhc.list_actions()
], True)
class NikoHomeControlLight(Light):
"""Representation of an Niko Light."""
def __init__(self, light, data):
"""Set up the Niko Home Control light platform."""
self._data = data
self._light = light
self._unique_id = "light-{}".format(light.id)
self._name = light.name
self._state = light.is_on
self._brightness = None
_LOGGER.debug("Init new light: %s", light.name)
@property
def unique_id(self):
"""Return unique ID for light."""
return self._unique_id
@property
def device_info(self):
"""Return device info for light."""
return {
'identifiers': {
('niko_home_control', self.unique_id)
},
'name': self.name,
'manufacturer': 'Niko group nv',
'model': 'Niko connected controller',
'sw_version': self._data.info_swversion(self._light),
'via_hub': ('niko_home_control'),
}
@property
def name(self):
"""Return the display name of this light."""
return self._name
@property
def brightness(self):
"""Return the brightness of the light."""
return self._brightness
@property
def is_on(self):
"""Return true if light is on."""
return self._state
async def async_turn_on(self, **kwargs):
"""Instruct the light to turn on."""
self._light.brightness = kwargs.get(ATTR_BRIGHTNESS, 255)
_LOGGER.debug('Turn on: %s', self.name)
await self._data.hass.async_add_executor_job(self._light.turn_on)
async def async_turn_off(self, **kwargs):
"""Instruct the light to turn off."""
_LOGGER.debug('Turn off: %s', self.name)
await self._data.hass.async_add_executor_job(self._light.turn_off)
async def async_update(self):
"""Get the latest data from NikoHomeControl API."""
await self._data.async_update()
self._state = self._data.get_state(self._light.id)
class NikoHomeControlData:
"""The class for handling data retrieval."""
def __init__(self, hass, nhc):
"""Set up Niko Home Control Data object."""
self._nhc = nhc
self.hass = hass
self.available = True
self.data = {}
self._system_info = None
@Throttle(MIN_TIME_BETWEEN_UPDATES)
async def async_update(self):
"""Get the latest data from the NikoHomeControl API."""
_LOGGER.debug('Fetching async state in bulk')
try:
self.data = await self.hass.async_add_executor_job(
self._nhc.list_actions_raw)
self.available = True
except OSError as ex:
_LOGGER.error("Unable to retrieve data from Niko, %s", str(ex))
self.available = False
def get_state(self, aid):
"""Find and filter state based on action id."""
return next(filter(lambda a: a['id'] == aid, self.data))['value1'] != 0
def info_swversion(self, light):
"""Return software version information."""
if self._system_info is None:
self._system_info = self._nhc.system_info()
return self._system_info['swversion']