2019-12-24 11:53:26 +03:00
|
|
|
|
void All_init() {
|
|
|
|
|
|
|
2020-02-10 01:06:18 +03:00
|
|
|
|
server.on("/all_modules_init", HTTP_GET, [](AsyncWebServerRequest * request) {
|
2019-12-24 11:53:26 +03:00
|
|
|
|
Device_init();
|
|
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
|
|
|
|
|
});
|
|
|
|
|
|
server.on("/scenario", HTTP_GET, [](AsyncWebServerRequest * request) {
|
|
|
|
|
|
if (request->hasArg("status")) {
|
2020-03-27 15:48:17 +01:00
|
|
|
|
jsonWriteStr(configSetup, "scenario", request->getParam("status")->value());
|
2019-12-24 11:53:26 +03:00
|
|
|
|
}
|
|
|
|
|
|
saveConfig();
|
|
|
|
|
|
Scenario_init();
|
|
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
|
|
|
|
|
});
|
|
|
|
|
|
server.on("/cleanlog", HTTP_GET, [](AsyncWebServerRequest * request) {
|
2020-03-27 15:48:17 +01:00
|
|
|
|
clean_log_date();
|
2019-12-24 11:53:26 +03:00
|
|
|
|
request->send(200, "text/text", "OK"); // отправляем ответ о выполнении
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2020-02-18 16:22:17 +03:00
|
|
|
|
prsets_init();
|
|
|
|
|
|
|
2019-12-24 11:53:26 +03:00
|
|
|
|
Device_init();
|
|
|
|
|
|
Scenario_init();
|
|
|
|
|
|
Timer_countdown_init();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Device_init() {
|
|
|
|
|
|
|
|
|
|
|
|
ts.remove(ANALOG_);
|
2020-02-10 01:06:18 +03:00
|
|
|
|
ts.remove(LEVEL);
|
2019-12-24 11:53:26 +03:00
|
|
|
|
ts.remove(DALLAS);
|
2020-02-10 01:06:18 +03:00
|
|
|
|
ts.remove(DHTT);
|
|
|
|
|
|
ts.remove(DHTH);
|
2020-03-22 01:50:31 +01:00
|
|
|
|
ts.remove(DHTC);
|
|
|
|
|
|
ts.remove(DHTP);
|
|
|
|
|
|
ts.remove(DHTD);
|
|
|
|
|
|
ts.remove(STEPPER1);
|
|
|
|
|
|
ts.remove(STEPPER2);
|
2020-02-15 20:17:25 +03:00
|
|
|
|
|
2020-03-30 01:45:42 +02:00
|
|
|
|
#ifdef layout_in_ram
|
2020-03-24 19:01:11 +01:00
|
|
|
|
all_widgets = "";
|
2020-03-30 01:45:42 +02:00
|
|
|
|
#else
|
2020-03-27 15:48:17 +01:00
|
|
|
|
SPIFFS.remove("/layout.txt");
|
2020-03-30 01:45:42 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
txtExecution("firmware.c.txt");
|
2019-12-24 11:53:26 +03:00
|
|
|
|
//outcoming_date();
|
|
|
|
|
|
}
|
|
|
|
|
|
//-------------------------------сценарии-----------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
void Scenario_init() {
|
|
|
|
|
|
if (jsonRead(configSetup, "scenario") == "1") {
|
2020-03-30 01:45:42 +02:00
|
|
|
|
scenario = readFile("firmware.s.txt", 2048);
|
2019-12-24 11:53:26 +03:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2020-02-15 20:17:25 +03:00
|
|
|
|
|
2020-02-18 16:22:17 +03:00
|
|
|
|
void prsets_init() {
|
2020-03-30 01:45:42 +02:00
|
|
|
|
server.on("/preset", HTTP_GET, [](AsyncWebServerRequest * request) {
|
|
|
|
|
|
String value;
|
|
|
|
|
|
if (request->hasArg("arg")) {
|
|
|
|
|
|
value = request->getParam("arg")->value();
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "1") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "2") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_t.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_t.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "3") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_c.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_c.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "4") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_s.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_s.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "5") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_sw.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_sw.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "6") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_br.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_br.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "7") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/relay_sr.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/relay_sr.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "8") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/pwm.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/pwm.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "9") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/dht11.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/dht11.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "10") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/dht22.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/dht22.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "11") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/analog.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/analog.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "12") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/dallas.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/dallas.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "13") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/termostat.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/termostat.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "14") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/level.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/level.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "15") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/moution_r.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/moution_r.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "16") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/moution_s.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/moution_s.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "17") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/stepper.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/stepper.s.txt", 2048));
|
|
|
|
|
|
}
|
|
|
|
|
|
if (value == "18") {
|
|
|
|
|
|
writeFile("firmware.c.txt", readFile("configs/firmware.c.txt", 2048));
|
|
|
|
|
|
writeFile("firmware.s.txt", readFile("configs/firmware.s.txt", 2048));
|
|
|
|
|
|
}
|
2020-02-18 16:22:17 +03:00
|
|
|
|
Device_init();
|
|
|
|
|
|
Scenario_init();
|
2020-03-01 20:41:16 +03:00
|
|
|
|
request->redirect("/page.htm?configuration");
|
2020-02-18 16:22:17 +03:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-02-15 20:17:25 +03:00
|
|
|
|
void up_time() {
|
|
|
|
|
|
uint32_t ss = millis() / 1000;
|
|
|
|
|
|
uint32_t mm = ss / 60;
|
|
|
|
|
|
uint32_t hh = mm / 60;
|
|
|
|
|
|
uint32_t dd = hh / 24;
|
2020-02-22 03:34:44 +03:00
|
|
|
|
|
2020-02-19 03:14:21 +03:00
|
|
|
|
String out = "";
|
2020-02-15 20:17:25 +03:00
|
|
|
|
|
2020-02-18 16:22:17 +03:00
|
|
|
|
if (ss != 0) {
|
2020-02-19 03:14:21 +03:00
|
|
|
|
out = "[i] uptime = " + String(ss) + " sec";
|
2020-03-27 15:48:17 +01:00
|
|
|
|
jsonWriteStr(configJson, "uptime", String(ss) + " sec");
|
2020-02-18 16:22:17 +03:00
|
|
|
|
}
|
2020-02-15 20:17:25 +03:00
|
|
|
|
if (mm != 0) {
|
2020-02-19 03:14:21 +03:00
|
|
|
|
out = "[i] uptime = " + String(mm) + " min";
|
2020-03-27 15:48:17 +01:00
|
|
|
|
jsonWriteStr(configJson, "uptime", String(mm) + " min");
|
2020-02-15 20:17:25 +03:00
|
|
|
|
}
|
|
|
|
|
|
if (hh != 0) {
|
2020-02-19 03:14:21 +03:00
|
|
|
|
out = "[i] uptime = " + String(hh) + " hours";
|
2020-03-27 15:48:17 +01:00
|
|
|
|
jsonWriteStr(configJson, "uptime", String(hh) + " hours");
|
2020-02-15 20:17:25 +03:00
|
|
|
|
}
|
|
|
|
|
|
if (dd != 0) {
|
2020-02-19 03:14:21 +03:00
|
|
|
|
out = "[i] uptime = " + String(dd) + " days";
|
2020-03-27 15:48:17 +01:00
|
|
|
|
jsonWriteStr(configJson, "uptime", String(dd) + " days");
|
2020-02-15 20:17:25 +03:00
|
|
|
|
}
|
2020-02-19 03:14:21 +03:00
|
|
|
|
Serial.println(out + ", mqtt_lost_error: " + String(mqtt_lost_error) + ", wifi_lost_error: " + String(wifi_lost_error));
|
2020-02-15 20:17:25 +03:00
|
|
|
|
}
|
2020-02-22 03:34:44 +03:00
|
|
|
|
|
2020-03-17 00:54:27 +01:00
|
|
|
|
void statistics_init() {
|
|
|
|
|
|
ts.add(STATISTICS, statistics_update, [&](void*) {
|
|
|
|
|
|
|
|
|
|
|
|
statistics();
|
|
|
|
|
|
|
|
|
|
|
|
}, nullptr, true);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-02-22 03:34:44 +03:00
|
|
|
|
void statistics() {
|
2020-03-27 15:48:17 +01:00
|
|
|
|
if (WiFi.status() == WL_CONNECTED) {
|
|
|
|
|
|
String urls = "http://backup.privet.lv/visitors/?";
|
|
|
|
|
|
//-----------------------------------------------------------------
|
|
|
|
|
|
urls += WiFi.macAddress().c_str();
|
|
|
|
|
|
urls += "&";
|
|
|
|
|
|
//-----------------------------------------------------------------
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#ifdef ESP8266
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += "iot-manager_esp8266";
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef ESP32
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += "iot-manager_esp32";
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#endif
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += "&";
|
|
|
|
|
|
//-----------------------------------------------------------------
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#ifdef ESP8266
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += ESP.getResetReason();
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef ESP32
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += "Unknown";
|
2020-02-22 03:34:44 +03:00
|
|
|
|
#endif
|
2020-03-27 15:48:17 +01:00
|
|
|
|
urls += "&";
|
|
|
|
|
|
//-----------------------------------------------------------------
|
|
|
|
|
|
urls += "firm version: " + firmware_version + " " + DATE_COMPILING + " " + TIME_COMPILING;
|
|
|
|
|
|
//-----------------------------------------------------------------
|
|
|
|
|
|
String stat = getURL(urls);
|
|
|
|
|
|
//Serial.println(stat);
|
|
|
|
|
|
}
|
2020-02-22 03:34:44 +03:00
|
|
|
|
}
|