Skip to content

Commit

Permalink
Intellifire climate Entity (home-assistant#70818)
Browse files Browse the repository at this point in the history
Co-authored-by: J. Nick Koston <nick@koston.org>
  • Loading branch information
jeeftor and bdraco authored Jun 29, 2022
1 parent 466ba47 commit 6127a9a
Show file tree
Hide file tree
Showing 5 changed files with 125 additions and 2 deletions.
1 change: 1 addition & 0 deletions .coveragerc
Original file line number Diff line number Diff line change
Expand Up @@ -555,6 +555,7 @@ omit =
homeassistant/components/insteon/utils.py
homeassistant/components/intellifire/__init__.py
homeassistant/components/intellifire/coordinator.py
homeassistant/components/intellifire/climate.py
homeassistant/components/intellifire/binary_sensor.py
homeassistant/components/intellifire/sensor.py
homeassistant/components/intellifire/switch.py
Expand Down
2 changes: 1 addition & 1 deletion homeassistant/components/intellifire/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
from .const import CONF_USER_ID, DOMAIN, LOGGER
from .coordinator import IntellifireDataUpdateCoordinator

PLATFORMS = [Platform.BINARY_SENSOR, Platform.SENSOR, Platform.SWITCH]
PLATFORMS = [Platform.BINARY_SENSOR, Platform.SENSOR, Platform.CLIMATE, Platform.SWITCH]


async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
Expand Down
120 changes: 120 additions & 0 deletions homeassistant/components/intellifire/climate.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
"""Intellifire Climate Entities."""
from __future__ import annotations

from homeassistant.components.climate import (
ClimateEntity,
ClimateEntityDescription,
ClimateEntityFeature,
)
from homeassistant.components.climate.const import HVACMode
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import ATTR_TEMPERATURE, TEMP_CELSIUS
from homeassistant.core import HomeAssistant
from homeassistant.helpers.entity_platform import AddEntitiesCallback

from . import IntellifireDataUpdateCoordinator
from .const import DEFAULT_THERMOSTAT_TEMP, DOMAIN, LOGGER
from .entity import IntellifireEntity

INTELLIFIRE_CLIMATES: tuple[ClimateEntityDescription, ...] = (
ClimateEntityDescription(key="climate", name="Thermostat"),
)


async def async_setup_entry(
hass: HomeAssistant,
entry: ConfigEntry,
async_add_entities: AddEntitiesCallback,
) -> None:
"""Configure the fan entry.."""
coordinator: IntellifireDataUpdateCoordinator = hass.data[DOMAIN][entry.entry_id]

if coordinator.data.has_thermostat:
async_add_entities(
IntellifireClimate(
coordinator=coordinator,
description=description,
)
for description in INTELLIFIRE_CLIMATES
)


class IntellifireClimate(IntellifireEntity, ClimateEntity):
"""Intellifire climate entity."""

entity_description: ClimateEntityDescription

_attr_hvac_modes = [HVACMode.HEAT, HVACMode.OFF]
_attr_min_temp = 0
_attr_max_temp = 37
_attr_supported_features = ClimateEntityFeature.TARGET_TEMPERATURE
_attr_target_temperature_step = 1.0
_attr_temperature_unit = TEMP_CELSIUS
last_temp = DEFAULT_THERMOSTAT_TEMP

def __init__(
self,
coordinator: IntellifireDataUpdateCoordinator,
description: ClimateEntityDescription,
) -> None:
"""Configure climate entry - and override last_temp if the thermostat is currently on."""
super().__init__(coordinator, description)

if coordinator.data.thermostat_on:
self.last_temp = coordinator.data.thermostat_setpoint_c

@property
def hvac_mode(self) -> str:
"""Return current hvac mode."""
if self.coordinator.read_api.data.thermostat_on:
return HVACMode.HEAT
return HVACMode.OFF

async def async_set_temperature(self, **kwargs) -> None:
"""Turn on thermostat by setting a target temperature."""
raw_target_temp = kwargs[ATTR_TEMPERATURE]
self.last_temp = int(raw_target_temp)
LOGGER.debug(
"Setting target temp to %sc %sf",
int(raw_target_temp),
(raw_target_temp * 9 / 5) + 32,
)
await self.coordinator.control_api.set_thermostat_c(
fireplace=self.coordinator.control_api.default_fireplace,
temp_c=self.last_temp,
)

@property
def current_temperature(self) -> float:
"""Return the current temperature."""
return float(self.coordinator.read_api.data.temperature_c)

@property
def target_temperature(self) -> float:
"""Return target temperature."""
return float(self.coordinator.read_api.data.thermostat_setpoint_c)

async def async_set_hvac_mode(self, hvac_mode: str) -> None:
"""Set HVAC mode to normal or thermostat control."""
LOGGER.debug(
"Setting mode to [%s] - using last temp: %s", hvac_mode, self.last_temp
)

if hvac_mode == HVACMode.OFF:
await self.coordinator.control_api.turn_off_thermostat(
fireplace=self.coordinator.control_api.default_fireplace
)
return

# hvac_mode == HVACMode.HEAT
# 1) Set the desired target temp
await self.coordinator.control_api.set_thermostat_c(
fireplace=self.coordinator.control_api.default_fireplace,
temp_c=self.last_temp,
)

# 2) Make sure the fireplace is on!
if not self.coordinator.read_api.data.is_on:
await self.coordinator.control_api.flame_on(
fireplace=self.coordinator.control_api.default_fireplace,
)
2 changes: 2 additions & 0 deletions homeassistant/components/intellifire/const.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,5 @@
LOGGER = logging.getLogger(__package__)

CONF_SERIAL = "serial"

DEFAULT_THERMOSTAT_TEMP = 21
2 changes: 1 addition & 1 deletion homeassistant/components/intellifire/coordinator.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ async def _async_update_data(self) -> IntellifirePollData:
except (ConnectionError, ClientConnectionError) as exception:
raise UpdateFailed from exception

LOGGER.info("Failure Count %d", self._api.failed_poll_attempts)
LOGGER.debug("Failure Count %d", self._api.failed_poll_attempts)
if self._api.failed_poll_attempts > 10:
LOGGER.debug("Too many polling errors - raising exception")
raise UpdateFailed
Expand Down

0 comments on commit 6127a9a

Please sign in to comment.