3 #ifdef USE_ESP32_FRAMEWORK_ARDUINO 10 #ifdef USE_WIFI_WPA2_EAP 13 #include "lwip/apps/sntp.h" 26 static const char *
const TAG =
"wifi_esp32";
28 static esp_netif_t *s_sta_netif =
nullptr;
30 static esp_netif_t *s_ap_netif =
nullptr;
33 static bool s_sta_connecting =
false;
38 WiFi.persistent(
false);
44 wifi_mode_t current_mode = WiFiClass::getMode();
45 bool current_sta = current_mode == WIFI_MODE_STA || current_mode == WIFI_MODE_APSTA;
46 bool current_ap = current_mode == WIFI_MODE_AP || current_mode == WIFI_MODE_APSTA;
52 if (set_sta && set_ap) {
53 set_mode = WIFI_MODE_APSTA;
54 }
else if (set_sta && !set_ap) {
55 set_mode = WIFI_MODE_STA;
56 }
else if (!set_sta && set_ap) {
57 set_mode = WIFI_MODE_AP;
59 set_mode = WIFI_MODE_NULL;
62 if (current_mode == set_mode)
65 if (set_sta && !current_sta) {
66 ESP_LOGV(TAG,
"Enabling STA.");
67 }
else if (!set_sta && current_sta) {
68 ESP_LOGV(TAG,
"Disabling STA.");
70 if (set_ap && !current_ap) {
71 ESP_LOGV(TAG,
"Enabling AP.");
72 }
else if (!set_ap && current_ap) {
73 ESP_LOGV(TAG,
"Disabling AP.");
79 ESP_LOGW(TAG,
"Setting WiFi mode failed!");
86 s_sta_netif = esp_netif_get_handle_from_ifkey(
"WIFI_STA_DEF");
89 s_ap_netif = esp_netif_get_handle_from_ifkey(
"WIFI_AP_DEF");
99 WiFi.setAutoReconnect(
false);
105 int8_t
val =
static_cast<int8_t
>(output_power * 4);
106 return esp_wifi_set_max_tx_power(val) == ESP_OK;
110 wifi_ps_type_t power_save;
113 power_save = WIFI_PS_MIN_MODEM;
116 power_save = WIFI_PS_MAX_MODEM;
120 power_save = WIFI_PS_NONE;
123 return esp_wifi_set_ps(power_save) == ESP_OK;
133 memset(&conf, 0,
sizeof(conf));
134 strncpy(reinterpret_cast<char *>(conf.sta.ssid), ap.
get_ssid().c_str(),
sizeof(conf.sta.ssid));
135 strncpy(reinterpret_cast<char *>(conf.sta.password), ap.
get_password().c_str(),
sizeof(conf.sta.password));
139 conf.sta.threshold.authmode = WIFI_AUTH_OPEN;
141 conf.sta.threshold.authmode = WIFI_AUTH_WPA_WPA2_PSK;
144 #ifdef USE_WIFI_WPA2_EAP 145 if (ap.
get_eap().has_value()) {
146 conf.sta.threshold.authmode = WIFI_AUTH_WPA2_ENTERPRISE;
151 conf.sta.bssid_set =
true;
152 memcpy(conf.sta.bssid, ap.
get_bssid()->data(), 6);
154 conf.sta.bssid_set =
false;
158 conf.sta.scan_method = WIFI_FAST_SCAN;
160 conf.sta.scan_method = WIFI_ALL_CHANNEL_SCAN;
164 conf.sta.listen_interval = 0;
168 conf.sta.pmf_cfg.capable =
true;
169 conf.sta.pmf_cfg.required =
false;
173 conf.sta.threshold.rssi = -127;
175 conf.sta.threshold.authmode = WIFI_AUTH_OPEN;
177 wifi_config_t current_conf;
179 err = esp_wifi_get_config(WIFI_IF_STA, ¤t_conf);
181 ESP_LOGW(TAG,
"esp_wifi_get_config failed: %s", esp_err_to_name(err));
185 if (memcmp(¤t_conf, &conf,
sizeof(wifi_config_t)) != 0) {
186 err = esp_wifi_disconnect();
188 ESP_LOGV(TAG,
"esp_wifi_disconnect failed: %s", esp_err_to_name(err));
193 err = esp_wifi_set_config(WIFI_IF_STA, &conf);
195 ESP_LOGV(TAG,
"esp_wifi_set_config failed: %s", esp_err_to_name(err));
204 #ifdef USE_WIFI_WPA2_EAP 205 if (ap.
get_eap().has_value()) {
208 err = esp_wifi_sta_wpa2_ent_set_identity((uint8_t *) eap.
identity.c_str(), eap.
identity.length());
210 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_identity failed! %d", err);
212 int ca_cert_len = strlen(eap.
ca_cert);
216 err = esp_wifi_sta_wpa2_ent_set_ca_cert((uint8_t *) eap.
ca_cert, ca_cert_len + 1);
218 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_ca_cert failed! %d", err);
223 if (client_cert_len && client_key_len) {
225 err = esp_wifi_sta_wpa2_ent_set_cert_key((uint8_t *) eap.
client_cert, client_cert_len + 1,
226 (uint8_t *) eap.
client_key, client_key_len + 1,
229 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_cert_key failed! %d", err);
233 err = esp_wifi_sta_wpa2_ent_set_username((uint8_t *) eap.
username.c_str(), eap.
username.length());
235 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_username failed! %d", err);
237 err = esp_wifi_sta_wpa2_ent_set_password((uint8_t *) eap.
password.c_str(), eap.
password.length());
239 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_set_password failed! %d", err);
242 err = esp_wifi_sta_wpa2_ent_enable();
244 ESP_LOGV(TAG,
"esp_wifi_sta_wpa2_ent_enable failed! %d", err);
247 #endif // USE_WIFI_WPA2_EAP 251 s_sta_connecting =
true;
253 err = esp_wifi_connect();
255 ESP_LOGW(TAG,
"esp_wifi_connect failed: %s", esp_err_to_name(err));
267 esp_netif_dhcp_status_t dhcp_status;
268 esp_err_t err = esp_netif_dhcpc_get_status(s_sta_netif, &dhcp_status);
270 ESP_LOGV(TAG,
"esp_netif_dhcpc_get_status failed: %s", esp_err_to_name(err));
278 sntp_servermode_dhcp(
false);
281 if (dhcp_status != ESP_NETIF_DHCP_STARTED) {
282 err = esp_netif_dhcpc_start(s_sta_netif);
284 ESP_LOGV(TAG,
"Starting DHCP client failed! %d", err);
286 return err == ESP_OK;
291 esp_netif_ip_info_t info;
292 info.ip = manual_ip->static_ip;
293 info.gw = manual_ip->gateway;
294 info.netmask = manual_ip->subnet;
295 err = esp_netif_dhcpc_stop(s_sta_netif);
296 if (err != ESP_OK && err != ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED) {
297 ESP_LOGV(TAG,
"Stopping DHCP client failed! %s", esp_err_to_name(err));
300 err = esp_netif_set_ip_info(s_sta_netif, &info);
302 ESP_LOGV(TAG,
"Setting manual IP info failed! %s", esp_err_to_name(err));
305 esp_netif_dns_info_t dns;
306 if (manual_ip->dns1.is_set()) {
307 dns.ip = manual_ip->dns1;
308 esp_netif_set_dns_info(s_sta_netif, ESP_NETIF_DNS_MAIN, &dns);
310 if (manual_ip->dns2.is_set()) {
311 dns.ip = manual_ip->dns2;
312 esp_netif_set_dns_info(s_sta_netif, ESP_NETIF_DNS_BACKUP, &dns);
322 esp_netif_ip_info_t ip;
323 esp_err_t err = esp_netif_get_ip_info(s_sta_netif, &ip);
325 ESP_LOGV(TAG,
"esp_netif_get_ip_info failed: %s", esp_err_to_name(err));
332 struct esp_ip6_addr if_ip6s[CONFIG_LWIP_IPV6_NUM_ADDRESSES];
334 count = esp_netif_get_all_ip6(s_sta_netif, if_ip6s);
335 assert(count <= CONFIG_LWIP_IPV6_NUM_ADDRESSES);
336 for (
int i = 0; i < count; i++) {
353 case WIFI_AUTH_WPA_PSK:
355 case WIFI_AUTH_WPA2_PSK:
357 case WIFI_AUTH_WPA_WPA2_PSK:
358 return "WPA/WPA2 PSK";
359 case WIFI_AUTH_WPA2_ENTERPRISE:
360 return "WPA2 Enterprise";
361 case WIFI_AUTH_WPA3_PSK:
363 case WIFI_AUTH_WPA2_WPA3_PSK:
364 return "WPA2/WPA3 PSK";
365 case WIFI_AUTH_WAPI_PSK:
376 sprintf(buf,
"%u.%u.%u.%u", uint8_t(ip.addr >> 0), uint8_t(ip.addr >> 8), uint8_t(ip.addr >> 16),
377 uint8_t(ip.addr >> 24));
396 case WIFI_REASON_AUTH_EXPIRE:
397 return "Auth Expired";
398 case WIFI_REASON_AUTH_LEAVE:
400 case WIFI_REASON_ASSOC_EXPIRE:
401 return "Association Expired";
402 case WIFI_REASON_ASSOC_TOOMANY:
403 return "Too Many Associations";
404 case WIFI_REASON_NOT_AUTHED:
405 return "Not Authenticated";
406 case WIFI_REASON_NOT_ASSOCED:
407 return "Not Associated";
408 case WIFI_REASON_ASSOC_LEAVE:
409 return "Association Leave";
410 case WIFI_REASON_ASSOC_NOT_AUTHED:
411 return "Association not Authenticated";
412 case WIFI_REASON_DISASSOC_PWRCAP_BAD:
413 return "Disassociate Power Cap Bad";
414 case WIFI_REASON_DISASSOC_SUPCHAN_BAD:
415 return "Disassociate Supported Channel Bad";
416 case WIFI_REASON_IE_INVALID:
418 case WIFI_REASON_MIC_FAILURE:
419 return "Mic Failure";
420 case WIFI_REASON_4WAY_HANDSHAKE_TIMEOUT:
421 return "4-Way Handshake Timeout";
422 case WIFI_REASON_GROUP_KEY_UPDATE_TIMEOUT:
423 return "Group Key Update Timeout";
424 case WIFI_REASON_IE_IN_4WAY_DIFFERS:
425 return "IE In 4-Way Handshake Differs";
426 case WIFI_REASON_GROUP_CIPHER_INVALID:
427 return "Group Cipher Invalid";
428 case WIFI_REASON_PAIRWISE_CIPHER_INVALID:
429 return "Pairwise Cipher Invalid";
430 case WIFI_REASON_AKMP_INVALID:
431 return "AKMP Invalid";
432 case WIFI_REASON_UNSUPP_RSN_IE_VERSION:
433 return "Unsupported RSN IE version";
434 case WIFI_REASON_INVALID_RSN_IE_CAP:
435 return "Invalid RSN IE Cap";
436 case WIFI_REASON_802_1X_AUTH_FAILED:
437 return "802.1x Authentication Failed";
438 case WIFI_REASON_CIPHER_SUITE_REJECTED:
439 return "Cipher Suite Rejected";
440 case WIFI_REASON_BEACON_TIMEOUT:
441 return "Beacon Timeout";
442 case WIFI_REASON_NO_AP_FOUND:
443 return "AP Not Found";
444 case WIFI_REASON_AUTH_FAIL:
445 return "Authentication Failed";
446 case WIFI_REASON_ASSOC_FAIL:
447 return "Association Failed";
448 case WIFI_REASON_HANDSHAKE_TIMEOUT:
449 return "Handshake Failed";
450 case WIFI_REASON_CONNECTION_FAIL:
451 return "Connection Failed";
452 case WIFI_REASON_ROAMING:
453 return "Station Roaming";
454 case WIFI_REASON_UNSPECIFIED:
456 return "Unspecified";
462 #define ESPHOME_EVENT_ID_WIFI_READY ARDUINO_EVENT_WIFI_READY 463 #define ESPHOME_EVENT_ID_WIFI_SCAN_DONE ARDUINO_EVENT_WIFI_SCAN_DONE 464 #define ESPHOME_EVENT_ID_WIFI_STA_START ARDUINO_EVENT_WIFI_STA_START 465 #define ESPHOME_EVENT_ID_WIFI_STA_STOP ARDUINO_EVENT_WIFI_STA_STOP 466 #define ESPHOME_EVENT_ID_WIFI_STA_CONNECTED ARDUINO_EVENT_WIFI_STA_CONNECTED 467 #define ESPHOME_EVENT_ID_WIFI_STA_DISCONNECTED ARDUINO_EVENT_WIFI_STA_DISCONNECTED 468 #define ESPHOME_EVENT_ID_WIFI_STA_AUTHMODE_CHANGE ARDUINO_EVENT_WIFI_STA_AUTHMODE_CHANGE 469 #define ESPHOME_EVENT_ID_WIFI_STA_GOT_IP ARDUINO_EVENT_WIFI_STA_GOT_IP 470 #define ESPHOME_EVENT_ID_WIFI_STA_GOT_IP6 ARDUINO_EVENT_WIFI_STA_GOT_IP6 471 #define ESPHOME_EVENT_ID_WIFI_STA_LOST_IP ARDUINO_EVENT_WIFI_STA_LOST_IP 472 #define ESPHOME_EVENT_ID_WIFI_AP_START ARDUINO_EVENT_WIFI_AP_START 473 #define ESPHOME_EVENT_ID_WIFI_AP_STOP ARDUINO_EVENT_WIFI_AP_STOP 474 #define ESPHOME_EVENT_ID_WIFI_AP_STACONNECTED ARDUINO_EVENT_WIFI_AP_STACONNECTED 475 #define ESPHOME_EVENT_ID_WIFI_AP_STADISCONNECTED ARDUINO_EVENT_WIFI_AP_STADISCONNECTED 476 #define ESPHOME_EVENT_ID_WIFI_AP_STAIPASSIGNED ARDUINO_EVENT_WIFI_AP_STAIPASSIGNED 477 #define ESPHOME_EVENT_ID_WIFI_AP_PROBEREQRECVED ARDUINO_EVENT_WIFI_AP_PROBEREQRECVED 478 #define ESPHOME_EVENT_ID_WIFI_AP_GOT_IP6 ARDUINO_EVENT_WIFI_AP_GOT_IP6 484 case ESPHOME_EVENT_ID_WIFI_READY: {
485 ESP_LOGV(TAG,
"Event: WiFi ready");
488 case ESPHOME_EVENT_ID_WIFI_SCAN_DONE: {
489 auto it = info.wifi_scan_done;
490 ESP_LOGV(TAG,
"Event: WiFi Scan Done status=%u number=%u scan_id=%u", it.status, it.number, it.scan_id);
495 case ESPHOME_EVENT_ID_WIFI_STA_START: {
496 ESP_LOGV(TAG,
"Event: WiFi STA start");
498 esp_err_t err = esp_netif_set_hostname(s_sta_netif,
App.
get_name().c_str());
500 ESP_LOGW(TAG,
"esp_netif_set_hostname failed: %s", esp_err_to_name(err));
504 case ESPHOME_EVENT_ID_WIFI_STA_STOP: {
505 ESP_LOGV(TAG,
"Event: WiFi STA stop");
508 case ESPHOME_EVENT_ID_WIFI_STA_CONNECTED: {
509 auto it = info.wifi_sta_connected;
511 memcpy(buf, it.ssid, it.ssid_len);
512 buf[it.ssid_len] =
'\0';
513 ESP_LOGV(TAG,
"Event: Connected ssid='%s' bssid=" LOG_SECRET(
"%s")
" channel=%u, authmode=%s", buf,
521 case ESPHOME_EVENT_ID_WIFI_STA_DISCONNECTED: {
522 auto it = info.wifi_sta_disconnected;
524 memcpy(buf, it.ssid, it.ssid_len);
525 buf[it.ssid_len] =
'\0';
526 if (it.reason == WIFI_REASON_NO_AP_FOUND) {
527 ESP_LOGW(TAG,
"Event: Disconnected ssid='%s' reason='Probe Request Unsuccessful'", buf);
529 ESP_LOGW(TAG,
"Event: Disconnected ssid='%s' bssid=" LOG_SECRET(
"%s")
" reason='%s'", buf,
533 uint8_t reason = it.reason;
534 if (reason == WIFI_REASON_AUTH_EXPIRE || reason == WIFI_REASON_BEACON_TIMEOUT ||
535 reason == WIFI_REASON_NO_AP_FOUND || reason == WIFI_REASON_ASSOC_FAIL ||
536 reason == WIFI_REASON_HANDSHAKE_TIMEOUT) {
537 err_t err = esp_wifi_disconnect();
539 ESP_LOGV(TAG,
"Disconnect failed: %s", esp_err_to_name(err));
544 s_sta_connecting =
false;
547 case ESPHOME_EVENT_ID_WIFI_STA_AUTHMODE_CHANGE: {
548 auto it = info.wifi_sta_authmode_change;
549 ESP_LOGV(TAG,
"Event: Authmode Change old=%s new=%s",
get_auth_mode_str(it.old_mode),
553 if (it.old_mode != WIFI_AUTH_OPEN && it.new_mode == WIFI_AUTH_OPEN) {
554 ESP_LOGW(TAG,
"Potential Authmode downgrade detected, disconnecting...");
557 err_t err = esp_wifi_disconnect();
559 ESP_LOGW(TAG,
"Disconnect failed: %s", esp_err_to_name(err));
565 case ESPHOME_EVENT_ID_WIFI_STA_GOT_IP: {
566 auto it = info.got_ip.ip_info;
567 ESP_LOGV(TAG,
"Event: Got IP static_ip=%s gateway=%s",
format_ip4_addr(it.ip).c_str(),
573 s_sta_connecting =
false;
578 case ESPHOME_EVENT_ID_WIFI_STA_GOT_IP6: {
579 auto it = info.got_ip6.ip6_info;
580 ESP_LOGV(TAG,
"Got IPv6 address=" IPV6STR, IPV62STR(it.ip));
586 case ESPHOME_EVENT_ID_WIFI_STA_LOST_IP: {
587 ESP_LOGV(TAG,
"Event: Lost IP");
591 case ESPHOME_EVENT_ID_WIFI_AP_START: {
592 ESP_LOGV(TAG,
"Event: WiFi AP start");
595 case ESPHOME_EVENT_ID_WIFI_AP_STOP: {
596 ESP_LOGV(TAG,
"Event: WiFi AP stop");
599 case ESPHOME_EVENT_ID_WIFI_AP_STACONNECTED: {
600 auto it = info.wifi_sta_connected;
601 auto &mac = it.bssid;
602 ESP_LOGV(TAG,
"Event: AP client connected MAC=%s",
format_mac_addr(mac).c_str());
605 case ESPHOME_EVENT_ID_WIFI_AP_STADISCONNECTED: {
606 auto it = info.wifi_sta_disconnected;
607 auto &mac = it.bssid;
608 ESP_LOGV(TAG,
"Event: AP client disconnected MAC=%s",
format_mac_addr(mac).c_str());
611 case ESPHOME_EVENT_ID_WIFI_AP_STAIPASSIGNED: {
612 ESP_LOGV(TAG,
"Event: AP client assigned IP");
615 case ESPHOME_EVENT_ID_WIFI_AP_PROBEREQRECVED: {
616 auto it = info.wifi_ap_probereqrecved;
617 ESP_LOGVV(TAG,
"Event: AP receive Probe Request MAC=%s RSSI=%d",
format_mac_addr(it.mac).c_str(), it.rssi);
627 if (
status == WL_CONNECT_FAILED ||
status == WL_CONNECTION_LOST) {
630 if (
status == WL_NO_SSID_AVAIL) {
633 if (s_sta_connecting) {
636 if (
status == WL_CONNECTED) {
647 int16_t err = WiFi.scanNetworks(
true,
true, passive, 200);
648 if (err != WIFI_SCAN_RUNNING) {
649 ESP_LOGV(TAG,
"WiFi.scanNetworks failed! %d", err);
658 int16_t num = WiFi.scanComplete();
662 this->
scan_result_.reserve(static_cast<unsigned int>(num));
663 for (
int i = 0; i < num; i++) {
664 String ssid = WiFi.SSID(i);
665 wifi_auth_mode_t authmode = WiFi.encryptionType(i);
666 int32_t rssi = WiFi.RSSI(i);
667 uint8_t *bssid = WiFi.BSSID(i);
668 int32_t channel = WiFi.channel(i);
670 WiFiScanResult scan({bssid[0], bssid[1], bssid[2], bssid[3], bssid[4], bssid[5]}, std::string(ssid.c_str()),
671 channel, rssi, authmode != WIFI_AUTH_OPEN, ssid.length() == 0);
686 esp_netif_ip_info_t info;
688 info.ip = manual_ip->static_ip;
689 info.gw = manual_ip->gateway;
690 info.netmask = manual_ip->subnet;
697 err = esp_netif_dhcps_stop(s_ap_netif);
698 if (err != ESP_OK && err != ESP_ERR_ESP_NETIF_DHCP_ALREADY_STOPPED) {
699 ESP_LOGE(TAG,
"esp_netif_dhcps_stop failed: %s", esp_err_to_name(err));
703 err = esp_netif_set_ip_info(s_ap_netif, &info);
705 ESP_LOGE(TAG,
"esp_netif_set_ip_info failed! %d", err);
713 lease.start_ip = start_address;
714 ESP_LOGV(TAG,
"DHCP server IP lease start: %s", start_address.
str().c_str());
716 lease.end_ip = start_address;
717 ESP_LOGV(TAG,
"DHCP server IP lease end: %s", start_address.str().c_str());
718 err = esp_netif_dhcps_option(s_ap_netif, ESP_NETIF_OP_SET, ESP_NETIF_REQUESTED_IP_ADDRESS, &lease,
sizeof(lease));
721 ESP_LOGE(TAG,
"esp_netif_dhcps_option failed! %d", err);
725 err = esp_netif_dhcps_start(s_ap_netif);
728 ESP_LOGE(TAG,
"esp_netif_dhcps_start failed! %d", err);
741 memset(&conf, 0,
sizeof(conf));
742 strncpy(reinterpret_cast<char *>(conf.ap.ssid), ap.
get_ssid().c_str(),
sizeof(conf.ap.ssid));
744 conf.ap.ssid_hidden = ap.
get_ssid().size();
745 conf.ap.max_connection = 5;
746 conf.ap.beacon_interval = 100;
749 conf.ap.authmode = WIFI_AUTH_OPEN;
750 *conf.ap.password = 0;
752 conf.ap.authmode = WIFI_AUTH_WPA2_PSK;
753 strncpy(reinterpret_cast<char *>(conf.ap.password), ap.
get_password().c_str(),
sizeof(conf.ap.password));
757 conf.ap.pairwise_cipher = WIFI_CIPHER_TYPE_CCMP;
759 esp_err_t err = esp_wifi_set_config(WIFI_IF_AP, &conf);
761 ESP_LOGV(TAG,
"esp_wifi_set_config failed! %d", err);
768 ESP_LOGV(TAG,
"wifi_ap_ip_config_ failed!");
776 esp_netif_ip_info_t ip;
777 esp_netif_get_ip_info(s_ap_netif, &ip);
780 #endif // USE_WIFI_AP 786 uint8_t *raw_bssid = WiFi.BSSID();
787 if (raw_bssid !=
nullptr) {
788 for (
size_t i = 0; i < bssid.size(); i++)
789 bssid[i] = raw_bssid[i];
803 #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_()
void set_ap(const WiFiAP &ap)
Setup an Access Point that should be created if no connection to a station can be made...
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_
void set_sta(const WiFiAP &ap)
Implementation of SPI Controller mode.
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)