mirror of
				https://github.com/esp8266/Arduino.git
				synced 2025-10-25 18:38:07 +03:00 
			
		
		
		
	Check if AP exists before adding it (#5373)
This commit is contained in:
		| @@ -69,6 +69,7 @@ softAPgetStationNum	KEYWORD2 | |||||||
|  |  | ||||||
| #ESP8266WiFiMulti | #ESP8266WiFiMulti | ||||||
| addAP	KEYWORD2 | addAP	KEYWORD2 | ||||||
|  | existsAP	KEYWORD2 | ||||||
| run	KEYWORD2 | run	KEYWORD2 | ||||||
|  |  | ||||||
| #ESP8266WiFiScan | #ESP8266WiFiScan | ||||||
|   | |||||||
| @@ -38,6 +38,10 @@ bool ESP8266WiFiMulti::addAP(const char* ssid, const char *passphrase) { | |||||||
|     return APlistAdd(ssid, passphrase); |     return APlistAdd(ssid, passphrase); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool ESP8266WiFiMulti::existsAP(const char* ssid, const char *passphrase) { | ||||||
|  |     return APlistExists(ssid, passphrase); | ||||||
|  | } | ||||||
|  |  | ||||||
| wl_status_t ESP8266WiFiMulti::run(void) { | wl_status_t ESP8266WiFiMulti::run(void) { | ||||||
|  |  | ||||||
|     wl_status_t status = WiFi.status(); |     wl_status_t status = WiFi.status(); | ||||||
| @@ -184,18 +188,23 @@ bool ESP8266WiFiMulti::APlistAdd(const char* ssid, const char *passphrase) { | |||||||
|     WifiAPEntry newAP; |     WifiAPEntry newAP; | ||||||
|  |  | ||||||
|     if(!ssid || *ssid == 0x00 || strlen(ssid) > 31) { |     if(!ssid || *ssid == 0x00 || strlen(ssid) > 31) { | ||||||
|         // fail SSID to long or missing! |         // fail SSID too long or missing! | ||||||
|         DEBUG_WIFI_MULTI("[WIFI][APlistAdd] no ssid or ssid to long\n"); |         DEBUG_WIFI_MULTI("[WIFI][APlistAdd] no ssid or ssid too long\n"); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     //for passphrase, max is 63 ascii + null. For psk, 64hex + null. |     //for passphrase, max is 63 ascii + null. For psk, 64hex + null. | ||||||
|     if(passphrase && strlen(passphrase) > 64) { |     if(passphrase && strlen(passphrase) > 64) { | ||||||
|         // fail passphrase to long! |         // fail passphrase too long! | ||||||
|         DEBUG_WIFI_MULTI("[WIFI][APlistAdd] passphrase to long\n"); |         DEBUG_WIFI_MULTI("[WIFI][APlistAdd] passphrase too long\n"); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     if(APlistExists(ssid, passphrase)) { | ||||||
|  |         DEBUG_WIFI_MULTI("[WIFI][APlistAdd] SSID: %s already exists\n", ssid); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     newAP.ssid = strdup(ssid); |     newAP.ssid = strdup(ssid); | ||||||
|  |  | ||||||
|     if(!newAP.ssid) { |     if(!newAP.ssid) { | ||||||
| @@ -220,6 +229,28 @@ bool ESP8266WiFiMulti::APlistAdd(const char* ssid, const char *passphrase) { | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool ESP8266WiFiMulti::APlistExists(const char* ssid, const char *passphrase) { | ||||||
|  |     if(!ssid || *ssid == 0x00 || strlen(ssid) > 31) { | ||||||
|  |         // fail SSID too long or missing! | ||||||
|  |         DEBUG_WIFI_MULTI("[WIFI][APlistExists] no ssid or ssid too long\n"); | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |     for(auto entry : APlist) { | ||||||
|  |         if(!strcmp(entry.ssid, ssid)) { | ||||||
|  |             if(!passphrase) { | ||||||
|  |                 if(!strcmp(entry.passphrase, "")) { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 if(!strcmp(entry.passphrase, passphrase)) { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  |  | ||||||
| void ESP8266WiFiMulti::APlistClean(void) { | void ESP8266WiFiMulti::APlistClean(void) { | ||||||
|     for(auto entry : APlist) { |     for(auto entry : APlist) { | ||||||
|         if(entry.ssid) { |         if(entry.ssid) { | ||||||
|   | |||||||
| @@ -53,12 +53,14 @@ class ESP8266WiFiMulti { | |||||||
|         ~ESP8266WiFiMulti(); |         ~ESP8266WiFiMulti(); | ||||||
|  |  | ||||||
|         bool addAP(const char* ssid, const char *passphrase = NULL); |         bool addAP(const char* ssid, const char *passphrase = NULL); | ||||||
|  |         bool existsAP(const char* ssid, const char *passphrase = NULL); | ||||||
|  |  | ||||||
|         wl_status_t run(void); |         wl_status_t run(void); | ||||||
|  |  | ||||||
|     private: |     private: | ||||||
|         WifiAPlist APlist; |         WifiAPlist APlist; | ||||||
|         bool APlistAdd(const char* ssid, const char *passphrase = NULL); |         bool APlistAdd(const char* ssid, const char *passphrase = NULL); | ||||||
|  |         bool APlistExists(const char* ssid, const char *passphrase = NULL); | ||||||
|         void APlistClean(void); |         void APlistClean(void); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user