2019-02-13 20:21:14 +00:00
|
|
|
"""Support for LIFX Cloud scenes."""
|
2024-03-08 14:01:29 +00:00
|
|
|
|
2022-01-04 10:30:13 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2017-04-16 23:40:12 +00:00
|
|
|
import asyncio
|
2021-10-22 21:06:18 +00:00
|
|
|
from http import HTTPStatus
|
2017-04-16 23:40:12 +00:00
|
|
|
import logging
|
2020-04-21 01:07:50 +00:00
|
|
|
from typing import Any
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
import aiohttp
|
2017-11-04 19:04:05 +00:00
|
|
|
from aiohttp.hdrs import AUTHORIZATION
|
|
|
|
import voluptuous as vol
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
from homeassistant.components.scene import Scene
|
2021-10-22 21:06:18 +00:00
|
|
|
from homeassistant.const import CONF_PLATFORM, CONF_TIMEOUT, CONF_TOKEN
|
2022-01-04 10:30:13 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2017-11-04 19:04:05 +00:00
|
|
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
2017-04-16 23:40:12 +00:00
|
|
|
import homeassistant.helpers.config_validation as cv
|
2022-01-04 10:30:13 +00:00
|
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|
|
|
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
DEFAULT_TIMEOUT = 10
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA = vol.Schema(
|
|
|
|
{
|
|
|
|
vol.Required(CONF_PLATFORM): "lifx_cloud",
|
|
|
|
vol.Required(CONF_TOKEN): cv.string,
|
|
|
|
vol.Optional(CONF_TIMEOUT, default=DEFAULT_TIMEOUT): cv.positive_int,
|
|
|
|
}
|
|
|
|
)
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
|
2022-01-04 10:30:13 +00:00
|
|
|
async def async_setup_platform(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
config: ConfigType,
|
|
|
|
async_add_entities: AddEntitiesCallback,
|
|
|
|
discovery_info: DiscoveryInfoType | None = None,
|
|
|
|
) -> None:
|
2017-05-02 16:18:47 +00:00
|
|
|
"""Set up the scenes stored in the LIFX Cloud."""
|
2017-04-16 23:40:12 +00:00
|
|
|
token = config.get(CONF_TOKEN)
|
|
|
|
timeout = config.get(CONF_TIMEOUT)
|
|
|
|
|
2019-09-03 19:14:00 +00:00
|
|
|
headers = {AUTHORIZATION: f"Bearer {token}"}
|
2017-04-16 23:40:12 +00:00
|
|
|
|
2020-02-28 11:39:29 +00:00
|
|
|
url = "https://api.lifx.com/v1/scenes"
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
try:
|
|
|
|
httpsession = async_get_clientsession(hass)
|
2023-08-15 12:32:15 +00:00
|
|
|
async with asyncio.timeout(timeout):
|
2018-10-01 06:56:50 +00:00
|
|
|
scenes_resp = await httpsession.get(url, headers=headers)
|
2017-04-16 23:40:12 +00:00
|
|
|
|
2024-02-05 11:08:18 +00:00
|
|
|
except (TimeoutError, aiohttp.ClientError):
|
2017-04-16 23:40:12 +00:00
|
|
|
_LOGGER.exception("Error on %s", url)
|
2022-01-04 10:30:13 +00:00
|
|
|
return
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
status = scenes_resp.status
|
2021-10-22 21:06:18 +00:00
|
|
|
if status == HTTPStatus.OK:
|
2018-10-01 06:56:50 +00:00
|
|
|
data = await scenes_resp.json()
|
2020-04-21 01:07:50 +00:00
|
|
|
devices = [LifxCloudScene(hass, headers, timeout, scene) for scene in data]
|
2018-08-24 14:37:30 +00:00
|
|
|
async_add_entities(devices)
|
2022-01-04 10:30:13 +00:00
|
|
|
return
|
2021-10-22 21:06:18 +00:00
|
|
|
if status == HTTPStatus.UNAUTHORIZED:
|
2017-04-16 23:40:12 +00:00
|
|
|
_LOGGER.error("Unauthorized (bad token?) on %s", url)
|
2022-01-04 10:30:13 +00:00
|
|
|
return
|
2017-07-06 06:30:01 +00:00
|
|
|
|
|
|
|
_LOGGER.error("HTTP error %d on %s", scenes_resp.status, url)
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LifxCloudScene(Scene):
|
|
|
|
"""Representation of a LIFX Cloud scene."""
|
|
|
|
|
|
|
|
def __init__(self, hass, headers, timeout, scene_data):
|
|
|
|
"""Initialize the scene."""
|
|
|
|
self.hass = hass
|
|
|
|
self._headers = headers
|
|
|
|
self._timeout = timeout
|
|
|
|
self._name = scene_data["name"]
|
|
|
|
self._uuid = scene_data["uuid"]
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of the scene."""
|
|
|
|
return self._name
|
|
|
|
|
2020-04-21 01:07:50 +00:00
|
|
|
async def async_activate(self, **kwargs: Any) -> None:
|
2017-04-16 23:40:12 +00:00
|
|
|
"""Activate the scene."""
|
2020-02-28 11:39:29 +00:00
|
|
|
url = f"https://api.lifx.com/v1/scenes/scene_id:{self._uuid}/activate"
|
2017-04-16 23:40:12 +00:00
|
|
|
|
|
|
|
try:
|
|
|
|
httpsession = async_get_clientsession(self.hass)
|
2023-08-15 12:32:15 +00:00
|
|
|
async with asyncio.timeout(self._timeout):
|
2018-10-01 06:56:50 +00:00
|
|
|
await httpsession.put(url, headers=self._headers)
|
2017-04-16 23:40:12 +00:00
|
|
|
|
2024-02-05 11:08:18 +00:00
|
|
|
except (TimeoutError, aiohttp.ClientError):
|
2017-04-16 23:40:12 +00:00
|
|
|
_LOGGER.exception("Error on %s", url)
|