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);
|
|
|
|
|
|
|
|
|
|
|
|
void WIFI_init()
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
// --------------------Получаем ssid password со страницы
|
2020-06-18 23:43:06 +02:00
|
|
|
|
server.on("/ssid", HTTP_GET, [](AsyncWebServerRequest *request) {
|
|
|
|
|
|
if (request->hasArg("ssid"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "ssid", request->getParam("ssid")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (request->hasArg("password"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "password", request->getParam("password")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
saveConfig(); // Функция сохранения данных во Flash
|
|
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
2020-06-17 23:30:48 +03:00
|
|
|
|
});
|
|
|
|
|
|
// --------------------Получаем ssidAP passwordAP со страницы
|
2020-06-18 23:43:06 +02:00
|
|
|
|
server.on("/ssidap", HTTP_GET, [](AsyncWebServerRequest *request) {
|
|
|
|
|
|
if (request->hasArg("ssidAP"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "ssidAP", request->getParam("ssidAP")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (request->hasArg("passwordAP"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "passwordAP", request->getParam("passwordAP")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
saveConfig(); // Функция сохранения данных во Flash
|
|
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
2020-06-17 23:30:48 +03:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
// --------------------Получаем логин и пароль для web со страницы
|
2020-06-18 23:43:06 +02:00
|
|
|
|
server.on("/web", HTTP_GET, [](AsyncWebServerRequest *request) {
|
|
|
|
|
|
if (request->hasArg("web_login"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "web_login", request->getParam("web_login")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (request->hasArg("web_pass"))
|
|
|
|
|
|
{
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configSetupJson, "web_pass", request->getParam("web_pass")->value());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
saveConfig(); // Функция сохранения данных во Flash
|
2020-06-17 23:30:48 +03:00
|
|
|
|
//Web_server_init();
|
2020-06-18 23:43:06 +02:00
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
2020-06-17 23:30:48 +03:00
|
|
|
|
});
|
|
|
|
|
|
|
2020-06-18 23:43:06 +02:00
|
|
|
|
server.on("/restart", HTTP_GET, [](AsyncWebServerRequest *request) {
|
|
|
|
|
|
if (request->hasArg("device"))
|
|
|
|
|
|
{
|
|
|
|
|
|
if (request->getParam("device")->value() == "ok")
|
|
|
|
|
|
ESP.restart();
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
2020-06-17 23:30:48 +03:00
|
|
|
|
});
|
|
|
|
|
|
ROUTER_Connecting();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-06-18 23:43:06 +02:00
|
|
|
|
void ROUTER_Connecting()
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
led_blink("slow");
|
|
|
|
|
|
|
|
|
|
|
|
WiFi.mode(WIFI_STA);
|
|
|
|
|
|
|
|
|
|
|
|
byte tries = 20;
|
2020-06-19 14:50:34 +02:00
|
|
|
|
String _ssid = jsonReadStr(configSetupJson, "ssid");
|
|
|
|
|
|
String _password = jsonReadStr(configSetupJson, "password");
|
2020-06-17 23:30:48 +03:00
|
|
|
|
//WiFi.persistent(false);
|
|
|
|
|
|
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (_ssid == "" && _password == "")
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
WiFi.begin();
|
2020-06-18 23:43:06 +02:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
WiFi.begin(_ssid.c_str(), _password.c_str());
|
|
|
|
|
|
Serial.print("ssid: ");
|
|
|
|
|
|
Serial.println(_ssid);
|
|
|
|
|
|
}
|
|
|
|
|
|
// Делаем проверку подключения до тех пор пока счетчик tries
|
|
|
|
|
|
// не станет равен нулю или не получим подключение
|
2020-06-18 23:43:06 +02:00
|
|
|
|
while (--tries && WiFi.status() != WL_CONNECTED)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (WiFi.status() == WL_CONNECT_FAILED)
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("[E] password is not correct");
|
|
|
|
|
|
tries = 1;
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteInt(configOptionJson, "pass_status", 1);
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
|
|
|
|
|
Serial.print(".");
|
|
|
|
|
|
delay(1000);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Serial.println();
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (WiFi.status() != WL_CONNECTED)
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
StartAPMode();
|
2020-06-18 23:43:06 +02:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("[V] WiFi connected");
|
|
|
|
|
|
Serial.print("[V] IP address: http://");
|
|
|
|
|
|
Serial.print(WiFi.localIP());
|
|
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configLiveJson, "ip", WiFi.localIP().toString());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
led_blink("off");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-06-18 23:43:06 +02:00
|
|
|
|
bool StartAPMode()
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("WiFi up AP");
|
|
|
|
|
|
WiFi.disconnect();
|
|
|
|
|
|
|
|
|
|
|
|
WiFi.mode(WIFI_AP);
|
|
|
|
|
|
|
2020-06-19 14:50:34 +02:00
|
|
|
|
String _ssidAP = jsonReadStr(configSetupJson, "ssidAP");
|
|
|
|
|
|
String _passwordAP = jsonReadStr(configSetupJson, "passwordAP");
|
2020-06-17 23:30:48 +03:00
|
|
|
|
WiFi.softAP(_ssidAP.c_str(), _passwordAP.c_str());
|
|
|
|
|
|
IPAddress myIP = WiFi.softAPIP();
|
|
|
|
|
|
led_blink("on");
|
|
|
|
|
|
Serial.print("AP IP address: ");
|
|
|
|
|
|
Serial.println(myIP);
|
2020-06-19 14:50:34 +02:00
|
|
|
|
jsonWriteStr(configLiveJson, "ip", myIP.toString());
|
2020-06-17 23:30:48 +03:00
|
|
|
|
|
2020-06-19 14:50:34 +02:00
|
|
|
|
if (jsonReadInt(configOptionJson, "pass_status") != 1)
|
2020-06-18 23:43:06 +02:00
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
ts.add(
|
2020-06-18 23:43:06 +02:00
|
|
|
|
ROUTER_SEARCHING, 10 * 1000, [&](void *) {
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("->try find router");
|
2020-06-19 14:50:34 +02:00
|
|
|
|
if (RouterFind(jsonReadStr(configSetupJson, "ssid")))
|
2020-06-18 23:43:06 +02:00
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
ts.remove(ROUTER_SEARCHING);
|
|
|
|
|
|
WiFi.scanDelete();
|
|
|
|
|
|
ROUTER_Connecting();
|
|
|
|
|
|
MQTT_init();
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
nullptr, true);
|
|
|
|
|
|
}
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-06-18 23:43:06 +02:00
|
|
|
|
boolean RouterFind(String ssid)
|
|
|
|
|
|
{
|
|
|
|
|
|
bool res = false;
|
|
|
|
|
|
|
2020-06-17 23:30:48 +03:00
|
|
|
|
int n = WiFi.scanComplete();
|
|
|
|
|
|
Serial.println("n = " + String(n));
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (n == -2)
|
|
|
|
|
|
{ //Сканирование не было запущено, запускаем
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("[WIFI][i] scanning has not been triggered, starting scanning");
|
2020-06-18 23:43:06 +02:00
|
|
|
|
WiFi.scanNetworks(true, false); //async, show_hidde
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
else if (n == -1)
|
|
|
|
|
|
{ //Сканирование все еще выполняется
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("[WIFI][i] scanning still in progress");
|
|
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
else if (n == 0)
|
|
|
|
|
|
{ //ни одна сеть не найдена
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.println("[WIFI][i] no any wifi sations, starting scanning");
|
|
|
|
|
|
WiFi.scanNetworks(true, false);
|
|
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
else if (n > 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
for (int 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;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.print(i);
|
|
|
|
|
|
Serial.print(")");
|
2020-06-18 23:43:06 +02:00
|
|
|
|
if (i == n)
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.print(WiFi.SSID(i));
|
|
|
|
|
|
Serial.println("; ");
|
2020-06-18 23:43:06 +02:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2020-06-17 23:30:48 +03:00
|
|
|
|
Serial.print(WiFi.SSID(i));
|
|
|
|
|
|
Serial.println("; ");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
WiFi.scanDelete();
|
|
|
|
|
|
}
|
2020-06-18 23:43:06 +02:00
|
|
|
|
return res;
|
2020-06-17 23:30:48 +03:00
|
|
|
|
}
|