* Add amcrest camera services and deprecate switches - Implement enabling and disabling motion detection from camera platform. - Add amcrest specific camera services for controlling audio stream, motion recording, continuous recording and camera color mode, as well as moving camera to PTZ preset and starting and stopping PTZ tour function. - Add camera attributes to indicate the state of the various camera settings controlled by the new services. - Deprecate switches in favor of camera services and attributes. * Rename services and move service handling to __init__.py Rename services from 'camera.amcrest_xxx' to 'amcrest.xxx'. This allows services to be documented in services.yaml. Add services.yaml. Reorganize hass.data[DATA_AMCREST] and do some general cleanup to make various platform modules more consistent. Move service handling code to __init__.py from camera.py. * Update per review comments, part 1 - Rebase - Add permission checking to services - Change cv.ensure_list_csv to cv.ensure_list - Add comment for "pointless-statement" in setup - Change handler_services to handled_services - Remove check if services have alreaday been registered - Pass ffmpeg instead of hass to AmcrestCam __init__ - Remove writing motion_detection attr from device_state_attributes - Change service methods from callbacks to coroutines * Update per review comments, part 2 - Use dispatcher to signal camera entities to run services. - Reorganize a bit, including moving a few things to new modules const.py & helpers.py. * Update per review comments, part 3 Move call data extraction from camera.py to __init__.py.
70 lines
2 KiB
Python
70 lines
2 KiB
Python
"""Suppoort for Amcrest IP camera binary sensors."""
|
|
from datetime import timedelta
|
|
import logging
|
|
|
|
from homeassistant.components.binary_sensor import (
|
|
BinarySensorDevice, DEVICE_CLASS_MOTION)
|
|
from homeassistant.const import CONF_NAME, CONF_BINARY_SENSORS
|
|
|
|
from .const import BINARY_SENSOR_SCAN_INTERVAL_SECS, DATA_AMCREST
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
SCAN_INTERVAL = timedelta(seconds=BINARY_SENSOR_SCAN_INTERVAL_SECS)
|
|
|
|
BINARY_SENSORS = {
|
|
'motion_detected': 'Motion Detected'
|
|
}
|
|
|
|
|
|
async def async_setup_platform(hass, config, async_add_entities,
|
|
discovery_info=None):
|
|
"""Set up a binary sensor for an Amcrest IP Camera."""
|
|
if discovery_info is None:
|
|
return
|
|
|
|
name = discovery_info[CONF_NAME]
|
|
device = hass.data[DATA_AMCREST]['devices'][name]
|
|
async_add_entities(
|
|
[AmcrestBinarySensor(name, device, sensor_type)
|
|
for sensor_type in discovery_info[CONF_BINARY_SENSORS]],
|
|
True)
|
|
|
|
|
|
class AmcrestBinarySensor(BinarySensorDevice):
|
|
"""Binary sensor for Amcrest camera."""
|
|
|
|
def __init__(self, name, device, sensor_type):
|
|
"""Initialize entity."""
|
|
self._name = '{} {}'.format(name, BINARY_SENSORS[sensor_type])
|
|
self._api = device.api
|
|
self._sensor_type = sensor_type
|
|
self._state = None
|
|
|
|
@property
|
|
def name(self):
|
|
"""Return entity name."""
|
|
return self._name
|
|
|
|
@property
|
|
def is_on(self):
|
|
"""Return if entity is on."""
|
|
return self._state
|
|
|
|
@property
|
|
def device_class(self):
|
|
"""Return device class."""
|
|
return DEVICE_CLASS_MOTION
|
|
|
|
def update(self):
|
|
"""Update entity."""
|
|
from amcrest import AmcrestError
|
|
|
|
_LOGGER.debug('Pulling data from %s binary sensor', self._name)
|
|
|
|
try:
|
|
self._state = self._api.is_motion_detected
|
|
except AmcrestError as error:
|
|
_LOGGER.error(
|
|
'Could not update %s binary sensor due to error: %s',
|
|
self.name, error)
|