hass_flickerstrip/custom_components/flickerstrip/__init__.py

53 lines
1.4 KiB
Python
Raw Normal View History

2023-01-30 12:14:08 -05:00
from dataclasses import dataclass
from flickerstrip_py import Flickerstrip
import logging
from homeassistant.config_entries import ConfigEntry, ConfigEntryError
2023-01-29 13:29:34 -05:00
from homeassistant.const import CONF_HOST, CONF_PORT
from homeassistant.core import HomeAssistant
2023-01-29 09:34:51 -05:00
2023-01-29 13:29:34 -05:00
from .const import (
DOMAIN,
2023-01-30 12:14:08 -05:00
PLATFORMS,
2023-01-29 13:29:34 -05:00
)
2023-01-30 12:14:08 -05:00
_LOGGER = logging.getLogger(__name__)
2023-01-29 13:29:34 -05:00
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
"""Setup flickerstrip from config entry."""
2023-01-30 12:14:08 -05:00
strip = Flickerstrip(
2023-01-29 13:29:34 -05:00
host=entry.data[CONF_HOST],
port=entry.data[CONF_PORT],
)
2023-01-30 12:14:08 -05:00
if not await strip.force_update():
_LOGGER.error("Unable to connect to flickerstrip")
raise ConfigEntryError("Unable to connect to flickerstrip")
hass.data.setdefault(DOMAIN, {})
hass.data[DOMAIN][entry.entry_id] = FlickerstripData(strip=strip)
for platform in PLATFORMS:
hass.async_create_task(
hass.config_entries.async_forward_entry_setup(entry, platform)
)
2023-01-29 13:29:34 -05:00
entry.async_on_unload(entry.add_update_listener(update_listener))
2023-01-29 09:34:51 -05:00
return True
2023-01-29 13:29:34 -05:00
async def update_listener(hass: HomeAssistant, entry: ConfigEntry) -> None:
"""Update when config_entry options update."""
2023-01-30 12:14:08 -05:00
await hass.config_entries.async_reload(entry.entry_id)
@dataclass
class FlickerstripData:
"""Data for the Flickerstrip integration."""
strip: Flickerstrip