2019-02-13 20:21:14 +00:00
|
|
|
"""Support for Verisure cameras."""
|
2016-10-22 19:01:12 +00:00
|
|
|
import errno
|
2016-10-21 20:41:17 +00:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
|
|
|
|
from homeassistant.components.camera import Camera
|
|
|
|
from homeassistant.const import EVENT_HOMEASSISTANT_STOP
|
2019-03-21 05:56:46 +00:00
|
|
|
|
|
|
|
from . import CONF_SMARTCAM, HUB as hub
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2018-08-24 14:37:30 +00:00
|
|
|
def setup_platform(hass, config, add_entities, discovery_info=None):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Set up the Verisure Camera."""
|
2016-10-21 20:41:17 +00:00
|
|
|
if not int(hub.config.get(CONF_SMARTCAM, 1)):
|
|
|
|
return False
|
|
|
|
directory_path = hass.config.config_dir
|
|
|
|
if not os.access(directory_path, os.R_OK):
|
|
|
|
_LOGGER.error("file path %s is not readable", directory_path)
|
|
|
|
return False
|
2017-06-26 20:30:25 +00:00
|
|
|
hub.update_overview()
|
2016-10-21 20:41:17 +00:00
|
|
|
smartcams = []
|
2019-07-31 19:25:30 +00:00
|
|
|
smartcams.extend(
|
|
|
|
[
|
|
|
|
VerisureSmartcam(hass, device_label, directory_path)
|
|
|
|
for device_label in hub.get("$.customerImageCameras[*].deviceLabel")
|
|
|
|
]
|
|
|
|
)
|
2018-08-24 14:37:30 +00:00
|
|
|
add_entities(smartcams)
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
class VerisureSmartcam(Camera):
|
2017-04-30 05:04:49 +00:00
|
|
|
"""Representation of a Verisure camera."""
|
2016-10-21 20:41:17 +00:00
|
|
|
|
2017-06-26 20:30:25 +00:00
|
|
|
def __init__(self, hass, device_label, directory_path):
|
2016-10-21 20:41:17 +00:00
|
|
|
"""Initialize Verisure File Camera component."""
|
|
|
|
super().__init__()
|
|
|
|
|
2017-06-26 20:30:25 +00:00
|
|
|
self._device_label = device_label
|
2016-10-21 20:41:17 +00:00
|
|
|
self._directory_path = directory_path
|
|
|
|
self._image = None
|
|
|
|
self._image_id = None
|
2019-07-31 19:25:30 +00:00
|
|
|
hass.bus.listen_once(EVENT_HOMEASSISTANT_STOP, self.delete_image)
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
def camera_image(self):
|
|
|
|
"""Return image response."""
|
|
|
|
self.check_imagelist()
|
|
|
|
if not self._image:
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("No image to display")
|
2016-10-21 20:41:17 +00:00
|
|
|
return
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("Trying to open %s", self._image)
|
2019-07-31 19:25:30 +00:00
|
|
|
with open(self._image, "rb") as file:
|
2016-10-21 20:41:17 +00:00
|
|
|
return file.read()
|
|
|
|
|
|
|
|
def check_imagelist(self):
|
|
|
|
"""Check the contents of the image list."""
|
2017-06-26 20:30:25 +00:00
|
|
|
hub.update_smartcam_imageseries()
|
|
|
|
image_ids = hub.get_image_info(
|
2019-07-31 19:25:30 +00:00
|
|
|
"$.imageSeries[?(@.deviceLabel=='%s')].image[0].imageId", self._device_label
|
|
|
|
)
|
2017-06-26 20:30:25 +00:00
|
|
|
if not image_ids:
|
2016-10-21 20:41:17 +00:00
|
|
|
return
|
2017-06-26 20:30:25 +00:00
|
|
|
new_image_id = image_ids[0]
|
2019-07-31 19:25:30 +00:00
|
|
|
if new_image_id in ("-1", self._image_id):
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("The image is the same, or loading image_id")
|
2016-10-21 20:41:17 +00:00
|
|
|
return
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("Download new image %s", new_image_id)
|
2017-06-26 20:30:25 +00:00
|
|
|
new_image_path = os.path.join(
|
2019-07-31 19:25:30 +00:00
|
|
|
self._directory_path, "{}{}".format(new_image_id, ".jpg")
|
|
|
|
)
|
|
|
|
hub.session.download_image(self._device_label, new_image_id, new_image_path)
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("Old image_id=%s", self._image_id)
|
2016-10-22 19:01:12 +00:00
|
|
|
self.delete_image(self)
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
self._image_id = new_image_id
|
2017-06-26 20:30:25 +00:00
|
|
|
self._image = new_image_path
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
def delete_image(self, event):
|
|
|
|
"""Delete an old image."""
|
2017-04-30 05:04:49 +00:00
|
|
|
remove_image = os.path.join(
|
2019-07-31 19:25:30 +00:00
|
|
|
self._directory_path, "{}{}".format(self._image_id, ".jpg")
|
|
|
|
)
|
2016-10-22 19:01:12 +00:00
|
|
|
try:
|
|
|
|
os.remove(remove_image)
|
2017-04-30 05:04:49 +00:00
|
|
|
_LOGGER.debug("Deleting old image %s", remove_image)
|
2016-10-22 19:01:12 +00:00
|
|
|
except OSError as error:
|
|
|
|
if error.errno != errno.ENOENT:
|
|
|
|
raise
|
2016-10-21 20:41:17 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the name of this camera."""
|
2017-06-26 20:30:25 +00:00
|
|
|
return hub.get_first(
|
2019-07-31 19:25:30 +00:00
|
|
|
"$.customerImageCameras[?(@.deviceLabel=='%s')].area", self._device_label
|
|
|
|
)
|