|
ESPHome 2026.2.1
|
#include <espnow_component.h>
Public Member Functions | |
| ESPNowComponent () | |
| void | setup () override |
| void | loop () override |
| void | dump_config () override |
| float | get_setup_priority () const override |
| void | add_peer (peer_address_t address) |
| esp_err_t | add_peer (const uint8_t *peer) |
| esp_err_t | del_peer (const uint8_t *peer) |
| void | set_wifi_channel (uint8_t channel) |
| void | apply_wifi_channel () |
| uint8_t | get_wifi_channel () |
| void | set_auto_add_peer (bool value) |
| void | enable () |
| void | disable () |
| bool | is_disabled () const |
| void | set_enable_on_boot (bool enable_on_boot) |
| bool | is_wifi_enabled () |
| esp_err_t | send (const uint8_t *peer_address, const std::vector< uint8_t > &payload, const send_callback_t &callback=nullptr) |
| Queue a packet to be sent to a specific peer address. | |
| esp_err_t | send (const uint8_t *peer_address, const uint8_t *payload, size_t size, const send_callback_t &callback=nullptr) |
| void | register_received_handler (ESPNowReceivedPacketHandler *handler) |
| void | register_unknown_peer_handler (ESPNowUnknownPeerHandler *handler) |
| void | register_broadcasted_handler (ESPNowBroadcastedHandler *handler) |
Public Member Functions inherited from esphome::Component | |
| float | get_actual_setup_priority () const |
| void | set_setup_priority (float priority) |
| virtual float | get_loop_priority () const |
| priority of loop(). | |
| void | call () |
| virtual void | on_shutdown () |
| virtual void | on_safe_shutdown () |
| virtual bool | teardown () |
| Called during teardown to allow component to gracefully finish operations. | |
| virtual void | on_powerdown () |
| Called after teardown is complete to power down hardware. | |
| uint8_t | get_component_state () const |
| void | reset_to_construction_state () |
| Reset this component back to the construction state to allow setup to run again. | |
| bool | is_in_loop_state () const |
| Check if this component has completed setup and is in the loop state. | |
| bool | is_idle () const |
| Check if this component is idle. | |
| virtual void | mark_failed () |
| Mark this component as failed. | |
| ESPDEPRECATED ("Use mark_failed(LOG_STR(\"static string literal\")) instead. Do NOT use .c_str() from temporary " "strings. Will stop working in 2026.6.0", "2025.12.0") void mark_failed(const char *message) | |
| void | mark_failed (const LogString *message) |
| void | disable_loop () |
| Disable this component's loop. | |
| void | enable_loop () |
| Enable this component's loop. | |
| void | enable_loop_soon_any_context () |
| Thread and ISR-safe version of enable_loop() that can be called from any context. | |
| bool | is_failed () const |
| bool | is_ready () const |
| virtual bool | can_proceed () |
| bool | status_has_warning () const |
| bool | status_has_error () const |
| void | status_set_warning (const char *message=nullptr) |
| void | status_set_warning (const LogString *message) |
| void | status_set_error () |
| ESPDEPRECATED ("Use status_set_error(LOG_STR(\"static string literal\")) instead. Do NOT use .c_str() from temporary " "strings. Will stop working in 2026.6.0", "2025.12.0") void status_set_error(const char *message) | |
| void | status_set_error (const LogString *message) |
| void | status_clear_warning () |
| void | status_clear_error () |
| void | status_momentary_warning (const char *name, uint32_t length=5000) |
| Set warning status flag and automatically clear it after a timeout. | |
| void | status_momentary_error (const char *name, uint32_t length=5000) |
| Set error status flag and automatically clear it after a timeout. | |
| bool | has_overridden_loop () const |
| void | set_component_source (const LogString *source) |
| Set where this component was loaded from for some debug messages. | |
| const LogString * | get_component_log_str () const |
| Get the integration where this component was declared as a LogString for logging. | |
| bool | should_warn_of_blocking (uint32_t blocking_time) |
Protected Member Functions | |
| void | enable_ () |
| void | send_ () |
Protected Member Functions inherited from esphome::Component | |
| virtual void | call_loop () |
| virtual void | call_setup () |
| virtual void | call_dump_config () |
| void | set_component_state_ (uint8_t state) |
| Helper to set component state (clears state bits and sets new state) | |
| void | set_interval (uint32_t id, uint32_t interval, std::function< void()> &&f) |
| Set an interval function with a numeric ID (zero heap allocation). | |
| void | set_interval (InternalSchedulerID id, uint32_t interval, std::function< void()> &&f) |
| void | set_interval (uint32_t interval, std::function< void()> &&f) |
| bool | cancel_interval (uint32_t id) |
| bool | cancel_interval (InternalSchedulerID id) |
| ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std | ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const char *name |
| ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(uint32_t id | |
| ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(uint32_t initial_wait_time | |
| ESPDEPRECATED("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(const std | ESPDEPRECATED ("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(const char *name) |
| ESPDEPRECATED ("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(uint32_t id) | |
| void | set_timeout (uint32_t id, uint32_t timeout, std::function< void()> &&f) |
| Set a timeout function with a numeric ID (zero heap allocation). | |
| void | set_timeout (InternalSchedulerID id, uint32_t timeout, std::function< void()> &&f) |
| void | set_timeout (uint32_t timeout, std::function< void()> &&f) |
| bool | cancel_timeout (uint32_t id) |
| bool | cancel_timeout (InternalSchedulerID id) |
| void | defer (std::function< void()> &&f) |
| Defer a callback to the next loop() call. | |
| void | defer (uint32_t id, std::function< void()> &&f) |
| Defer a callback with a numeric ID (zero heap allocation) | |
| bool | cancel_defer (uint32_t id) |
Protected Attributes | |
| std::vector< ESPNowUnknownPeerHandler * > | unknown_peer_handlers_ |
| std::vector< ESPNowReceivedPacketHandler * > | received_handlers_ |
| std::vector< ESPNowBroadcastedHandler * > | broadcasted_handlers_ |
| std::vector< ESPNowPeer > | peers_ {} |
| uint8_t | own_address_ [ESP_NOW_ETH_ALEN] {0} |
| LockFreeQueue< ESPNowPacket, MAX_ESP_NOW_RECEIVE_QUEUE_SIZE > | receive_packet_queue_ {} |
| EventPool< ESPNowPacket, MAX_ESP_NOW_RECEIVE_QUEUE_SIZE > | receive_packet_pool_ {} |
| LockFreeQueue< ESPNowSendPacket, MAX_ESP_NOW_SEND_QUEUE_SIZE > | send_packet_queue_ {} |
| EventPool< ESPNowSendPacket, MAX_ESP_NOW_SEND_QUEUE_SIZE > | send_packet_pool_ {} |
| ESPNowSendPacket * | current_send_packet_ {nullptr} |
| uint8_t | wifi_channel_ {0} |
| ESPNowState | state_ {ESPNOW_STATE_OFF} |
| bool | auto_add_peer_ {false} |
| bool | enable_on_boot_ {true} |
Protected Attributes inherited from esphome::Component | |
| ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") void set_interval(const std voi | set_interval )(const char *name, uint32_t interval, std::function< void()> &&f) |
| Set an interval function with a unique name. | |
| ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_interval(const std boo | cancel_interval )(const char *name) |
| Cancel an interval function. | |
| ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t | initial_wait_time |
| ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t | max_attempts |
| ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t std::function< RetryResult(uint8_t)> && | f |
| ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t std::function< RetryResult(uint8_t)> float | backoff_increase_factor = 1.0f) |
| uint32_t | initial_wait_time |
| uint32_t uint8_t | max_attempts |
| uint32_t uint8_t std::function< RetryResult(uint8_t)> && | f |
| uint32_t uint8_t std::function< RetryResult(uint8_t)> float | backoff_increase_factor = 1.0f) |
| uint8_t | max_attempts |
| uint8_t std::function< RetryResult(uint8_t)> && | f |
| uint8_t std::function< RetryResult(uint8_t)> float | backoff_increase_factor = 1.0f) |
| ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") void set_timeout(const std voi | set_timeout )(const char *name, uint32_t timeout, std::function< void()> &&f) |
| Set a timeout function with a unique name. | |
| ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_timeout(const std boo | cancel_timeout )(const char *name) |
| Cancel a timeout function. | |
| ESPDEPRECATED("Use const char* overload instead. Removed in 2026.7.0", "2026.1.0") void defer(const std voi | defer )(const char *name, std::function< void()> &&f) |
| Defer a callback to the next loop() call. | |
| ESPDEPRECATED("Use const char* overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_defer(const std boo | cancel_defer )(const char *name) |
| Cancel a defer callback using the specified name, name must not be empty. | |
| const LogString * | component_source_ {nullptr} |
| uint16_t | warn_if_blocking_over_ {WARN_IF_BLOCKING_OVER_MS} |
| Warn if blocked for this many ms (max 65.5s) | |
| uint8_t | component_state_ {0x00} |
| State of this component - each bit has a purpose: Bits 0-2: Component state (0x00=CONSTRUCTION, 0x01=SETUP, 0x02=LOOP, 0x03=FAILED, 0x04=LOOP_DONE) Bit 3: STATUS_LED_WARNING Bit 4: STATUS_LED_ERROR Bits 5-7: Unused - reserved for future expansion. | |
| volatile bool | pending_enable_loop_ {false} |
| ISR-safe flag for enable_loop_soon_any_context. | |
Definition at line 91 of file espnow_component.h.
| esphome::espnow::ESPNowComponent::ESPNowComponent | ( | ) |
Definition at line 120 of file espnow_component.cpp.
| esp_err_t esphome::espnow::ESPNowComponent::add_peer | ( | const uint8_t * | peer | ) |
Definition at line 419 of file espnow_component.cpp.
|
inline |
Definition at line 101 of file espnow_component.h.
| void esphome::espnow::ESPNowComponent::apply_wifi_channel | ( | ) |
Definition at line 243 of file espnow_component.cpp.
| esp_err_t esphome::espnow::ESPNowComponent::del_peer | ( | const uint8_t * | peer | ) |
Definition at line 460 of file espnow_component.cpp.
| void esphome::espnow::ESPNowComponent::disable | ( | ) |
Definition at line 227 of file espnow_component.cpp.
|
overridevirtual |
Reimplemented from esphome::Component.
Definition at line 122 of file espnow_component.cpp.
| void esphome::espnow::ESPNowComponent::enable | ( | ) |
Definition at line 165 of file espnow_component.cpp.
|
protected |
Definition at line 175 of file espnow_component.cpp.
|
inlineoverridevirtual |
Reimplemented from esphome::Component.
Definition at line 98 of file espnow_component.h.
| uint8_t esphome::espnow::ESPNowComponent::get_wifi_channel | ( | ) |
Definition at line 354 of file espnow_component.cpp.
|
inline |
Definition at line 119 of file espnow_component.h.
| bool esphome::espnow::ESPNowComponent::is_wifi_enabled | ( | ) |
Definition at line 143 of file espnow_component.cpp.
|
overridevirtual |
Reimplemented from esphome::Component.
Definition at line 262 of file espnow_component.cpp.
|
inline |
Definition at line 143 of file espnow_component.h.
|
inline |
Definition at line 139 of file espnow_component.h.
|
inline |
Definition at line 140 of file espnow_component.h.
|
inline |
Queue a packet to be sent to a specific peer address.
This method will add the packet to the internal queue and call the callback when the packet is sent. Only one packet will be sent at any given time and the next one will not be sent until the previous one has been acknowledged or failed.
| peer_address | MAC address of the peer to send the packet to |
| payload | Data payload to send |
| callback | Callback to call when the send operation is complete |
Definition at line 132 of file espnow_component.h.
| esp_err_t esphome::espnow::ESPNowComponent::send | ( | const uint8_t * | peer_address, |
| const uint8_t * | payload, | ||
| size_t | size, | ||
| const send_callback_t & | callback = nullptr ) |
Definition at line 360 of file espnow_component.cpp.
|
protected |
Definition at line 397 of file espnow_component.cpp.
|
inline |
Definition at line 115 of file espnow_component.h.
|
inline |
Definition at line 120 of file espnow_component.h.
|
inline |
Definition at line 111 of file espnow_component.h.
|
overridevirtual |
Reimplemented from esphome::Component.
Definition at line 151 of file espnow_component.cpp.
|
protected |
Definition at line 175 of file espnow_component.h.
|
protected |
Definition at line 160 of file espnow_component.h.
|
protected |
Definition at line 170 of file espnow_component.h.
|
protected |
Definition at line 176 of file espnow_component.h.
|
protected |
Definition at line 164 of file espnow_component.h.
|
protected |
Definition at line 162 of file espnow_component.h.
|
protected |
Definition at line 166 of file espnow_component.h.
|
protected |
Definition at line 165 of file espnow_component.h.
|
protected |
Definition at line 159 of file espnow_component.h.
|
protected |
Definition at line 169 of file espnow_component.h.
|
protected |
Definition at line 168 of file espnow_component.h.
|
protected |
Definition at line 173 of file espnow_component.h.
|
protected |
Definition at line 158 of file espnow_component.h.
|
protected |
Definition at line 172 of file espnow_component.h.