From f072fe8b0b1963f959dc37ff7386a5bbb775ecac Mon Sep 17 00:00:00 2001 From: Felix Kaechele Date: Sat, 11 Mar 2023 22:44:28 -0500 Subject: [PATCH] fix: ensure consistent state when using flame_height to turn on This works around a quirk in which the eFIRE controller maintains its own state for on/off which goes out of sync if the fireplace is enabled by moving the flame height from 0 to a higher value without first turning the fireplace on through the eFIRE controller. Signed-off-by: Felix Kaechele --- src/bonaparte/fireplace.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/bonaparte/fireplace.py b/src/bonaparte/fireplace.py index bf9479b..903da39 100644 --- a/src/bonaparte/fireplace.py +++ b/src/bonaparte/fireplace.py @@ -285,6 +285,21 @@ async def set_flame_height(self, flame_height: int) -> bool: if not 0 <= flame_height <= MAX_FLAME_HEIGHT: msg = "Flame height must be between 0 and 6." raise ValueError(msg) + # The eFIRE controller does not set the on state if we change + # flame height from 0 to a non-zero value. However, the IFC + # will ignite the burner and set the requested flame height. + # To maintain consistent state we force the eFIRE controller on. + # This has the annoying side-effect that flame height will be + # set to max before being set to the desired value shortly after. + if self._state.flame_height == 0 and flame_height > 0: + _LOGGER.debug( + ( + "%s: Turning on via flame_height setting, forcing controller on as" + " well" + ), + self.name, + ) + await self.power_on() self._state.flame_height = flame_height return await self._ifc_cmd2()