ESPHome 2025.10.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_CALLBACK
9#endif
10
11namespace esphome {
12namespace ota {
13
43
51
53 public:
54 virtual ~OTABackend() = default;
55 virtual OTAResponseTypes begin(size_t image_size) = 0;
56 virtual void set_update_md5(const char *md5) = 0;
57 virtual OTAResponseTypes write(uint8_t *data, size_t len) = 0;
58 virtual OTAResponseTypes end() = 0;
59 virtual void abort() = 0;
60 virtual bool supports_compression() = 0;
61};
62
63class OTAComponent : public Component {
64#ifdef USE_OTA_STATE_CALLBACK
65 public:
66 void add_on_state_callback(std::function<void(ota::OTAState, float, uint8_t)> &&callback) {
67 this->state_callback_.add(std::move(callback));
68 }
69
70 protected:
75 class StateCallbackManager : public CallbackManager<void(OTAState, float, uint8_t)> {
76 public:
77 StateCallbackManager(OTAComponent *component) : component_(component) {}
78
84 void call_deferred(ota::OTAState state, float progress, uint8_t error) {
85 component_->defer([this, state, progress, error]() { this->call(state, progress, error); });
86 }
87
88 private:
89 OTAComponent *component_;
90 };
91
93#endif
94};
95
96#ifdef USE_OTA_STATE_CALLBACK
98 public:
99 void register_ota(OTAComponent *ota_caller) {
100 ota_caller->add_on_state_callback([this, ota_caller](OTAState state, float progress, uint8_t error) {
101 this->state_callback_.call(state, progress, error, ota_caller);
102 });
103 }
104 void add_on_state_callback(std::function<void(OTAState, float, uint8_t, OTAComponent *)> &&callback) {
105 this->state_callback_.add(std::move(callback));
106 }
107
108 protected:
110};
111
112OTAGlobalCallback *get_global_ota_callback();
113void register_ota_platform(OTAComponent *ota_caller);
114
115// OTA implementations should use:
116// - state_callback_.call() when already in main loop (e.g., esphome OTA)
117// - state_callback_.call_deferred() when in separate task (e.g., web_server OTA)
118// This ensures proper callback execution in all contexts.
119#endif
120std::unique_ptr<ota::OTABackend> make_ota_backend();
121
122} // namespace ota
123} // namespace esphome
void defer(const std::string &name, std::function< void()> &&f)
Defer a callback to the next loop() call.
virtual OTAResponseTypes end()=0
virtual OTAResponseTypes begin(size_t image_size)=0
virtual ~OTABackend()=default
virtual void abort()=0
virtual bool supports_compression()=0
virtual OTAResponseTypes write(uint8_t *data, size_t len)=0
virtual void set_update_md5(const char *md5)=0
Extended callback manager with deferred call support.
Definition ota_backend.h:75
void call_deferred(ota::OTAState state, float progress, uint8_t error)
Call callbacks with deferral to main loop (for thread safety).
Definition ota_backend.h:84
void add_on_state_callback(std::function< void(ota::OTAState, float, uint8_t)> &&callback)
Definition ota_backend.h:66
StateCallbackManager state_callback_
Definition ota_backend.h:92
void register_ota(OTAComponent *ota_caller)
Definition ota_backend.h:99
void add_on_state_callback(std::function< void(OTAState, float, uint8_t, OTAComponent *)> &&callback)
CallbackManager< void(OTAState, float, uint8_t, OTAComponent *)> state_callback_
bool state
Definition fan.h:0
void register_ota_platform(OTAComponent *ota_caller)
OTAGlobalCallback * get_global_ota_callback()
std::unique_ptr< ota::OTABackend > make_ota_backend()
@ OTA_RESPONSE_ERROR_MD5_MISMATCH
Definition ota_backend.h:39
@ OTA_RESPONSE_ERROR_ESP32_NOT_ENOUGH_SPACE
Definition ota_backend.h:37
@ OTA_RESPONSE_UPDATE_PREPARE_OK
Definition ota_backend.h:21
@ OTA_RESPONSE_ERROR_WRONG_NEW_FLASH_CONFIG
Definition ota_backend.h:35
@ OTA_RESPONSE_SUPPORTS_COMPRESSION
Definition ota_backend.h:25
@ OTA_RESPONSE_ERROR_WRONG_CURRENT_FLASH_CONFIG
Definition ota_backend.h:34
@ OTA_RESPONSE_BIN_MD5_OK
Definition ota_backend.h:22
@ OTA_RESPONSE_UPDATE_END_OK
Definition ota_backend.h:24
@ OTA_RESPONSE_RECEIVE_OK
Definition ota_backend.h:23
@ OTA_RESPONSE_CHUNK_OK
Definition ota_backend.h:26
@ OTA_RESPONSE_ERROR_WRITING_FLASH
Definition ota_backend.h:31
@ OTA_RESPONSE_ERROR_ESP8266_NOT_ENOUGH_SPACE
Definition ota_backend.h:36
@ OTA_RESPONSE_ERROR_UPDATE_END
Definition ota_backend.h:32
@ OTA_RESPONSE_ERROR_AUTH_INVALID
Definition ota_backend.h:30
@ OTA_RESPONSE_ERROR_RP2040_NOT_ENOUGH_SPACE
Definition ota_backend.h:40
@ OTA_RESPONSE_ERROR_UNKNOWN
Definition ota_backend.h:41
@ OTA_RESPONSE_REQUEST_SHA256_AUTH
Definition ota_backend.h:17
@ OTA_RESPONSE_ERROR_NO_UPDATE_PARTITION
Definition ota_backend.h:38
@ OTA_RESPONSE_ERROR_MAGIC
Definition ota_backend.h:28
@ OTA_RESPONSE_ERROR_UPDATE_PREPARE
Definition ota_backend.h:29
@ OTA_RESPONSE_HEADER_OK
Definition ota_backend.h:19
@ OTA_RESPONSE_REQUEST_AUTH
Definition ota_backend.h:16
@ OTA_RESPONSE_ERROR_INVALID_BOOTSTRAPPING
Definition ota_backend.h:33
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7
std::string size_t len
Definition helpers.h:291