ESPHome 2025.5.0
Loading...
Searching...
No Matches
haier_base.h
Go to the documentation of this file.
1#pragma once
2
3#include <chrono>
4#include <set>
8// HaierProtocol
9#include <protocol/haier_protocol.h>
10
11#ifdef USE_SWITCH
13#endif
14
15namespace esphome {
16namespace haier {
17
18enum class ActionRequest : uint8_t {
20 TURN_POWER_ON = 1,
22 TOGGLE_POWER = 3,
23 START_SELF_CLEAN = 4, // only hOn
24 START_STERI_CLEAN = 5, // only hOn
25};
26
31
35 public haier_protocol::ProtocolStream {
36#ifdef USE_SWITCH
37 public:
40
41 protected:
44#endif
45 public:
50 void setup() override;
51 void loop() override;
52 void control(const esphome::climate::ClimateCall &call) override;
53 void dump_config() override;
54 float get_setup_priority() const override { return esphome::setup_priority::HARDWARE; }
55 void set_display_state(bool state);
56 bool get_display_state() const;
57 void set_health_mode(bool state);
58 bool get_health_mode() const;
61 void toggle_power();
62 void reset_protocol() { this->reset_protocol_request_ = true; };
63 void set_supported_modes(const std::set<esphome::climate::ClimateMode> &modes);
64 void set_supported_swing_modes(const std::set<esphome::climate::ClimateSwingMode> &modes);
65 void set_supported_presets(const std::set<esphome::climate::ClimatePreset> &presets);
66 bool valid_connection() const { return this->protocol_phase_ >= ProtocolPhases::IDLE; };
67 size_t available() noexcept override { return esphome::uart::UARTDevice::available(); };
68 size_t read_array(uint8_t *data, size_t len) noexcept override {
70 };
71 void write_array(const uint8_t *data, size_t len) noexcept override {
73 };
74 bool can_send_message() const { return haier_protocol_.get_outgoing_queue_size() == 0; };
75 void set_answer_timeout(uint32_t timeout);
76 void set_send_wifi(bool send_wifi);
77 void send_custom_command(const haier_protocol::HaierMessage &message);
78 void add_status_message_callback(std::function<void(const char *, size_t)> &&callback);
79
80 protected:
98 const char *phase_to_string_(ProtocolPhases phase);
99 virtual void set_handlers() = 0;
100 virtual void process_phase(std::chrono::steady_clock::time_point now) = 0;
101 virtual haier_protocol::HaierMessage get_control_message() = 0; // NOLINT(readability-identifier-naming)
102 virtual haier_protocol::HaierMessage get_power_message(bool state) = 0; // NOLINT(readability-identifier-naming)
103 virtual void save_settings();
104 virtual void initialization();
105 virtual bool prepare_pending_action();
106 virtual void process_protocol_reset();
108 // Answer handlers
109 haier_protocol::HandlerError answer_preprocess_(haier_protocol::FrameType request_message_type,
110 haier_protocol::FrameType expected_request_message_type,
111 haier_protocol::FrameType answer_message_type,
112 haier_protocol::FrameType expected_answer_message_type,
113 ProtocolPhases expected_phase);
114 haier_protocol::HandlerError report_network_status_answer_handler_(haier_protocol::FrameType request_type,
115 haier_protocol::FrameType message_type,
116 const uint8_t *data, size_t data_size);
117 // Timeout handler
118 haier_protocol::HandlerError timeout_default_handler_(haier_protocol::FrameType request_type);
119 // Helper functions
120 void send_message_(const haier_protocol::HaierMessage &command, bool use_crc, uint8_t num_repeats = 0,
121 std::chrono::milliseconds interval = std::chrono::milliseconds::zero());
122 virtual void set_phase(ProtocolPhases phase);
123 void reset_phase_();
124 void reset_to_idle_();
125 bool is_message_interval_exceeded_(std::chrono::steady_clock::time_point now);
126 bool is_status_request_interval_exceeded_(std::chrono::steady_clock::time_point now);
127 bool is_control_message_interval_exceeded_(std::chrono::steady_clock::time_point now);
128 bool is_protocol_initialisation_interval_exceeded_(std::chrono::steady_clock::time_point now);
129#ifdef USE_WIFI
130 haier_protocol::HaierMessage get_wifi_signal_message_();
131#endif
132
149 enum class SwitchState {
150 OFF = 0b00,
151 ON = 0b01,
152 PENDING_OFF = 0b10,
153 PENDING_ON = 0b11,
154 };
155 haier_protocol::ProtocolHandler haier_protocol_;
170 std::unique_ptr<uint8_t[]> last_status_message_{nullptr};
171 std::chrono::steady_clock::time_point last_request_timestamp_; // For interval between messages
172 std::chrono::steady_clock::time_point last_valid_status_timestamp_; // For protocol timeout
173 std::chrono::steady_clock::time_point last_status_request_; // To request AC status
174 std::chrono::steady_clock::time_point last_signal_request_; // To send WiFI signal level
175 CallbackManager<void(const char *, size_t)> status_message_callback_{};
177};
178
179class StatusMessageTrigger : public Trigger<const char *, size_t> {
180 public:
182 parent->add_status_message_callback([this](const char *data, size_t data_size) { this->trigger(data, data_size); });
183 }
184};
185
186} // namespace haier
187} // namespace esphome
send_message_t send_message_
This class is used to encode all control actions on a climate device.
Definition climate.h:33
ClimateDevice - This is the base class for all climate integrations.
Definition climate.h:168
This class contains all static data for climate devices.
virtual haier_protocol::HaierMessage get_power_message(bool state)=0
void add_status_message_callback(std::function< void(const char *, size_t)> &&callback)
esphome::climate::ClimateTraits traits_
Definition haier_base.h:167
ESPPreferenceObject base_rtc_
Definition haier_base.h:176
bool is_message_interval_exceeded_(std::chrono::steady_clock::time_point now)
void set_supported_swing_modes(const std::set< esphome::climate::ClimateSwingMode > &modes)
void write_array(const uint8_t *data, size_t len) noexcept override
Definition haier_base.h:71
CallbackManager< void(const char *, size_t)> status_message_callback_
Definition haier_base.h:175
void set_supported_presets(const std::set< esphome::climate::ClimatePreset > &presets)
bool is_protocol_initialisation_interval_exceeded_(std::chrono::steady_clock::time_point now)
bool is_status_request_interval_exceeded_(std::chrono::steady_clock::time_point now)
esphome::climate::ClimateTraits traits() override
haier_protocol::HandlerError answer_preprocess_(haier_protocol::FrameType request_message_type, haier_protocol::FrameType expected_request_message_type, haier_protocol::FrameType answer_message_type, haier_protocol::FrameType expected_answer_message_type, ProtocolPhases expected_phase)
haier_protocol::ProtocolHandler haier_protocol_
Definition haier_base.h:155
size_t available() noexcept override
Definition haier_base.h:67
std::chrono::steady_clock::time_point last_request_timestamp_
Definition haier_base.h:171
const char * phase_to_string_(ProtocolPhases phase)
std::unique_ptr< uint8_t[]> last_status_message_
Definition haier_base.h:170
haier_protocol::HandlerError report_network_status_answer_handler_(haier_protocol::FrameType request_type, haier_protocol::FrameType message_type, const uint8_t *data, size_t data_size)
void control(const esphome::climate::ClimateCall &call) override
virtual void process_phase(std::chrono::steady_clock::time_point now)=0
void set_health_mode_switch(switch_::Switch *sw)
HaierClimateBase(const HaierClimateBase &)=delete
std::chrono::steady_clock::time_point last_valid_status_timestamp_
Definition haier_base.h:172
size_t read_array(uint8_t *data, size_t len) noexcept override
Definition haier_base.h:68
HaierClimateBase & operator=(const HaierClimateBase &)=delete
haier_protocol::HaierMessage get_wifi_signal_message_()
haier_protocol::HandlerError timeout_default_handler_(haier_protocol::FrameType request_type)
bool is_control_message_interval_exceeded_(std::chrono::steady_clock::time_point now)
virtual haier_protocol::HaierMessage get_control_message()=0
switch_::Switch * health_mode_switch_
Definition haier_base.h:43
esphome::optional< PendingAction > action_request_
Definition haier_base.h:157
void set_answer_timeout(uint32_t timeout)
std::chrono::steady_clock::time_point last_status_request_
Definition haier_base.h:173
float get_setup_priority() const override
Definition haier_base.h:54
void set_display_switch(switch_::Switch *sw)
void set_send_wifi(bool send_wifi)
virtual void set_phase(ProtocolPhases phase)
void send_custom_command(const haier_protocol::HaierMessage &message)
std::chrono::steady_clock::time_point last_signal_request_
Definition haier_base.h:174
void set_supported_modes(const std::set< esphome::climate::ClimateMode > &modes)
switch_::Switch * display_switch_
Definition haier_base.h:42
StatusMessageTrigger(HaierClimateBase *parent)
Definition haier_base.h:181
Base class for all switches.
Definition switch.h:39
optional< std::array< uint8_t, N > > read_array()
Definition uart.h:33
void write_array(const uint8_t *data, size_t len)
Definition uart.h:21
bool state
Definition fan.h:0
const float HARDWARE
For components that deal with hardware and are very important like GPIO switch.
Definition component.cpp:18
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7
std::string size_t len
Definition helpers.h:301
esphome::optional< esphome::climate::ClimateFanMode > fan_mode
Definition haier_base.h:135
esphome::optional< esphome::climate::ClimateSwingMode > swing_mode
Definition haier_base.h:136
esphome::optional< esphome::climate::ClimateMode > mode
Definition haier_base.h:134
esphome::optional< esphome::climate::ClimatePreset > preset
Definition haier_base.h:138
HvacSettings & operator=(const HvacSettings &)=default
HvacSettings(const HvacSettings &)=default
esphome::optional< float > target_temperature
Definition haier_base.h:137
esphome::optional< haier_protocol::HaierMessage > message
Definition haier_base.h:147