"""Support for Vera locks.""" import logging from homeassistant.components.lock import ENTITY_ID_FORMAT, LockDevice from homeassistant.const import STATE_LOCKED, STATE_UNLOCKED from . import VERA_CONTROLLER, VERA_DEVICES, VeraDevice _LOGGER = logging.getLogger(__name__) ATTR_LAST_USER_NAME = "changed_by_name" ATTR_LOW_BATTERY = "low_battery" def setup_platform(hass, config, add_entities, discovery_info=None): """Find and return Vera locks.""" add_entities( [ VeraLock(device, hass.data[VERA_CONTROLLER]) for device in hass.data[VERA_DEVICES]["lock"] ], True, ) class VeraLock(VeraDevice, LockDevice): """Representation of a Vera lock.""" def __init__(self, vera_device, controller): """Initialize the Vera device.""" self._state = None VeraDevice.__init__(self, vera_device, controller) self.entity_id = ENTITY_ID_FORMAT.format(self.vera_id) def lock(self, **kwargs): """Lock the device.""" self.vera_device.lock() self._state = STATE_LOCKED def unlock(self, **kwargs): """Unlock the device.""" self.vera_device.unlock() self._state = STATE_UNLOCKED @property def is_locked(self): """Return true if device is on.""" return self._state == STATE_LOCKED @property def device_state_attributes(self): """Who unlocked the lock and did a low battery alert fire. Reports on the previous poll cycle. changed_by_name is a string like 'Bob'. low_battery is 1 if an alert fired, 0 otherwise. """ data = super().device_state_attributes last_user = self.vera_device.get_last_user_alert() if last_user is not None: data[ATTR_LAST_USER_NAME] = last_user[1] data[ATTR_LOW_BATTERY] = self.vera_device.get_low_battery_alert() return data @property def changed_by(self): """Who unlocked the lock. Reports on the previous poll cycle. changed_by is an integer user ID. """ last_user = self.vera_device.get_last_user_alert() if last_user is not None: return last_user[0] return None def update(self): """Update state by the Vera device callback.""" self._state = ( STATE_LOCKED if self.vera_device.is_locked(True) else STATE_UNLOCKED )