From 21f893a19551ebef74a7cf717ecc1950b34e9679 Mon Sep 17 00:00:00 2001 From: tyeth Date: Wed, 11 Dec 2024 22:27:15 +0000 Subject: [PATCH] Remove scan print sort in favour of BSSID/RSSI/Channel (airlift) --- .../Wippersnapper_AIRLIFT.h | 49 +++++-------------- 1 file changed, 11 insertions(+), 38 deletions(-) diff --git a/src/network_interfaces/Wippersnapper_AIRLIFT.h b/src/network_interfaces/Wippersnapper_AIRLIFT.h index 6f1b96a7..056e37bb 100644 --- a/src/network_interfaces/Wippersnapper_AIRLIFT.h +++ b/src/network_interfaces/Wippersnapper_AIRLIFT.h @@ -143,45 +143,14 @@ class Wippersnapper_AIRLIFT : public Wippersnapper { return false; } - WiFiNetwork networks[WS_MAX_SORTED_NETWORKS]; - uint8_t numSavedNetworks = 0; - - // Store the scanned networks in the array - for (int i = 0; i < n; ++i) { - if (i < WS_MAX_SORTED_NETWORKS) { - strncpy(networks[i].ssid, WiFi.SSID(i), sizeof(networks[i].ssid)); - networks[i].ssid[sizeof(networks[i].ssid) - 1] = '\0'; - networks[i].rssi = WiFi.RSSI(i); - numSavedNetworks++; - } else { - WS_DEBUG_PRINT("ERROR: Too many networks found! (>"); - WS_DEBUG_PRINT(WS_MAX_SORTED_NETWORKS); - WS_DEBUG_PRINT(") Ignoring "); - WS_DEBUG_PRINT(WiFi.SSID(i)); - WS_DEBUG_PRINT("("); - WS_DEBUG_PRINT(WiFi.RSSI(i)); - WS_DEBUG_PRINTLN(")"); - } - } + bool foundNetwork = false; - // Sort the networks by RSSI in descending order - std::sort(networks, networks + numSavedNetworks, compareByRSSI); - - // Was the network within secrets.json found? - for (int i = 0; i < numSavedNetworks; ++i) { - if (strcmp(_ssid, networks[i].ssid) == 0) { - WS_DEBUG_PRINT("SSID ("); - WS_DEBUG_PRINT(_ssid); - WS_DEBUG_PRINT(") found! RSSI: "); - WS_DEBUG_PRINTLN(networks[i].rssi); - return true; - } - } - - // User-set network not found, print scan results to serial console - WS_DEBUG_PRINTLN("ERROR: Your requested WiFi network was not found!"); WS_DEBUG_PRINTLN("WipperSnapper found these WiFi networks:"); - for (uint8_t i = 0; i < n; ++i) { + for (uint8_t i = 0; i < n; i++) { + if (strcmp(WiFi.SSID(i), _ssid) == 0) { + foundNetwork = true; + break; + } WS_DEBUG_PRINT(WiFi.SSID(i)); WS_DEBUG_PRINT(" ("); uint8_t BSSID[WL_MAC_ADDR_LENGTH]; @@ -198,7 +167,11 @@ class Wippersnapper_AIRLIFT : public Wippersnapper { WS_DEBUG_PRINTLN(")"); } - return false; + if(foundNetwork == 0) { + WS_DEBUG_PRINTLN("ERROR: Your requested WiFi network was not found!"); + return false; + } + return true; } /********************************************************/