2019-05-07 16:39:42 +00:00
|
|
|
"""Services for the HEOS integration."""
|
|
|
|
import functools
|
|
|
|
import logging
|
|
|
|
|
2019-08-25 18:57:43 +00:00
|
|
|
from pyheos import CommandFailedError, Heos, HeosError, const
|
2019-05-07 16:39:42 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2021-04-23 07:49:02 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2019-05-07 16:39:42 +00:00
|
|
|
from homeassistant.helpers import config_validation as cv
|
|
|
|
|
|
|
|
from .const import (
|
2019-07-31 19:25:30 +00:00
|
|
|
ATTR_PASSWORD,
|
|
|
|
ATTR_USERNAME,
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_SIGN_IN,
|
|
|
|
SERVICE_SIGN_OUT,
|
|
|
|
)
|
2019-05-07 16:39:42 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
HEOS_SIGN_IN_SCHEMA = vol.Schema(
|
|
|
|
{vol.Required(ATTR_USERNAME): cv.string, vol.Required(ATTR_PASSWORD): cv.string}
|
|
|
|
)
|
2019-05-07 16:39:42 +00:00
|
|
|
|
|
|
|
HEOS_SIGN_OUT_SCHEMA = vol.Schema({})
|
|
|
|
|
|
|
|
|
2021-04-23 07:49:02 +00:00
|
|
|
def register(hass: HomeAssistant, controller: Heos):
|
2019-05-07 16:39:42 +00:00
|
|
|
"""Register HEOS services."""
|
|
|
|
hass.services.async_register(
|
2019-07-31 19:25:30 +00:00
|
|
|
DOMAIN,
|
|
|
|
SERVICE_SIGN_IN,
|
2019-05-07 16:39:42 +00:00
|
|
|
functools.partial(_sign_in_handler, controller),
|
2019-07-31 19:25:30 +00:00
|
|
|
schema=HEOS_SIGN_IN_SCHEMA,
|
|
|
|
)
|
2019-05-07 16:39:42 +00:00
|
|
|
hass.services.async_register(
|
2019-07-31 19:25:30 +00:00
|
|
|
DOMAIN,
|
|
|
|
SERVICE_SIGN_OUT,
|
2019-05-07 16:39:42 +00:00
|
|
|
functools.partial(_sign_out_handler, controller),
|
2019-07-31 19:25:30 +00:00
|
|
|
schema=HEOS_SIGN_OUT_SCHEMA,
|
|
|
|
)
|
2019-05-07 16:39:42 +00:00
|
|
|
|
|
|
|
|
2021-04-23 07:49:02 +00:00
|
|
|
def remove(hass: HomeAssistant):
|
2019-05-07 16:39:42 +00:00
|
|
|
"""Unregister HEOS services."""
|
|
|
|
hass.services.async_remove(DOMAIN, SERVICE_SIGN_IN)
|
|
|
|
hass.services.async_remove(DOMAIN, SERVICE_SIGN_OUT)
|
|
|
|
|
|
|
|
|
|
|
|
async def _sign_in_handler(controller, service):
|
|
|
|
"""Sign in to the HEOS account."""
|
|
|
|
if controller.connection_state != const.STATE_CONNECTED:
|
|
|
|
_LOGGER.error("Unable to sign in because HEOS is not connected")
|
|
|
|
return
|
|
|
|
username = service.data[ATTR_USERNAME]
|
|
|
|
password = service.data[ATTR_PASSWORD]
|
|
|
|
try:
|
|
|
|
await controller.sign_in(username, password)
|
2019-08-25 18:57:43 +00:00
|
|
|
except CommandFailedError as err:
|
2019-05-07 16:39:42 +00:00
|
|
|
_LOGGER.error("Sign in failed: %s", err)
|
2019-08-25 18:57:43 +00:00
|
|
|
except HeosError as err:
|
2019-05-07 16:39:42 +00:00
|
|
|
_LOGGER.error("Unable to sign in: %s", err)
|
|
|
|
|
|
|
|
|
|
|
|
async def _sign_out_handler(controller, service):
|
|
|
|
"""Sign out of the HEOS account."""
|
|
|
|
if controller.connection_state != const.STATE_CONNECTED:
|
|
|
|
_LOGGER.error("Unable to sign out because HEOS is not connected")
|
|
|
|
return
|
|
|
|
try:
|
|
|
|
await controller.sign_out()
|
2019-08-25 18:57:43 +00:00
|
|
|
except HeosError as err:
|
2019-05-07 16:39:42 +00:00
|
|
|
_LOGGER.error("Unable to sign out: %s", err)
|