#include #include #include #include #include #include #include #include #include #include #include #include "pax_gfx.h" #include "system_wrapper.h" #include "settings.h" #include "wifi_connection.h" static const char *TAG = "wifi_connect"; bool wifi_connect_to_stored() { bool result = false; // Open NVS. nvs_handle_t handle; nvs_open("system", NVS_READWRITE, &handle); uint8_t use_ent; char *ssid = NULL; char *ident = NULL; char *anon_ident = NULL; char *password = NULL; size_t len; // Read NVS. esp_err_t res; // Read SSID. res = nvs_get_str(handle, "wifi.ssid", NULL, &len); if (res) goto errcheck; ssid = malloc(len); res = nvs_get_str(handle, "wifi.ssid", ssid, &len); if (res) goto errcheck; // Check whether connection is enterprise. res = nvs_get_u8(handle, "wifi.use_ent", &use_ent); if (res) goto errcheck; if (use_ent) { // Read enterprise-specific parameters. // Read identity. res = nvs_get_str(handle, "wifi.ident", NULL, &len); if (res) goto errcheck; ident = malloc(len); res = nvs_get_str(handle, "wifi.ident", ident, &len); // Read anonymous identity. res = nvs_get_str(handle, "wifi.anon_ident", NULL, &len); if (res) goto errcheck; anon_ident = malloc(len); res = nvs_get_str(handle, "wifi.anon_ident", anon_ident, &len); if (res) goto errcheck; } // Read password. res = nvs_get_str(handle, "wifi.password", NULL, &len); if (res) goto errcheck; password = malloc(len); res = nvs_get_str(handle, "wifi.password", password, &len); if (res) goto errcheck; // Close NVS. nvs_close(handle); // Open the appropriate connection. if (use_ent) { result = wifi_connect_ent(ssid, ident, anon_ident, password, 3); } else { result = wifi_connect(ssid, password, WIFI_AUTH_WPA2_PSK, 3); } errcheck: if (res == ESP_ERR_NVS_NOT_FOUND || res == ESP_ERR_NVS_NOT_INITIALIZED) { // When NVS is not initialised. ESP_LOGI(TAG, "WiFi settings not stored in NVS."); } else if (res) { // Other errors. ESP_LOGE(TAG, "Error connecting to WiFi: %s", esp_err_to_name(res)); } // Free memory. if (ssid) free(ssid); if (ident) free(ident); if (anon_ident) free(anon_ident); if (password) free(password); return result; }