ESPHome 2026.5.0-dev
Loading...
Searching...
No Matches
ota_backend.h
Go to the documentation of this file.
1#pragma once
2
6
7#ifdef USE_OTA_STATE_LISTENER
8#include <vector>
9#endif
10
11namespace esphome::ota {
12
43
51
58 public:
59 virtual ~OTAStateListener() = default;
60 virtual void on_ota_state(OTAState state, float progress, uint8_t error) = 0;
61};
62
63class OTAComponent : public Component {
64#ifdef USE_OTA_STATE_LISTENER
65 public:
66 void add_state_listener(OTAStateListener *listener) { this->state_listeners_.push_back(listener); }
67
68 protected:
69 void notify_state_(OTAState state, float progress, uint8_t error);
70
76 void notify_state_deferred_(OTAState state, float progress, uint8_t error);
77
78 std::vector<OTAStateListener *> state_listeners_;
79#endif
80};
81
82#ifdef USE_OTA_STATE_LISTENER
83
89 public:
90 virtual ~OTAGlobalStateListener() = default;
91 virtual void on_ota_global_state(OTAState state, float progress, uint8_t error, OTAComponent *component) = 0;
92};
93
100 public:
101 void add_global_state_listener(OTAGlobalStateListener *listener) { this->global_listeners_.push_back(listener); }
102
103 void notify_ota_state(OTAState state, float progress, uint8_t error, OTAComponent *component) {
104 for (auto *listener : this->global_listeners_) {
105 listener->on_ota_global_state(state, progress, error, component);
106 }
107 }
108
109 protected:
110 std::vector<OTAGlobalStateListener *> global_listeners_;
111};
112
114
115// OTA implementations should use:
116// - notify_state_() when already in main loop (e.g., esphome OTA)
117// - notify_state_deferred_() when in separate task (e.g., web_server OTA)
118// This ensures proper listener execution in all contexts.
119#endif
120} // namespace esphome::ota
void notify_state_deferred_(OTAState state, float progress, uint8_t error)
Notify state with deferral to main loop (for thread safety).
void add_state_listener(OTAStateListener *listener)
Definition ota_backend.h:66
std::vector< OTAStateListener * > state_listeners_
Definition ota_backend.h:78
void notify_state_(OTAState state, float progress, uint8_t error)
Global callback that aggregates OTA state from all OTA components.
Definition ota_backend.h:99
std::vector< OTAGlobalStateListener * > global_listeners_
void notify_ota_state(OTAState state, float progress, uint8_t error, OTAComponent *component)
void add_global_state_listener(OTAGlobalStateListener *listener)
Listener interface for global OTA state changes (includes OTA component pointer).
Definition ota_backend.h:88
virtual void on_ota_global_state(OTAState state, float progress, uint8_t error, OTAComponent *component)=0
virtual ~OTAGlobalStateListener()=default
Listener interface for OTA state changes.
Definition ota_backend.h:57
virtual ~OTAStateListener()=default
virtual void on_ota_state(OTAState state, float progress, uint8_t error)=0
const Component * component
Definition component.cpp:34
bool state
Definition fan.h:2
OTAGlobalCallback * get_global_ota_callback()
@ OTA_RESPONSE_ERROR_MD5_MISMATCH
Definition ota_backend.h:38
@ OTA_RESPONSE_ERROR_ESP32_NOT_ENOUGH_SPACE
Definition ota_backend.h:36
@ OTA_RESPONSE_UPDATE_PREPARE_OK
Definition ota_backend.h:20
@ OTA_RESPONSE_ERROR_WRONG_NEW_FLASH_CONFIG
Definition ota_backend.h:34
@ OTA_RESPONSE_SUPPORTS_COMPRESSION
Definition ota_backend.h:24
@ OTA_RESPONSE_ERROR_WRONG_CURRENT_FLASH_CONFIG
Definition ota_backend.h:33
@ OTA_RESPONSE_BIN_MD5_OK
Definition ota_backend.h:21
@ OTA_RESPONSE_UPDATE_END_OK
Definition ota_backend.h:23
@ OTA_RESPONSE_RECEIVE_OK
Definition ota_backend.h:22
@ OTA_RESPONSE_CHUNK_OK
Definition ota_backend.h:25
@ OTA_RESPONSE_ERROR_WRITING_FLASH
Definition ota_backend.h:30
@ OTA_RESPONSE_ERROR_ESP8266_NOT_ENOUGH_SPACE
Definition ota_backend.h:35
@ OTA_RESPONSE_ERROR_UPDATE_END
Definition ota_backend.h:31
@ OTA_RESPONSE_ERROR_SIGNATURE_INVALID
Definition ota_backend.h:40
@ OTA_RESPONSE_ERROR_AUTH_INVALID
Definition ota_backend.h:29
@ OTA_RESPONSE_ERROR_RP2040_NOT_ENOUGH_SPACE
Definition ota_backend.h:39
@ OTA_RESPONSE_ERROR_UNKNOWN
Definition ota_backend.h:41
@ OTA_RESPONSE_REQUEST_SHA256_AUTH
Definition ota_backend.h:16
@ OTA_RESPONSE_ERROR_NO_UPDATE_PARTITION
Definition ota_backend.h:37
@ OTA_RESPONSE_ERROR_MAGIC
Definition ota_backend.h:27
@ OTA_RESPONSE_ERROR_UPDATE_PREPARE
Definition ota_backend.h:28
@ OTA_RESPONSE_HEADER_OK
Definition ota_backend.h:18
@ OTA_RESPONSE_REQUEST_AUTH
Definition ota_backend.h:15
@ OTA_RESPONSE_ERROR_INVALID_BOOTSTRAPPING
Definition ota_backend.h:32