Honeywell evohome/TCC systems

The evohome integration links Home Assistant with all non-US Honeywell Total Connect Comfort (TCC) CH/DHW systems, such as:

  • The Honeywell evohome CH/DHW system, and
  • The Honeywell Round Thermostat

It does not support the home security functionality of TCC.

It uses v2 of the evohome-client client library.

Honeywell removed support for higher-precision temperatures from the v2 API, and thus reported temperatures are rounded up to the nearest 0.5C.


evohome is a multi-zone system. Each zone is represented as a Climate device: it will expose the zone’s operating mode, temperature and setpoint.

The controller/location is also represented as a Climate device: it will expose the location’s operating mode (see below for details). Note that the controller’s current temperature is calculated as an average of all the Zones.

The DHW controller is represented as a WaterHeater device: It will report its current temperature (but not target temperature), and it can be turned on or off.

Round Thermostat

Although Round Thermostat is, strictly speaking, a Controller and a single zone, they are merged into a single Climate device.


To set up this integration, add the following to your configuration.yaml file:

# Example configuration.yaml entry
  username: YOUR_USERNAME
  password: YOUR_PASSWORD

Configuration Variables



The username (email address) that has access to Honeywell TCC web site.



The password corresponding to the above username.



Used to select which location to use, if your login has access to more than one location. Multiple locations at one time are not supported.

Default value:




How often updates are retrieved from Honeywell’s web servers. The minimum value is 60 seconds.

Default value:


This is an IoT cloud-polling device, and the recommended scan_interval is 180 seconds. Testing has indicated that this is a safe interval that - by itself - shouldn’t cause you to be rate-limited by Honeywell.

Operating modes, and inheritance

Zones support only three setpoint modes: FollowSchedule, TemporaryOverride, and PermanentOverride.

Mostly, the zone ‘inherits’ its functional operating mode from the controller (the actual algorithm for this is a little complicated).

The evohome controller supports seven distinct system modes: Auto, AutoWithEco, Away, DayOff, HeatingOff, and Custom; AutoWithReset is a hidden mode that will revert all zones to FollowSchedule mode.

If the zone is in FollowSchedule mode, its temperature (target temperature) is a function of its scheduled temperature and its functional mode - for example, AutoWithEco is scheduled temperature less 3C.

If the controller is set to HeatingOff (target temperature to a minimum) or Away (target temperature to 12C), then the zones will inherit that mode regardless of their own setpoint mode.

If the zone’s temperature is changed, then it will be a TemporaryOverride that will revert to FollowSchedule at the next scheduled setpoint. Once this is done, the zone can be switched to PermanentOverride mode.

In Home Assistant, all this is done via HVAC_MODE and PRESET_MODE (but also see systemModeStatus, setpointStatus, below).

Useful Jinja Templates

The actual operating mode of evohome entities can be tracked via their state attributes, which includes a JSON data structure for the current state called status.

For the Controller, see systemModeStatus:

{% if state_attr('climate.my_home', 'status').systemModeStatus.mode == "Away" %}
  The system is in Away mode
{% else %}
  The system is not in Away mode
{% endif %}

For the Zones, it is setpointStatus:

{{ state_attr('', 'status').setpointStatus.setpointMode }}

The Zones will expose the current/upcoming scheduled setpoints:

{{ state_attr('', 'status') }}

All evohome entities may have faults, and these can be turned into sensors, or:

{% if state_attr('climate.bedroom', 'status').activeFaults %}
  {% if state_attr('climate.bedroom', 'status').activeFaults[0].faultType == 'TempZoneActuatorLowBattery' %}
    There is a low battery
  {% endif %}
    There is a Fault!
{% else %}
  Yay, everything is OK :)
{% endif %}