ESPHome 2025.6.3
Loading...
Searching...
No Matches
esphome::api::APIPlaintextFrameHelper Class Reference

#include <api_frame_helper.h>

Inheritance diagram for esphome::api::APIPlaintextFrameHelper:
esphome::api::APIFrameHelper

Public Member Functions

 APIPlaintextFrameHelper (std::unique_ptr< socket::Socket > socket)
 
 ~APIPlaintextFrameHelper () override=default
 
APIError init () override
 Initialize the frame helper, returns OK if successful.
 
APIError loop () override
 Not used for plaintext.
 
APIError read_packet (ReadPacketBuffer *buffer) override
 
APIError write_protobuf_packet (uint16_t type, ProtoWriteBuffer buffer) override
 
APIError write_protobuf_packets (ProtoWriteBuffer buffer, const std::vector< PacketInfo > &packets) override
 
uint8_t frame_header_padding () override
 
uint8_t frame_footer_size () override
 
- Public Member Functions inherited from esphome::api::APIFrameHelper
 APIFrameHelper ()=default
 
 APIFrameHelper (std::unique_ptr< socket::Socket > socket)
 
virtual ~APIFrameHelper ()=default
 
bool can_write_without_blocking ()
 
std::string getpeername ()
 
int getpeername (struct sockaddr *addr, socklen_t *addrlen)
 
APIError close ()
 
APIError shutdown (int how)
 
void set_log_info (std::string info)
 
bool is_socket_ready () const
 

Protected Member Functions

APIError try_read_frame_ (ParsedFrame *frame)
 Read a packet into the rx_buf_.
 
- Protected Member Functions inherited from esphome::api::APIFrameHelper
APIError write_raw_ (const struct iovec *iov, int iovcnt)
 
APIError try_send_tx_buf_ ()
 
void buffer_data_from_iov_ (const struct iovec *iov, int iovcnt, uint16_t total_write_len)
 
template<typename StateEnum >
APIError write_raw_ (const struct iovec *iov, int iovcnt, socket::Socket *socket, std::vector< uint8_t > &tx_buf, const std::string &info, StateEnum &state, StateEnum failed_state)
 
APIError init_common_ ()
 

Protected Attributes

uint8_t rx_header_buf_ [6]
 
uint8_t rx_header_buf_pos_ = 0
 
bool rx_header_parsed_ = false
 
uint16_t rx_header_parsed_type_ = 0
 
uint16_t rx_header_parsed_len_ = 0
 
- Protected Attributes inherited from esphome::api::APIFrameHelper
std::deque< SendBuffertx_buf_
 
State state_ {State::INITIALIZE}
 
std::string info_
 
socket::Socketsocket_ {nullptr}
 
std::unique_ptr< socket::Socketsocket_owned_
 
uint8_t frame_header_padding_ {0}
 
uint8_t frame_footer_size_ {0}
 
std::vector< struct iovecreusable_iovs_
 
std::vector< uint8_t > rx_buf_
 
uint16_t rx_buf_len_ = 0
 

Additional Inherited Members

- Protected Types inherited from esphome::api::APIFrameHelper
enum class  State {
  INITIALIZE = 1 , CLIENT_HELLO = 2 , SERVER_HELLO = 3 , HANDSHAKE = 4 ,
  DATA = 5 , CLOSED = 6 , FAILED = 7 , EXPLICIT_REJECT = 8
}
 

Detailed Description

Definition at line 233 of file api_frame_helper.h.

Constructor & Destructor Documentation

◆ APIPlaintextFrameHelper()

esphome::api::APIPlaintextFrameHelper::APIPlaintextFrameHelper ( std::unique_ptr< socket::Socket > socket)
inline

Definition at line 235 of file api_frame_helper.h.

◆ ~APIPlaintextFrameHelper()

esphome::api::APIPlaintextFrameHelper::~APIPlaintextFrameHelper ( )
overridedefault

Member Function Documentation

◆ frame_footer_size()

uint8_t esphome::api::APIPlaintextFrameHelper::frame_footer_size ( )
inlineoverridevirtual

Implements esphome::api::APIFrameHelper.

Definition at line 251 of file api_frame_helper.h.

◆ frame_header_padding()

uint8_t esphome::api::APIPlaintextFrameHelper::frame_header_padding ( )
inlineoverridevirtual

Implements esphome::api::APIFrameHelper.

Definition at line 249 of file api_frame_helper.h.

◆ init()

APIError esphome::api::APIPlaintextFrameHelper::init ( )
overridevirtual

Initialize the frame helper, returns OK if successful.

Implements esphome::api::APIFrameHelper.

Definition at line 816 of file api_frame_helper.cpp.

◆ loop()

APIError esphome::api::APIPlaintextFrameHelper::loop ( )
overridevirtual

Not used for plaintext.

Implements esphome::api::APIFrameHelper.

Definition at line 826 of file api_frame_helper.cpp.

◆ read_packet()

APIError esphome::api::APIPlaintextFrameHelper::read_packet ( ReadPacketBuffer * buffer)
overridevirtual

Implements esphome::api::APIFrameHelper.

Definition at line 990 of file api_frame_helper.cpp.

◆ try_read_frame_()

APIError esphome::api::APIPlaintextFrameHelper::try_read_frame_ ( ParsedFrame * frame)
protected

Read a packet into the rx_buf_.

If successful, stores frame data in the frame parameter

Parameters
frameThe struct to hold the frame information in. msg: store the parsed frame in that struct
Returns
See APIError

error API_ERROR_BAD_INDICATOR: Bad indicator byte at start of frame.

Definition at line 848 of file api_frame_helper.cpp.

◆ write_protobuf_packet()

APIError esphome::api::APIPlaintextFrameHelper::write_protobuf_packet ( uint16_t type,
ProtoWriteBuffer buffer )
overridevirtual

Implements esphome::api::APIFrameHelper.

Definition at line 1028 of file api_frame_helper.cpp.

◆ write_protobuf_packets()

APIError esphome::api::APIPlaintextFrameHelper::write_protobuf_packets ( ProtoWriteBuffer buffer,
const std::vector< PacketInfo > & packets )
overridevirtual

Implements esphome::api::APIFrameHelper.

Definition at line 1039 of file api_frame_helper.cpp.

Field Documentation

◆ rx_header_buf_

uint8_t esphome::api::APIPlaintextFrameHelper::rx_header_buf_[6]
protected

Definition at line 263 of file api_frame_helper.h.

◆ rx_header_buf_pos_

uint8_t esphome::api::APIPlaintextFrameHelper::rx_header_buf_pos_ = 0
protected

Definition at line 264 of file api_frame_helper.h.

◆ rx_header_parsed_

bool esphome::api::APIPlaintextFrameHelper::rx_header_parsed_ = false
protected

Definition at line 265 of file api_frame_helper.h.

◆ rx_header_parsed_len_

uint16_t esphome::api::APIPlaintextFrameHelper::rx_header_parsed_len_ = 0
protected

Definition at line 267 of file api_frame_helper.h.

◆ rx_header_parsed_type_

uint16_t esphome::api::APIPlaintextFrameHelper::rx_header_parsed_type_ = 0
protected

Definition at line 266 of file api_frame_helper.h.


The documentation for this class was generated from the following files: