Files
IoTManager/Init.ino

214 lines
6.7 KiB
Arduino
Raw Normal View History

2019-12-24 11:53:26 +03:00
void All_init() {
2020-04-05 01:52:02 +02:00
server.on("/init", HTTP_GET, [](AsyncWebServerRequest * request) {
String value;
if (request->hasArg("arg")) {
value = request->getParam("arg")->value();
}
if (value == "0") {
jsonWriteStr(configSetup, "scenario", value);
saveConfig();
Scenario_init();
}
if (value == "1") {
jsonWriteStr(configSetup, "scenario", value);
saveConfig();
Scenario_init();
}
if (value == "2") {
Device_init();
}
if (value == "3") {
clean_log_date();
}
if (value == "4") {
Scenario_init();
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
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-04-05 01:52:02 +02:00
request->redirect("/?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";
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";
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";
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";
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() {
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
urls += "iot-manager_esp8266";
2020-02-22 03:34:44 +03:00
#endif
#ifdef ESP32
urls += "iot-manager_esp32";
2020-02-22 03:34:44 +03:00
#endif
urls += "&";
//-----------------------------------------------------------------
2020-02-22 03:34:44 +03:00
#ifdef ESP8266
urls += ESP.getResetReason();
2020-02-22 03:34:44 +03:00
#endif
#ifdef ESP32
urls += "Unknown";
2020-02-22 03:34:44 +03:00
#endif
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
}