Files
IoTManager/WiFi.ino

163 lines
4.6 KiB
Arduino
Raw Normal View History

2020-04-05 01:52:02 +02:00
void ROUTER_Connecting() {
2020-05-20 02:16:23 +02:00
2020-05-28 00:33:26 +02:00
led_blink("slow");
2019-12-24 11:53:26 +03:00
WiFi.mode(WIFI_STA);
byte tries = 20;
2020-06-11 22:51:34 +02:00
String _ssid = jsonReadStr(configSetupJson, "routerssid");
String _password = jsonReadStr(configSetupJson, "routerpass");
2019-12-24 11:53:26 +03:00
//WiFi.persistent(false);
if (_ssid == "" && _password == "") {
WiFi.begin();
}
else {
WiFi.begin(_ssid.c_str(), _password.c_str());
2020-02-19 03:14:21 +03:00
Serial.print("ssid: ");
Serial.println(_ssid);
2019-12-24 11:53:26 +03:00
}
// Делаем проверку подключения до тех пор пока счетчик tries
// не станет равен нулю или не получим подключение
2020-06-12 15:34:30 +02:00
while (--tries && WiFi.status() != WL_CONNECTED) {
2019-12-24 11:53:26 +03:00
if (WiFi.status() == WL_CONNECT_FAILED) {
Serial.println("[E] password is not correct");
tries = 1;
2020-06-11 22:51:34 +02:00
jsonWriteInt(configOptionJson, "pass_status", 1);
2019-12-24 11:53:26 +03:00
}
Serial.print(".");
delay(1000);
}
if (WiFi.status() != WL_CONNECTED)
{
// Если не удалось подключиться запускаем в режиме AP
Serial.println("");
// WiFi.disconnect(true);
StartAPMode();
}
else {
// Иначе удалось подключиться отправляем сообщение
// о подключении и выводим адрес IP
Serial.println("");
Serial.println("[V] WiFi connected");
Serial.print("[V] IP address: http://");
2020-02-13 20:20:34 +03:00
Serial.print(WiFi.localIP());
Serial.println("");
2020-06-11 22:51:34 +02:00
jsonWriteStr(configSetupJson, "ip", WiFi.localIP().toString());
2020-05-20 02:16:23 +02:00
led_blink("off");
2020-04-05 01:52:02 +02:00
//add_dev_in_list("dev.txt", chipID, WiFi.localIP().toString());
2020-05-28 00:33:26 +02:00
MQTT_init();
2019-12-24 11:53:26 +03:00
}
}
bool StartAPMode() {
Serial.println("WiFi up AP");
WiFi.disconnect();
WiFi.mode(WIFI_AP);
2020-06-11 22:51:34 +02:00
String _ssidAP = jsonReadStr(configSetupJson, "apssid");
String _passwordAP = jsonReadStr(configSetupJson, "appass");
2019-12-24 11:53:26 +03:00
WiFi.softAP(_ssidAP.c_str(), _passwordAP.c_str());
IPAddress myIP = WiFi.softAPIP();
2020-05-20 02:16:23 +02:00
led_blink("on");
2019-12-24 11:53:26 +03:00
Serial.print("AP IP address: ");
Serial.println(myIP);
2020-06-11 22:51:34 +02:00
jsonWriteStr(configSetupJson, "ip", myIP.toString());
2019-12-24 11:53:26 +03:00
2020-06-11 22:51:34 +02:00
//if (jsonReadInt(configOptionJson, "pass_status") != 1) {
2020-02-10 01:06:18 +03:00
ts.add(ROUTER_SEARCHING, 10 * 1000, [&](void*) {
2019-12-24 11:53:26 +03:00
Serial.println("->try find router");
2020-06-11 22:51:34 +02:00
if (RouterFind(jsonReadStr(configSetupJson, "routerssid"))) {
2019-12-24 11:53:26 +03:00
ts.remove(ROUTER_SEARCHING);
2020-05-02 12:20:30 +02:00
WiFi.scanDelete();
2020-04-05 01:52:02 +02:00
ROUTER_Connecting();
2019-12-24 11:53:26 +03:00
}
}, nullptr, true);
2020-05-28 00:33:26 +02:00
//}
2019-12-24 11:53:26 +03:00
return true;
}
boolean RouterFind(String ssid) {
int n = WiFi.scanComplete ();
2020-02-08 02:45:35 +03:00
Serial.println("n = " + String(n));
2019-12-24 11:53:26 +03:00
if (n == -2) { //Сканирование не было запущено, запускаем
2020-02-08 02:45:35 +03:00
Serial.println("[WIFI][i] scanning has not been triggered, starting scanning");
2019-12-24 11:53:26 +03:00
WiFi.scanNetworks (true, false); //async, show_hidden
return false;
}
if (n == -1) { //Сканирование все еще выполняется
2020-02-08 02:45:35 +03:00
Serial.println("[WIFI][i] scanning still in progress");
return false;
}
2020-05-04 15:57:54 +02:00
if (n == 0) { //ни одна сеть не найдена
2020-02-08 02:45:35 +03:00
Serial.println("[WIFI][i] no any wifi sations, starting scanning");
WiFi.scanNetworks (true, false);
2019-12-24 11:53:26 +03:00
return false;
}
if (n > 0) {
for (int i = 0; i <= n; i++) {
if (WiFi.SSID (i) == ssid) {
WiFi.scanDelete();
return true;
} else {
Serial.print(i);
Serial.print(")");
2020-03-16 00:00:59 +01:00
//Serial.print(ssid);
//Serial.print("<=>");
2020-02-08 02:45:35 +03:00
if (i == n) {
Serial.print(WiFi.SSID(i));
Serial.println("; ");
} else {
Serial.print(WiFi.SSID(i));
2020-03-16 00:00:59 +01:00
Serial.println("; ");
2020-02-08 02:45:35 +03:00
}
2019-12-24 11:53:26 +03:00
}
}
WiFi.scanDelete();
return false;
}
}
2020-04-05 01:52:02 +02:00
2020-03-20 21:00:11 +01:00
/*
2020-04-05 01:52:02 +02:00
String scanWIFI() {
2020-03-20 21:00:11 +01:00
uint8_t n = WiFi.scanNetworks();
DynamicJsonBuffer jsonBuffer;
JsonObject& json = jsonBuffer.createObject();
JsonArray& networks = json.createNestedArray("networks");
for (uint8_t i = 0; i < n; i++) {
JsonObject& data = networks.createNestedObject();
String ssidMy = WiFi.SSID(i);
2020-06-11 22:51:34 +02:00
data["routerssid"] = ssidMy;
2020-03-20 21:00:11 +01:00
data["pass"] = (WiFi.encryptionType(i) == ENC_TYPE_NONE) ? "" : "*";
int8_t dbm = WiFi.RSSI(i);
data["dbm"] = dbm;
2020-06-11 22:51:34 +02:00
if (ssidMy == jsonReadStr(configSetupJson, "routerssid")) {
jsonWriteStr(configLiveJson, "dbm", dbm);
2020-03-20 21:00:11 +01:00
}
}
String root;
json.printTo(root);
return root;
2020-04-05 01:52:02 +02:00
}
2020-03-20 21:00:11 +01:00
*/
/*
{
"type":"wifi",
"title":"{{LangWiFi1}}",
2020-06-11 22:51:34 +02:00
"name":"routerssid",
2020-03-20 21:00:11 +01:00
"state":"{{ssid}}",
"pattern":".{1,}"
},
{
2020-06-11 22:51:34 +02:00
"type":"routerpass",
2020-03-20 21:00:11 +01:00
"title":"{{LangPass}}",
2020-06-11 22:51:34 +02:00
"name":"routerpass",
2020-03-20 21:00:11 +01:00
"state":"{{ssidPass}}",
"pattern":".{8,}"
},
*/