115 lines
3.9 KiB
Python
115 lines
3.9 KiB
Python
"""Support for WaterHeater devices of (EMEA/EU) Honeywell TCC systems."""
|
|
import logging
|
|
from typing import List
|
|
|
|
from homeassistant.components.water_heater import (
|
|
SUPPORT_AWAY_MODE,
|
|
SUPPORT_OPERATION_MODE,
|
|
WaterHeaterDevice,
|
|
)
|
|
from homeassistant.const import PRECISION_WHOLE, STATE_OFF, STATE_ON
|
|
from homeassistant.helpers.typing import ConfigType, HomeAssistantType
|
|
from homeassistant.util.dt import parse_datetime
|
|
|
|
from . import EvoChild
|
|
from .const import DOMAIN, EVO_FOLLOW, EVO_PERMOVER
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
STATE_AUTO = "auto"
|
|
|
|
HA_STATE_TO_EVO = {STATE_AUTO: "", STATE_ON: "On", STATE_OFF: "Off"}
|
|
EVO_STATE_TO_HA = {v: k for k, v in HA_STATE_TO_EVO.items() if k != ""}
|
|
|
|
STATE_ATTRS_DHW = ["dhwId", "activeFaults", "stateStatus", "temperatureStatus"]
|
|
|
|
|
|
async def async_setup_platform(
|
|
hass: HomeAssistantType, config: ConfigType, async_add_entities, discovery_info=None
|
|
) -> None:
|
|
"""Create a DHW controller."""
|
|
if discovery_info is None:
|
|
return
|
|
|
|
broker = hass.data[DOMAIN]["broker"]
|
|
|
|
_LOGGER.debug(
|
|
"Found the DHW Controller (%s), id: %s",
|
|
broker.tcs.hotwater.zone_type,
|
|
broker.tcs.hotwater.zoneId,
|
|
)
|
|
|
|
evo_dhw = EvoDHW(broker, broker.tcs.hotwater)
|
|
|
|
async_add_entities([evo_dhw], update_before_add=True)
|
|
|
|
|
|
class EvoDHW(EvoChild, WaterHeaterDevice):
|
|
"""Base for a Honeywell evohome DHW controller (aka boiler)."""
|
|
|
|
def __init__(self, evo_broker, evo_device) -> None:
|
|
"""Initialize a evohome DHW controller."""
|
|
super().__init__(evo_broker, evo_device)
|
|
|
|
self._unique_id = evo_device.dhwId
|
|
self._name = "DHW controller"
|
|
self._icon = "mdi:thermometer-lines"
|
|
|
|
self._precision = PRECISION_WHOLE
|
|
self._supported_features = SUPPORT_AWAY_MODE | SUPPORT_OPERATION_MODE
|
|
|
|
@property
|
|
def state(self):
|
|
"""Return the current state."""
|
|
return EVO_STATE_TO_HA[self._evo_device.stateStatus["state"]]
|
|
|
|
@property
|
|
def current_operation(self) -> str:
|
|
"""Return the current operating mode (Auto, On, or Off)."""
|
|
if self._evo_device.stateStatus["mode"] == EVO_FOLLOW:
|
|
return STATE_AUTO
|
|
return EVO_STATE_TO_HA[self._evo_device.stateStatus["state"]]
|
|
|
|
@property
|
|
def operation_list(self) -> List[str]:
|
|
"""Return the list of available operations."""
|
|
return list(HA_STATE_TO_EVO)
|
|
|
|
@property
|
|
def is_away_mode_on(self):
|
|
"""Return True if away mode is on."""
|
|
is_off = EVO_STATE_TO_HA[self._evo_device.stateStatus["state"]] == STATE_OFF
|
|
is_permanent = self._evo_device.stateStatus["mode"] == EVO_PERMOVER
|
|
return is_off and is_permanent
|
|
|
|
async def async_set_operation_mode(self, operation_mode: str) -> None:
|
|
"""Set new operation mode for a DHW controller.
|
|
|
|
Except for Auto, the mode is only until the next SetPoint.
|
|
"""
|
|
if operation_mode == STATE_AUTO:
|
|
await self._call_client_api(self._evo_device.set_dhw_auto())
|
|
else:
|
|
await self._update_schedule()
|
|
until = parse_datetime(str(self.setpoints.get("next_sp_from")))
|
|
|
|
if operation_mode == STATE_ON:
|
|
await self._call_client_api(self._evo_device.set_dhw_on(until))
|
|
else: # STATE_OFF
|
|
await self._call_client_api(self._evo_device.set_dhw_off(until))
|
|
|
|
async def async_turn_away_mode_on(self):
|
|
"""Turn away mode on."""
|
|
await self._call_client_api(self._evo_device.set_dhw_off())
|
|
|
|
async def async_turn_away_mode_off(self):
|
|
"""Turn away mode off."""
|
|
await self._call_client_api(self._evo_device.set_dhw_auto())
|
|
|
|
async def async_update(self) -> None:
|
|
"""Get the latest state data for a DHW controller."""
|
|
await super().async_update()
|
|
|
|
for attr in STATE_ATTRS_DHW:
|
|
self._device_state_attrs[attr] = getattr(self._evo_device, attr)
|