"""Support for ESPHome binary sensors.""" import logging from typing import TYPE_CHECKING, Optional from homeassistant.components.binary_sensor import BinarySensorDevice from homeassistant.components.esphome import EsphomeEntity, \ platform_async_setup_entry if TYPE_CHECKING: # pylint: disable=unused-import from aioesphomeapi import BinarySensorInfo, BinarySensorState # noqa DEPENDENCIES = ['esphome'] _LOGGER = logging.getLogger(__name__) async def async_setup_entry(hass, entry, async_add_entities): """Set up ESPHome binary sensors based on a config entry.""" # pylint: disable=redefined-outer-name from aioesphomeapi import BinarySensorInfo, BinarySensorState # noqa await platform_async_setup_entry( hass, entry, async_add_entities, component_key='binary_sensor', info_type=BinarySensorInfo, entity_type=EsphomeBinarySensor, state_type=BinarySensorState ) class EsphomeBinarySensor(EsphomeEntity, BinarySensorDevice): """A binary sensor implementation for ESPHome.""" @property def _static_info(self) -> 'BinarySensorInfo': return super()._static_info @property def _state(self) -> Optional['BinarySensorState']: return super()._state @property def is_on(self): """Return true if the binary sensor is on.""" if self._static_info.is_status_binary_sensor: # Status binary sensors indicated connected state. # So in their case what's usually _availability_ is now state return self._entry_data.available if self._state is None: return None return self._state.state @property def device_class(self): """Return the class of this device, from component DEVICE_CLASSES.""" return self._static_info.device_class @property def available(self): """Return True if entity is available.""" if self._static_info.is_status_binary_sensor: return True return super().available