""" device tracker for Georide object """ import logging from homeassistant.core import callback from homeassistant.components.switch import SwitchDevice from homeassistant.components.switch import ENTITY_ID_FORMAT import georideapilib.api as GeorideApi from .const import DOMAIN as GEORIDE_DOMAIN _LOGGER = logging.getLogger(__name__) async def async_setup_entry(hass, config_entry, async_add_entities): # pylint: disable=W0613 """Set up Georide tracker based off an entry.""" georide_context = hass.data[GEORIDE_DOMAIN]["context"] if georide_context.get_token() is None: return False _LOGGER.info('Current georide token: %s', georide_context.get_token()) trackers = GeorideApi.get_trackers(georide_context.get_token()) lock_switch_entities = [] for tracker in trackers: entity = GeorideLockSwitchEntity(tracker.tracker_id, georide_context.get_token, georide_context.get_tracker, data=tracker) hass.data[GEORIDE_DOMAIN]["devices"][tracker.tracker_id] = entity lock_switch_entities.append(entity) async_add_entities(lock_switch_entities) return True class GeorideLockSwitchEntity(SwitchDevice): """Represent a tracked device.""" def __init__(self, tracker_id, get_token_callback, get_tracker_callback, data): """Set up Georide entity.""" self._tracker_id = tracker_id self._data = data or {} self._get_token_callback = get_token_callback self._get_tracker_callback = get_tracker_callback self._name = data.tracker_name self._is_on = data.is_locked self.entity_id = ENTITY_ID_FORMAT.format("lock."+str(tracker_id)) self._state = {} def turn_on(self, **kwargs): """ lock the georide tracker """ _LOGGER.info('async_turn_on %s', kwargs) success = GeorideApi.lock_tracker(self._get_token_callback(), self._tracker_id) if success: self._data.is_locked = True self._is_on = True def turn_off(self, **kwargs): """ unlock the georide tracker """ _LOGGER.info('async_turn_off %s', kwargs) success = GeorideApi.unlock_tracker(self._get_token_callback(), self._tracker_id) if success: self._data.is_locked = False self._is_on = False async def async_toggle(self, **kwargs): """ toggle lock the georide tracker """ _LOGGER.info('async_toggle %s', kwargs) result = GeorideApi.toogle_lock_tracker(self._get_token_callback(), self._tracker_id) self._data.is_locked = result self._is_on = result def update(self): """ update the current tracker""" _LOGGER.info('async_update ') self._data = self._get_tracker_callback(self._tracker_id) self._name = self._data.tracker_name self._is_on = self._data.is_locked @property def unique_id(self): """Return the unique ID.""" return self._tracker_id @property def name(self): """ Georide switch name """ return self._name @property def is_on(self): """ Georide switch status """ return self._is_on @property def get_token_callback(self): """ Georide switch token callback method """ return self._get_token_callback @property def get_tracker_callback(self): """ Georide switch token callback method """ return self._get_tracker_callback @property def icon(self): if self._is_on: return "mdi:lock" return "mdi:lock-open" @property def device_info(self): """Return the device info.""" return { "name": self.name, "identifiers": {(GEORIDE_DOMAIN, self._tracker_id)}, "manufacturer": "GeoRide" }