core/homeassistant/components/epson/__init__.py

71 lines
2.2 KiB
Python
Raw Normal View History

"""The epson integration."""
import asyncio
import logging
from epson_projector import Projector
from epson_projector.const import POWER, STATE_UNAVAILABLE as EPSON_STATE_UNAVAILABLE
from homeassistant.components.media_player import DOMAIN as MEDIA_PLAYER_PLATFORM
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import CONF_HOST, CONF_PORT
from homeassistant.core import HomeAssistant
from homeassistant.helpers.aiohttp_client import async_get_clientsession
from .const import DOMAIN
from .exceptions import CannotConnect
PLATFORMS = [MEDIA_PLAYER_PLATFORM]
_LOGGER = logging.getLogger(__name__)
async def validate_projector(hass: HomeAssistant, host, port):
"""Validate the given host and port allows us to connect."""
epson_proj = Projector(
host=host,
websession=async_get_clientsession(hass, verify_ssl=False),
port=port,
)
_power = await epson_proj.get_property(POWER)
if not _power or _power == EPSON_STATE_UNAVAILABLE:
raise CannotConnect
return epson_proj
async def async_setup(hass: HomeAssistant, config: dict):
"""Set up the epson component."""
hass.data.setdefault(DOMAIN, {})
return True
async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry):
"""Set up epson from a config entry."""
try:
projector = await validate_projector(
hass, entry.data[CONF_HOST], entry.data[CONF_PORT]
)
except CannotConnect:
_LOGGER.warning("Cannot connect to projector %s", entry.data[CONF_HOST])
return False
hass.data[DOMAIN][entry.entry_id] = projector
for component in PLATFORMS:
hass.async_create_task(
hass.config_entries.async_forward_entry_setup(entry, component)
)
return True
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry):
"""Unload a config entry."""
unload_ok = all(
await asyncio.gather(
*[
hass.config_entries.async_forward_entry_unload(entry, component)
for component in PLATFORMS
]
)
)
if unload_ok:
hass.data[DOMAIN].pop(entry.entry_id)
return unload_ok