2020-07-17 00:58:45 +00:00
|
|
|
"""Entity for Firmata devices."""
|
2021-03-17 22:49:01 +00:00
|
|
|
from __future__ import annotations
|
2020-07-17 00:58:45 +00:00
|
|
|
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
2021-05-01 22:37:19 +00:00
|
|
|
from homeassistant.helpers.entity import DeviceInfo
|
2020-07-17 00:58:45 +00:00
|
|
|
|
|
|
|
from .board import FirmataPinType
|
|
|
|
from .const import DOMAIN, FIRMATA_MANUFACTURER
|
|
|
|
from .pin import FirmataBoardPin
|
|
|
|
|
|
|
|
|
|
|
|
class FirmataEntity:
|
|
|
|
"""Representation of a Firmata entity."""
|
|
|
|
|
|
|
|
def __init__(self, api):
|
|
|
|
"""Initialize the entity."""
|
|
|
|
self._api = api
|
|
|
|
|
|
|
|
@property
|
2021-05-01 22:37:19 +00:00
|
|
|
def device_info(self) -> DeviceInfo:
|
2020-07-17 00:58:45 +00:00
|
|
|
"""Return device info."""
|
|
|
|
return {
|
|
|
|
"connections": {},
|
|
|
|
"identifiers": {(DOMAIN, self._api.board.name)},
|
|
|
|
"manufacturer": FIRMATA_MANUFACTURER,
|
|
|
|
"name": self._api.board.name,
|
|
|
|
"sw_version": self._api.board.firmware_version,
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class FirmataPinEntity(FirmataEntity):
|
|
|
|
"""Representation of a Firmata pin entity."""
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
2021-03-17 22:49:01 +00:00
|
|
|
api: type[FirmataBoardPin],
|
2020-07-17 00:58:45 +00:00
|
|
|
config_entry: ConfigEntry,
|
|
|
|
name: str,
|
|
|
|
pin: FirmataPinType,
|
2021-05-20 15:47:30 +00:00
|
|
|
) -> None:
|
2020-07-17 00:58:45 +00:00
|
|
|
"""Initialize the pin entity."""
|
|
|
|
super().__init__(api)
|
|
|
|
self._name = name
|
|
|
|
|
|
|
|
location = (config_entry.entry_id, "pin", pin)
|
|
|
|
self._unique_id = "_".join(str(i) for i in location)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self) -> str:
|
|
|
|
"""Get the name of the pin."""
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def should_poll(self) -> bool:
|
|
|
|
"""No polling needed."""
|
|
|
|
return False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self) -> str:
|
|
|
|
"""Return a unique identifier for this device."""
|
|
|
|
return self._unique_id
|