Files
IoTManager/src/WiFiUtils.cpp

114 lines
3.7 KiB
C++
Raw Normal View History

2020-06-18 23:43:06 +02:00
#include "Global.h"
2020-06-17 23:30:48 +03:00
2020-06-18 23:43:06 +02:00
boolean RouterFind(String ssid);
2020-06-19 22:14:50 +02:00
void ROUTER_Connecting() {
2020-06-20 22:51:14 +03:00
led_blink("slow");
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
WiFi.mode(WIFI_STA);
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
byte tries = 20;
String _ssid = jsonReadStr(configSetupJson, "routerssid");
String _password = jsonReadStr(configSetupJson, "routerpass");
//WiFi.persistent(false);
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
if (_ssid == "" && _password == "") {
WiFi.begin();
} else {
WiFi.begin(_ssid.c_str(), _password.c_str());
Serial.print("ssid: ");
Serial.println(_ssid);
}
// Делаем проверку подключения до тех пор пока счетчик tries
// не станет равен нулю или не получим подключение
while (--tries && WiFi.status() != WL_CONNECTED) {
if (WiFi.status() == WL_CONNECT_FAILED) {
Serial.println("[E] password is not correct");
tries = 1;
jsonWriteInt(configOptionJson, "pass_status", 1);
}
Serial.print(".");
delay(1000);
2020-06-17 23:30:48 +03:00
}
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
if (WiFi.status() != WL_CONNECTED) {
// Если не удалось подключиться запускаем в режиме AP
Serial.println("");
// WiFi.disconnect(true);
StartAPMode();
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
} else {
// Иначе удалось подключиться отправляем сообщение
// о подключении и выводим адрес IP
Serial.println("");
Serial.println("[V] WiFi connected");
Serial.print("[V] IP address: http://");
Serial.print(WiFi.localIP());
Serial.println("");
jsonWriteStr(configSetupJson, "ip", WiFi.localIP().toString());
led_blink("off");
//add_dev_in_list("dev.txt", chipID, WiFi.localIP().toString());
MQTT_init();
}
2020-06-17 23:30:48 +03:00
}
2020-06-19 22:14:50 +02:00
bool StartAPMode() {
2020-06-20 22:51:14 +03:00
Serial.println("[I] WiFi AP");
WiFi.disconnect();
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
WiFi.mode(WIFI_AP);
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
String _ssidAP = jsonReadStr(configSetupJson, "apssid");
String _passwordAP = jsonReadStr(configSetupJson, "appass");
WiFi.softAP(_ssidAP.c_str(), _passwordAP.c_str());
IPAddress myIP = WiFi.softAPIP();
led_blink("on");
Serial.print("[I] AP IP: ");
Serial.println(myIP);
jsonWriteStr(configSetupJson, "ip", myIP.toString());
2020-06-19 22:14:50 +02:00
2020-06-20 22:51:14 +03:00
//if (jsonReadInt(configOptionJson, "pass_status") != 1) {
ts.add(
ROUTER_SEARCHING, 10 * 1000, [&](void*) {
Serial.println("[I] searching ssid");
if (RouterFind(jsonReadStr(configSetupJson, "routerssid"))) {
ts.remove(ROUTER_SEARCHING);
WiFi.scanDelete();
ROUTER_Connecting();
}
},
nullptr, true);
//}
return true;
2020-06-17 23:30:48 +03:00
}
2020-06-20 22:51:14 +03:00
boolean RouterFind(String ssid) {
2020-06-18 23:43:06 +02:00
bool res = false;
2020-06-20 22:51:14 +03:00
int8_t n = WiFi.scanComplete();
Serial.printf("[I][WIFI] scan result = %d\n", n);
if (n == -2) {
// не было запущено, запускаем
Serial.println("[I][WIFI] scanning has not been triggered, start scanning");
// async, show_hidden
2020-06-17 23:30:48 +03:00
WiFi.scanNetworks(true, false);
2020-06-20 22:51:14 +03:00
} else if (n == -1) {
// все еще выполняется
Serial.println("[I][WIFI] scanning in progress");
} else if (n == 0) {
// не найдена ни одна сеть
Serial.println("[I][WIFI] no wifi stations, start scanning");
WiFi.scanNetworks(true, false);
} else if (n > 0) {
for (int8_t i = 0; i < n; i++) {
if (WiFi.SSID(i) == ssid) {
2020-06-17 23:30:48 +03:00
WiFi.scanDelete();
2020-06-18 23:43:06 +02:00
res = true;
2020-06-20 22:51:14 +03:00
} else {
Serial.printf("%d) %s;\n", i, WiFi.SSID(i).c_str());
2020-06-17 23:30:48 +03:00
}
}
WiFi.scanDelete();
}
2020-06-18 23:43:06 +02:00
return res;
2020-06-19 22:14:50 +02:00
}