core/homeassistant/components/bloomsky/camera.py

67 lines
2.2 KiB
Python
Raw Normal View History

"""Support for a camera of a BloomSky weather station."""
from __future__ import annotations
2016-02-04 20:01:45 +00:00
import logging
2016-02-19 05:27:50 +00:00
2016-02-04 20:01:45 +00:00
import requests
2016-02-19 05:27:50 +00:00
2016-02-04 20:01:45 +00:00
from homeassistant.components.camera import Camera
from homeassistant.core import HomeAssistant
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from homeassistant.helpers.typing import ConfigType, DiscoveryInfoType
2016-02-04 20:01:45 +00:00
from . import DOMAIN
2016-02-04 20:01:45 +00:00
def setup_platform(
hass: HomeAssistant,
config: ConfigType,
add_entities: AddEntitiesCallback,
discovery_info: DiscoveryInfoType | None = None,
) -> None:
"""Set up access to BloomSky cameras."""
if discovery_info is not None:
return
bloomsky = hass.data[DOMAIN]
for device in bloomsky.devices.values():
add_entities([BloomSkyCamera(bloomsky, device)])
2016-02-04 20:01:45 +00:00
class BloomSkyCamera(Camera):
2016-03-07 19:29:54 +00:00
"""Representation of the images published from the BloomSky's camera."""
2016-02-04 20:01:45 +00:00
def __init__(self, bs, device):
"""Initialize access to the BloomSky camera images."""
super().__init__()
self._attr_name = device["DeviceName"]
2019-07-31 19:25:30 +00:00
self._id = device["DeviceID"]
2016-02-04 20:01:45 +00:00
self._bloomsky = bs
self._url = ""
self._last_url = ""
# last_image will store images as they are downloaded so that the
2016-02-04 20:01:45 +00:00
# frequent updates in home-assistant don't keep poking the server
2016-03-07 16:45:06 +00:00
# to download the same image over and over.
2016-02-04 20:01:45 +00:00
self._last_image = ""
self._logger = logging.getLogger(__name__)
self._attr_unique_id = self._id
2016-02-04 20:01:45 +00:00
def camera_image(
self, width: int | None = None, height: int | None = None
) -> bytes | None:
2016-03-07 16:45:06 +00:00
"""Update the camera's image if it has changed."""
2016-02-04 20:01:45 +00:00
try:
2019-07-31 19:25:30 +00:00
self._url = self._bloomsky.devices[self._id]["Data"]["ImageURL"]
2016-02-04 20:01:45 +00:00
self._bloomsky.refresh_devices()
2016-03-07 16:45:06 +00:00
# If the URL hasn't changed then the image hasn't changed.
2016-02-04 20:01:45 +00:00
if self._url != self._last_url:
response = requests.get(self._url, timeout=10)
self._last_url = self._url
self._last_image = response.content
except requests.exceptions.RequestException as error:
self._logger.error("Error getting bloomsky image: %s", error)
return None
return self._last_image