3 #ifdef USE_ESP32_FRAMEWORK_ARDUINO 9 #ifdef USE_WIFI_WPA2_EAP 12 #include "lwip/apps/sntp.h" 25 static const char *
const TAG =
"wifi_esp32";
27 static bool s_sta_connecting =
false;
30 uint8_t current_mode = WiFiClass::getMode();
31 bool current_sta = current_mode & 0b01;
32 bool current_ap = current_mode & 0b10;
33 bool enable_sta = sta.
value_or(current_sta);
34 bool enable_ap = ap.
value_or(current_ap);
35 if (current_sta == enable_sta && current_ap == enable_ap)
38 if (enable_sta && !current_sta) {
39 ESP_LOGV(TAG,
"Enabling STA.");
40 }
else if (!enable_sta && current_sta) {
41 ESP_LOGV(TAG,
"Disabling STA.");
43 if (enable_ap && !current_ap) {
44 ESP_LOGV(TAG,
"Enabling AP.");
45 }
else if (!enable_ap && current_ap) {
46 ESP_LOGV(TAG,
"Disabling AP.");
57 ESP_LOGW(TAG,
"Setting WiFi mode failed!");
63 int8_t
val =
static_cast<int8_t
>(output_power * 4);
64 return esp_wifi_set_max_tx_power(val) == ESP_OK;
70 WiFi.setAutoReconnect(
false);
75 wifi_ps_type_t power_save;
78 power_save = WIFI_PS_MIN_MODEM;
81 power_save = WIFI_PS_MAX_MODEM;
85 power_save = WIFI_PS_NONE;
88 return esp_wifi_set_ps(power_save) == ESP_OK;
95 tcpip_adapter_dhcp_status_t dhcp_status;
96 tcpip_adapter_dhcpc_get_status(TCPIP_ADAPTER_IF_STA, &dhcp_status);
101 sntp_servermode_dhcp(
false);
104 if (dhcp_status != TCPIP_ADAPTER_DHCP_STARTED) {
105 esp_err_t err = tcpip_adapter_dhcpc_start(TCPIP_ADAPTER_IF_STA);
107 ESP_LOGV(TAG,
"Starting DHCP client failed! %d", err);
109 return err == ESP_OK;
114 tcpip_adapter_ip_info_t info;
115 memset(&info, 0,
sizeof(info));
116 info.ip = manual_ip->static_ip;
117 info.gw = manual_ip->gateway;
118 info.netmask = manual_ip->subnet;
120 esp_err_t dhcp_stop_ret = tcpip_adapter_dhcpc_stop(TCPIP_ADAPTER_IF_STA);
121 if (dhcp_stop_ret != ESP_OK && dhcp_stop_ret != ESP_ERR_TCPIP_ADAPTER_DHCP_ALREADY_STOPPED) {
122 ESP_LOGV(TAG,
"Stopping DHCP client failed! %s", esp_err_to_name(dhcp_stop_ret));
125 esp_err_t wifi_set_info_ret = tcpip_adapter_set_ip_info(TCPIP_ADAPTER_IF_STA, &info);
126 if (wifi_set_info_ret != ESP_OK) {
127 ESP_LOGV(TAG,
"Setting manual IP info failed! %s", esp_err_to_name(wifi_set_info_ret));
133 dns.type = IPADDR_TYPE_V4;
135 if (manual_ip->dns1.is_set()) {
136 dns = manual_ip->dns1;
137 dns_setserver(0, &dns);
139 if (manual_ip->dns2.is_set()) {
140 dns = manual_ip->dns2;
141 dns_setserver(1, &dns);
151 tcpip_adapter_ip_info_t ip;
152 esp_err_t err = tcpip_adapter_get_ip_info(TCPIP_ADAPTER_IF_STA, &ip);
154 ESP_LOGV(TAG,
"esp_netif_get_ip_info failed: %s", esp_err_to_name(err));
162 err = tcpip_adapter_get_ip6_global(TCPIP_ADAPTER_IF_STA, &ipv6);
164 ESP_LOGV(TAG,
"esp_netif_get_ip6_gobal failed: %s", esp_err_to_name(err));
168 err = tcpip_adapter_get_ip6_linklocal(TCPIP_ADAPTER_IF_STA, &ipv6);
170 ESP_LOGV(TAG,
"esp_netif_get_ip6_linklocal failed: %s", esp_err_to_name(err));
190 memset(&conf, 0,
sizeof(conf));
191 strncpy(reinterpret_cast<char *>(conf.sta.ssid), ap.
get_ssid().c_str(),
sizeof(conf.sta.ssid));
192 strncpy(reinterpret_cast<char *>(conf.sta.password), ap.
get_password().c_str(),
sizeof(conf.sta.password));
196 conf.sta.threshold.authmode = WIFI_AUTH_OPEN;
198 conf.sta.threshold.authmode = WIFI_AUTH_WPA_WPA2_PSK;
201 #ifdef USE_WIFI_WPA2_EAP 202 if (ap.
get_eap().has_value()) {
203 conf.sta.threshold.authmode = WIFI_AUTH_WPA2_ENTERPRISE;
208 conf.sta.bssid_set =
true;
209 memcpy(conf.sta.bssid, ap.
get_bssid()->data(), 6);
211 conf.sta.bssid_set =
false;
215 conf.sta.scan_method = WIFI_FAST_SCAN;
217 conf.sta.scan_method = WIFI_ALL_CHANNEL_SCAN;
221 conf.sta.listen_interval = 0;
225 conf.sta.pmf_cfg.capable =
true;
226 conf.sta.pmf_cfg.required =
false;
230 conf.sta.threshold.rssi = -127;
232 conf.sta.threshold.authmode = WIFI_AUTH_OPEN;
234 wifi_config_t current_conf;
236 esp_wifi_get_config(WIFI_IF_STA, ¤t_conf);
238 if (memcmp(¤t_conf, &conf,
sizeof(wifi_config_t)) != 0) {
239 err = esp_wifi_disconnect();
241 ESP_LOGV(TAG,
"esp_wifi_disconnect failed! %d", err);
246 err = esp_wifi_set_config(WIFI_IF_STA, &conf);
248 ESP_LOGV(TAG,
"esp_wifi_set_config failed! %d", err);
256 #ifdef USE_WIFI_WPA2_EAP 257 if (ap.
get_eap().has_value()) {
260 err = esp_wifi_sta_wpa2_ent_set_identity((uint8_t *) eap.
identity.c_str(), eap.
identity.length());
262 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_identity failed! %d", err);
264 int ca_cert_len = strlen(eap.
ca_cert);
268 err = esp_wifi_sta_wpa2_ent_set_ca_cert((uint8_t *) eap.
ca_cert, ca_cert_len + 1);
270 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_ca_cert failed! %d", err);
275 if (client_cert_len && client_key_len) {
277 err = esp_wifi_sta_wpa2_ent_set_cert_key((uint8_t *) eap.
client_cert, client_cert_len + 1,
278 (uint8_t *) eap.
client_key, client_key_len + 1,
281 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_cert_key failed! %d", err);
285 err = esp_wifi_sta_wpa2_ent_set_username((uint8_t *) eap.
username.c_str(), eap.
username.length());
287 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_username failed! %d", err);
289 err = esp_wifi_sta_wpa2_ent_set_password((uint8_t *) eap.
password.c_str(), eap.
password.length());
291 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_password failed! %d", err);
294 err = esp_wifi_sta_wpa2_ent_enable();
296 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_enable failed! %d", err);
299 #endif // USE_WIFI_WPA2_EAP 303 s_sta_connecting =
true;
305 err = esp_wifi_connect();
307 ESP_LOGW(TAG,
"esp_wifi_connect failed! %d", err);
319 case WIFI_AUTH_WPA_PSK:
321 case WIFI_AUTH_WPA2_PSK:
323 case WIFI_AUTH_WPA_WPA2_PSK:
324 return "WPA/WPA2 PSK";
325 case WIFI_AUTH_WPA2_ENTERPRISE:
326 return "WPA2 Enterprise";
336 sprintf(buf,
"%u.%u.%u.%u", uint8_t(ip.addr >> 0), uint8_t(ip.addr >> 8), uint8_t(ip.addr >> 16),
337 uint8_t(ip.addr >> 24));
356 case WIFI_REASON_AUTH_EXPIRE:
357 return "Auth Expired";
358 case WIFI_REASON_AUTH_LEAVE:
360 case WIFI_REASON_ASSOC_EXPIRE:
361 return "Association Expired";
362 case WIFI_REASON_ASSOC_TOOMANY:
363 return "Too Many Associations";
364 case WIFI_REASON_NOT_AUTHED:
365 return "Not Authenticated";
366 case WIFI_REASON_NOT_ASSOCED:
367 return "Not Associated";
368 case WIFI_REASON_ASSOC_LEAVE:
369 return "Association Leave";
370 case WIFI_REASON_ASSOC_NOT_AUTHED:
371 return "Association not Authenticated";
372 case WIFI_REASON_DISASSOC_PWRCAP_BAD:
373 return "Disassociate Power Cap Bad";
374 case WIFI_REASON_DISASSOC_SUPCHAN_BAD:
375 return "Disassociate Supported Channel Bad";
376 case WIFI_REASON_IE_INVALID:
378 case WIFI_REASON_MIC_FAILURE:
379 return "Mic Failure";
380 case WIFI_REASON_4WAY_HANDSHAKE_TIMEOUT:
381 return "4-Way Handshake Timeout";
382 case WIFI_REASON_GROUP_KEY_UPDATE_TIMEOUT:
383 return "Group Key Update Timeout";
384 case WIFI_REASON_IE_IN_4WAY_DIFFERS:
385 return "IE In 4-Way Handshake Differs";
386 case WIFI_REASON_GROUP_CIPHER_INVALID:
387 return "Group Cipher Invalid";
388 case WIFI_REASON_PAIRWISE_CIPHER_INVALID:
389 return "Pairwise Cipher Invalid";
390 case WIFI_REASON_AKMP_INVALID:
391 return "AKMP Invalid";
392 case WIFI_REASON_UNSUPP_RSN_IE_VERSION:
393 return "Unsupported RSN IE version";
394 case WIFI_REASON_INVALID_RSN_IE_CAP:
395 return "Invalid RSN IE Cap";
396 case WIFI_REASON_802_1X_AUTH_FAILED:
397 return "802.1x Authentication Failed";
398 case WIFI_REASON_CIPHER_SUITE_REJECTED:
399 return "Cipher Suite Rejected";
400 case WIFI_REASON_BEACON_TIMEOUT:
401 return "Beacon Timeout";
402 case WIFI_REASON_NO_AP_FOUND:
403 return "AP Not Found";
404 case WIFI_REASON_AUTH_FAIL:
405 return "Authentication Failed";
406 case WIFI_REASON_ASSOC_FAIL:
407 return "Association Failed";
408 case WIFI_REASON_HANDSHAKE_TIMEOUT:
409 return "Handshake Failed";
410 case WIFI_REASON_CONNECTION_FAIL:
411 return "Connection Failed";
412 case WIFI_REASON_UNSPECIFIED:
414 return "Unspecified";
418 #define ESPHOME_EVENT_ID_WIFI_READY ARDUINO_EVENT_WIFI_READY 419 #define ESPHOME_EVENT_ID_WIFI_SCAN_DONE ARDUINO_EVENT_WIFI_SCAN_DONE 420 #define ESPHOME_EVENT_ID_WIFI_STA_START ARDUINO_EVENT_WIFI_STA_START 421 #define ESPHOME_EVENT_ID_WIFI_STA_STOP ARDUINO_EVENT_WIFI_STA_STOP 422 #define ESPHOME_EVENT_ID_WIFI_STA_CONNECTED ARDUINO_EVENT_WIFI_STA_CONNECTED 423 #define ESPHOME_EVENT_ID_WIFI_STA_DISCONNECTED ARDUINO_EVENT_WIFI_STA_DISCONNECTED 424 #define ESPHOME_EVENT_ID_WIFI_STA_AUTHMODE_CHANGE ARDUINO_EVENT_WIFI_STA_AUTHMODE_CHANGE 425 #define ESPHOME_EVENT_ID_WIFI_STA_GOT_IP ARDUINO_EVENT_WIFI_STA_GOT_IP 426 #define ESPHOME_EVENT_ID_WIFI_STA_GOT_IP6 ARDUINO_EVENT_WIFI_STA_GOT_IP6 427 #define ESPHOME_EVENT_ID_WIFI_STA_LOST_IP ARDUINO_EVENT_WIFI_STA_LOST_IP 428 #define ESPHOME_EVENT_ID_WIFI_AP_START ARDUINO_EVENT_WIFI_AP_START 429 #define ESPHOME_EVENT_ID_WIFI_AP_STOP ARDUINO_EVENT_WIFI_AP_STOP 430 #define ESPHOME_EVENT_ID_WIFI_AP_STACONNECTED ARDUINO_EVENT_WIFI_AP_STACONNECTED 431 #define ESPHOME_EVENT_ID_WIFI_AP_STADISCONNECTED ARDUINO_EVENT_WIFI_AP_STADISCONNECTED 432 #define ESPHOME_EVENT_ID_WIFI_AP_STAIPASSIGNED ARDUINO_EVENT_WIFI_AP_STAIPASSIGNED 433 #define ESPHOME_EVENT_ID_WIFI_AP_PROBEREQRECVED ARDUINO_EVENT_WIFI_AP_PROBEREQRECVED 434 #define ESPHOME_EVENT_ID_WIFI_AP_GOT_IP6 ARDUINO_EVENT_WIFI_AP_GOT_IP6 440 case ESPHOME_EVENT_ID_WIFI_READY: {
441 ESP_LOGV(TAG,
"Event: WiFi ready");
444 case ESPHOME_EVENT_ID_WIFI_SCAN_DONE: {
445 auto it = info.wifi_scan_done;
446 ESP_LOGV(TAG,
"Event: WiFi Scan Done status=%u number=%u scan_id=%u", it.status, it.number, it.scan_id);
451 case ESPHOME_EVENT_ID_WIFI_STA_START: {
452 ESP_LOGV(TAG,
"Event: WiFi STA start");
453 tcpip_adapter_set_hostname(TCPIP_ADAPTER_IF_STA,
App.
get_name().c_str());
456 case ESPHOME_EVENT_ID_WIFI_STA_STOP: {
457 ESP_LOGV(TAG,
"Event: WiFi STA stop");
460 case ESPHOME_EVENT_ID_WIFI_STA_CONNECTED: {
461 auto it = info.wifi_sta_connected;
463 memcpy(buf, it.ssid, it.ssid_len);
464 buf[it.ssid_len] =
'\0';
465 ESP_LOGV(TAG,
"Event: Connected ssid='%s' bssid=" LOG_SECRET(
"%s")
" channel=%u, authmode=%s", buf,
473 case ESPHOME_EVENT_ID_WIFI_STA_DISCONNECTED: {
474 auto it = info.wifi_sta_disconnected;
476 memcpy(buf, it.ssid, it.ssid_len);
477 buf[it.ssid_len] =
'\0';
478 if (it.reason == WIFI_REASON_NO_AP_FOUND) {
479 ESP_LOGW(TAG,
"Event: Disconnected ssid='%s' reason='Probe Request Unsuccessful'", buf);
481 ESP_LOGW(TAG,
"Event: Disconnected ssid='%s' bssid=" LOG_SECRET(
"%s")
" reason='%s'", buf,
485 uint8_t reason = it.reason;
486 if (reason == WIFI_REASON_AUTH_EXPIRE || reason == WIFI_REASON_BEACON_TIMEOUT ||
487 reason == WIFI_REASON_NO_AP_FOUND || reason == WIFI_REASON_ASSOC_FAIL ||
488 reason == WIFI_REASON_HANDSHAKE_TIMEOUT) {
489 err_t err = esp_wifi_disconnect();
491 ESP_LOGV(TAG,
"Disconnect failed: %s", esp_err_to_name(err));
496 s_sta_connecting =
false;
499 case ESPHOME_EVENT_ID_WIFI_STA_AUTHMODE_CHANGE: {
500 auto it = info.wifi_sta_authmode_change;
501 ESP_LOGV(TAG,
"Event: Authmode Change old=%s new=%s",
get_auth_mode_str(it.old_mode),
505 if (it.old_mode != WIFI_AUTH_OPEN && it.new_mode == WIFI_AUTH_OPEN) {
506 ESP_LOGW(TAG,
"Potential Authmode downgrade detected, disconnecting...");
509 err_t err = esp_wifi_disconnect();
511 ESP_LOGW(TAG,
"Disconnect failed: %s", esp_err_to_name(err));
517 case ESPHOME_EVENT_ID_WIFI_STA_GOT_IP: {
518 auto it = info.got_ip.ip_info;
519 ESP_LOGV(TAG,
"Event: Got IP static_ip=%s gateway=%s",
format_ip4_addr(it.ip).c_str(),
525 s_sta_connecting =
false;
530 case ESPHOME_EVENT_ID_WIFI_STA_GOT_IP6: {
531 auto it = info.got_ip6.ip6_info;
532 ESP_LOGV(TAG,
"Got IPv6 address=" IPV6STR, IPV62STR(it.ip));
538 case ESPHOME_EVENT_ID_WIFI_STA_LOST_IP: {
539 ESP_LOGV(TAG,
"Event: Lost IP");
543 case ESPHOME_EVENT_ID_WIFI_AP_START: {
544 ESP_LOGV(TAG,
"Event: WiFi AP start");
547 case ESPHOME_EVENT_ID_WIFI_AP_STOP: {
548 ESP_LOGV(TAG,
"Event: WiFi AP stop");
551 case ESPHOME_EVENT_ID_WIFI_AP_STACONNECTED: {
552 auto it = info.wifi_sta_connected;
553 auto &mac = it.bssid;
554 ESP_LOGV(TAG,
"Event: AP client connected MAC=%s",
format_mac_addr(mac).c_str());
557 case ESPHOME_EVENT_ID_WIFI_AP_STADISCONNECTED: {
558 auto it = info.wifi_sta_disconnected;
559 auto &mac = it.bssid;
560 ESP_LOGV(TAG,
"Event: AP client disconnected MAC=%s",
format_mac_addr(mac).c_str());
563 case ESPHOME_EVENT_ID_WIFI_AP_STAIPASSIGNED: {
564 ESP_LOGV(TAG,
"Event: AP client assigned IP");
567 case ESPHOME_EVENT_ID_WIFI_AP_PROBEREQRECVED: {
568 auto it = info.wifi_ap_probereqrecved;
569 ESP_LOGVV(TAG,
"Event: AP receive Probe Request MAC=%s RSSI=%d",
format_mac_addr(it.mac).c_str(), it.rssi);
579 WiFi.persistent(
false);
585 if (
status == WL_CONNECT_FAILED ||
status == WL_CONNECTION_LOST) {
587 }
else if (
status == WL_NO_SSID_AVAIL) {
589 }
else if (s_sta_connecting) {
591 }
else if (
status == WL_CONNECTED) {
602 int16_t err = WiFi.scanNetworks(
true,
true, passive, 200);
603 if (err != WIFI_SCAN_RUNNING) {
604 ESP_LOGV(TAG,
"WiFi.scanNetworks failed! %d", err);
613 int16_t num = WiFi.scanComplete();
617 this->
scan_result_.reserve(static_cast<unsigned int>(num));
618 for (
int i = 0; i < num; i++) {
619 String ssid = WiFi.SSID(i);
620 wifi_auth_mode_t authmode = WiFi.encryptionType(i);
621 int32_t rssi = WiFi.RSSI(i);
622 uint8_t *bssid = WiFi.BSSID(i);
623 int32_t channel = WiFi.channel(i);
625 WiFiScanResult scan({bssid[0], bssid[1], bssid[2], bssid[3], bssid[4], bssid[5]}, std::string(ssid.c_str()),
626 channel, rssi, authmode != WIFI_AUTH_OPEN, ssid.length() == 0);
641 tcpip_adapter_ip_info_t info;
642 memset(&info, 0,
sizeof(info));
644 info.ip = manual_ip->static_ip;
645 info.gw = manual_ip->gateway;
646 info.netmask = manual_ip->subnet;
652 tcpip_adapter_dhcp_status_t dhcp_status;
653 tcpip_adapter_dhcps_get_status(TCPIP_ADAPTER_IF_AP, &dhcp_status);
654 err = tcpip_adapter_dhcps_stop(TCPIP_ADAPTER_IF_AP);
656 ESP_LOGV(TAG,
"tcpip_adapter_dhcps_stop failed! %d", err);
660 err = tcpip_adapter_set_ip_info(TCPIP_ADAPTER_IF_AP, &info);
662 ESP_LOGV(TAG,
"tcpip_adapter_set_ip_info failed! %d", err);
670 lease.start_ip = start_address;
671 ESP_LOGV(TAG,
"DHCP server IP lease start: %s", start_address.
str().c_str());
672 start_address += 100;
673 lease.end_ip = start_address;
674 ESP_LOGV(TAG,
"DHCP server IP lease end: %s", start_address.str().c_str());
675 err = tcpip_adapter_dhcps_option(TCPIP_ADAPTER_OP_SET, TCPIP_ADAPTER_REQUESTED_IP_ADDRESS, &lease,
sizeof(lease));
678 ESP_LOGV(TAG,
"tcpip_adapter_dhcps_option failed! %d", err);
682 err = tcpip_adapter_dhcps_start(TCPIP_ADAPTER_IF_AP);
685 ESP_LOGV(TAG,
"tcpip_adapter_dhcps_start failed! %d", err);
698 memset(&conf, 0,
sizeof(conf));
699 strncpy(reinterpret_cast<char *>(conf.ap.ssid), ap.
get_ssid().c_str(),
sizeof(conf.ap.ssid));
701 conf.ap.ssid_hidden = ap.
get_ssid().size();
702 conf.ap.max_connection = 5;
703 conf.ap.beacon_interval = 100;
706 conf.ap.authmode = WIFI_AUTH_OPEN;
707 *conf.ap.password = 0;
709 conf.ap.authmode = WIFI_AUTH_WPA2_PSK;
710 strncpy(reinterpret_cast<char *>(conf.ap.password), ap.
get_password().c_str(),
sizeof(conf.ap.password));
713 conf.ap.pairwise_cipher = WIFI_CIPHER_TYPE_CCMP;
715 esp_err_t err = esp_wifi_set_config(WIFI_IF_AP, &conf);
717 ESP_LOGV(TAG,
"esp_wifi_set_config failed! %d", err);
724 ESP_LOGV(TAG,
"wifi_ap_ip_config_ failed!");
732 tcpip_adapter_ip_info_t ip;
733 tcpip_adapter_get_ip_info(TCPIP_ADAPTER_IF_AP, &ip);
736 #endif // USE_WIFI_AP 742 uint8_t *raw_bssid = WiFi.BSSID();
743 if (raw_bssid !=
nullptr) {
744 for (
size_t i = 0; i < bssid.size(); i++)
745 bssid[i] = raw_bssid[i];
760 #endif // USE_ESP32_FRAMEWORK_ARDUINO
WiFiSTAConnectStatus wifi_sta_connect_status_()
std::array< uint8_t, 6 > bssid_t
const optional< EAPAuth > & get_eap() const
static std::string format_mac_addr(const uint8_t mac[6])
const std::string & get_password() const
WiFiPowerSaveMode power_save_
network::IPAddress wifi_dns_ip_(int num)
network::IPAddresses wifi_sta_ip_addresses()
bool wifi_mode_(optional< bool > sta, optional< bool > ap)
const optional< bssid_t > & get_bssid() const
void set_timeout(const std::string &name, uint32_t timeout, std::function< void()> &&f)
Set a timeout function with a unique name.
bool wifi_apply_output_power_(float output_power)
esp_ip4_addr_t esphome_ip4_addr_t
bool wifi_sta_ip_config_(optional< ManualIP > manual_ip)
network::IPAddress wifi_subnet_mask_()
bool wifi_apply_hostname_()
bool error_from_callback_
const char * get_op_mode_str(uint8_t mode)
std::vector< WiFiScanResult > scan_result_
bool wifi_start_ap_(const WiFiAP &ap)
const optional< ManualIP > & get_manual_ip() const
const optional< uint8_t > & get_channel() const
arduino_event_id_t esphome_wifi_event_id_t
BedjetMode mode
BedJet operating mode.
bool wifi_apply_power_save_()
Application App
Global storage of Application pointer - only one Application can exist.
bool wifi_ap_ip_config_(optional< ManualIP > manual_ip)
const std::string & get_name() const
Get the name of this Application set by pre_setup().
std::array< IPAddress, 5 > IPAddresses
network::IPAddress wifi_soft_ap_ip()
void wifi_event_callback_(arduino_event_id_t event, arduino_event_info_t info)
arduino_event_info_t esphome_wifi_event_info_t
bool wifi_sta_pre_setup_()
const char * get_auth_mode_str(uint8_t mode)
void IRAM_ATTR HOT yield()
network::IPAddress wifi_gateway_ip_()
bool wifi_scan_start_(bool passive)
uint8_t num_ipv6_addresses_
This is a workaround until we can figure out a way to get the tflite-micro idf component code availab...
std::string format_ip4_addr(const esphome_ip4_addr_t &ip)
const std::string & get_ssid() const
const char * get_disconnect_reason_str(uint8_t reason)
void wifi_scan_done_callback_()
value_type value_or(U const &v) const
bool wifi_sta_connect_(const WiFiAP &ap)
void IRAM_ATTR HOT delay(uint32_t ms)