ESPHome 2026.4.0-dev
Loading...
Searching...
No Matches
water_heater.h
Go to the documentation of this file.
1#pragma once
7#include "esphome/core/log.h"
9
10namespace esphome::water_heater {
11
12class WaterHeater;
13struct WaterHeaterCallInternal;
14
68
71
72 public:
73 WaterHeaterCall() : parent_(nullptr) {}
74
76
78 WaterHeaterCall &set_mode(const char *mode);
79 WaterHeaterCall &set_mode(const char *mode, size_t len);
80 WaterHeaterCall &set_mode(const std::string &mode) { return this->set_mode(mode.c_str(), mode.size()); }
84 WaterHeaterCall &set_away(bool away);
85 WaterHeaterCall &set_on(bool on);
86
87 void perform();
88
89 const optional<WaterHeaterMode> &get_mode() const { return this->mode_; }
90 float get_target_temperature() const { return this->target_temperature_; }
94 ESPDEPRECATED("get_state() is deprecated, use get_away() and get_on() instead. (Removed in 2026.8.0)", "2026.2.0")
95 uint32_t get_state() const { return this->state_; }
96
97 optional<bool> get_away() const {
99 return (this->state_ & WATER_HEATER_STATE_AWAY) != 0;
100 }
101 return {};
102 }
103
104 optional<bool> get_on() const {
106 return (this->state_ & WATER_HEATER_STATE_ON) != 0;
107 }
108 return {};
109 }
110
111 protected:
112 void validate_();
114 optional<WaterHeaterMode> mode_;
121
124
126 this->mode_ = restore.mode_;
130 this->state_ = restore.state_;
131 this->state_mask_ = restore.state_mask_;
132 return *this;
133 }
134};
135
137 public:
141 bool has_feature_flags(uint32_t flags) const { return (this->feature_flags_ & flags) == flags; }
142 uint32_t get_feature_flags() const { return this->feature_flags_; }
143
154
156 void set_supports_away_mode(bool supports) {
157 if (supports) {
159 } else {
161 }
162 }
163
174
175 void set_min_temperature(float min_temperature) { this->min_temperature_ = min_temperature; }
176 float get_min_temperature() const { return this->min_temperature_; }
177
178 void set_max_temperature(float max_temperature) { this->max_temperature_ = max_temperature; }
179 float get_max_temperature() const { return this->max_temperature_; }
180
181 void set_target_temperature_step(float target_temperature_step) {
182 this->target_temperature_step_ = target_temperature_step;
183 }
185
188 bool supports_mode(WaterHeaterMode mode) const { return this->supported_modes_.count(mode); }
189
190 protected:
191 // Ordered to minimize padding: 4-byte members first
193 float min_temperature_{0.0f};
194 float max_temperature_{0.0f};
197};
198
199class WaterHeater : public EntityBase {
200 public:
201 WaterHeaterMode get_mode() const { return this->mode_; }
202 float get_current_temperature() const { return this->current_temperature_; }
203 float get_target_temperature() const { return this->target_temperature_; }
207 uint32_t get_state() const { return this->state_; }
209 bool is_away() const { return (this->state_ & WATER_HEATER_STATE_AWAY) != 0; }
211 bool is_on() const { return (this->state_ & WATER_HEATER_STATE_ON) != 0; }
212
213 void set_current_temperature(float current_temperature) { this->current_temperature_ = current_temperature; }
214
215 virtual void publish_state();
218
219#ifdef USE_WATER_HEATER_VISUAL_OVERRIDES
220 void set_visual_min_temperature_override(float min_temperature_override);
221 void set_visual_max_temperature_override(float max_temperature_override);
222 void set_visual_target_temperature_step_override(float visual_target_temperature_step_override);
223#endif
224 virtual void control(const WaterHeaterCall &call) = 0;
225
226 protected:
228
230 void dump_traits_(const char *tag);
231
233 optional<WaterHeaterCall> restore_state_();
234
250 void set_state_flag_(uint32_t flag, bool value) {
251 if (value) {
252 this->state_ |= flag;
253 } else {
254 this->state_ &= ~flag;
255 }
256 }
257
263 uint32_t state_{0}; // Bitmask of WaterHeaterStateFlag
264
265#ifdef USE_WATER_HEATER_VISUAL_OVERRIDES
269#endif
270
272};
273
276
277} // namespace esphome::water_heater
BedjetMode mode
BedJet operating mode.
constexpr size_t count(ValueType value) const
Check if the set contains a specific value (std::set compatibility) Returns 1 if present,...
WaterHeaterCall & set_away(bool away)
WaterHeaterCall & set_target_temperature_high(float temperature)
WaterHeaterCall & set_mode(WaterHeaterMode mode)
ESPDEPRECATED("get_state() is deprecated, use get_away() and get_on() instead. (Removed in 2026.8.0)", "2026.2.0") uint32_t get_state() const
Get state flags value.
WaterHeaterCall & set_target_temperature_low(float temperature)
WaterHeaterCall & set_on(bool on)
optional< bool > get_away() const
WaterHeaterCall & set_mode(const std::string &mode)
optional< WaterHeaterMode > mode_
const optional< WaterHeaterMode > & get_mode() const
WaterHeaterCall & set_target_temperature(float temperature)
uint32_t get_state() const
Get the current state flags bitmask.
void set_target_temperature_low_(float target_temperature_low)
Set the low target temperature (for two-point control). Should only be called from control().
void set_mode_(WaterHeaterMode mode)
Set the mode of the water heater. Should only be called from control().
void set_visual_min_temperature_override(float min_temperature_override)
virtual void control(const WaterHeaterCall &call)=0
void set_visual_target_temperature_step_override(float visual_target_temperature_step_override)
void set_state_flag_(uint32_t flag, bool value)
Set or clear a state flag. Should only be called from control().
void set_visual_max_temperature_override(float max_temperature_override)
optional< WaterHeaterCall > restore_state_()
Restore the state of the water heater, call this from your setup() method.
void set_state_(uint32_t state)
Set the state flags. Should only be called from control().
void set_target_temperature_high_(float target_temperature_high)
Set the high target temperature (for two-point control). Should only be called from control().
bool is_on() const
Check if the water heater is on.
bool is_away() const
Check if away mode is currently active.
void set_target_temperature_(float target_temperature)
Set the target temperature of the water heater. Should only be called from control().
virtual WaterHeaterCallInternal make_call()=0
WaterHeaterMode get_mode() const
void dump_traits_(const char *tag)
Log the traits of this water heater for dump_config().
virtual WaterHeaterTraits get_traits()
virtual WaterHeaterTraits traits()=0
void set_current_temperature(float current_temperature)
void set_supported_modes(WaterHeaterModeMask modes)
const WaterHeaterModeMask & get_supported_modes() const
void add_feature_flags(uint32_t flags)
Get/set feature flags (see WaterHeaterFeature enum)
bool supports_mode(WaterHeaterMode mode) const
void set_supports_current_temperature(bool supports)
void set_min_temperature(float min_temperature)
void set_supports_two_point_target_temperature(bool supports)
bool has_feature_flags(uint32_t flags) const
void set_target_temperature_step(float target_temperature_step)
void set_max_temperature(float max_temperature)
float target_temperature_high
Definition climate.h:3
float target_temperature
Definition climate.h:0
float target_temperature_low
Definition climate.h:2
uint16_t type
uint16_t flags
bool state
Definition fan.h:2
void log_water_heater(const char *tag, const char *prefix, const char *type, WaterHeater *obj)
WaterHeaterStateFlag
State flags for water heater current state (bitmask)
@ WATER_HEATER_STATE_ON
Water heater is on (not in standby)
@ WATER_HEATER_STATE_AWAY
Away/vacation mode is currently active.
WaterHeaterFeature
Feature flags for water heater capabilities (matches Home Assistant WaterHeaterEntityFeature)
@ WATER_HEATER_SUPPORTS_TARGET_TEMPERATURE
The water heater supports a target temperature.
@ WATER_HEATER_SUPPORTS_OPERATION_MODE
The water heater supports operation mode selection.
@ WATER_HEATER_SUPPORTS_ON_OFF
The water heater can be turned on/off.
@ WATER_HEATER_SUPPORTS_AWAY_MODE
The water heater supports an away/vacation mode.
@ WATER_HEATER_SUPPORTS_CURRENT_TEMPERATURE
The water heater supports reporting the current temperature.
@ WATER_HEATER_SUPPORTS_TWO_POINT_TARGET_TEMPERATURE
The water heater supports two-point target temperature (low/high range).
const LogString * water_heater_mode_to_string(WaterHeaterMode mode)
Convert the given WaterHeaterMode to a human-readable string for logging.
class esphome::water_heater::WaterHeaterCall __attribute__
const char * tag
Definition log.h:74
std::string size_t len
Definition helpers.h:1045
static void uint32_t
struct esphome::water_heater::SavedWaterHeaterState::@182::@183 __attribute__
WaterHeaterCallInternal & set_from_restore(const WaterHeaterCall &restore)
uint16_t temperature
Definition sun_gtil2.cpp:12