исправление бага списка, добавил кнопку перезагрузить все устройства

This commit is contained in:
Dmitry Borisenko
2022-02-15 00:03:28 +01:00
parent 709c4fb961
commit f5afc00c32
5 changed files with 43 additions and 63 deletions

File diff suppressed because one or more lines are too long

View File

@@ -1,7 +1,7 @@
#pragma once #pragma once
//Это версия прошивки //Это версия прошивки
#define FIRMWARE_VERSION 402 #define FIRMWARE_VERSION 403
//Размер буфера json //Размер буфера json
#define JSON_BUFFER_SIZE 1024 #define JSON_BUFFER_SIZE 1024

View File

@@ -13,5 +13,4 @@ extern void asyncUdpInit();
extern String uint8tToString(uint8_t* data, size_t len); extern String uint8tToString(uint8_t* data, size_t len);
extern bool udpPacketValidation(String& data); extern bool udpPacketValidation(String& data);
extern void udpPacketParse(String& data); extern void udpPacketParse(String& data);
extern void jsonMergeArrays(String& arr1, String& arr2); extern void jsonMergeArrays(String& existJson, String& incJson);
extern void jsonMergeArrays2(String& arr1, String& arr2);

View File

@@ -1,7 +1,7 @@
#include "DeviceList.h" #include "DeviceList.h"
const String getThisDevice() { const String getThisDevice() {
String thisDevice; String thisDevice = "{}";
jsonWriteStr_(thisDevice, F("devicelist"), ""); //метка для парсинга jsonWriteStr_(thisDevice, F("devicelist"), ""); //метка для парсинга
jsonWriteStr_(thisDevice, F("ip"), jsonReadStr(settingsFlashJson, F("ip"))); jsonWriteStr_(thisDevice, F("ip"), jsonReadStr(settingsFlashJson, F("ip")));
jsonWriteStr_(thisDevice, F("id"), jsonReadStr(settingsFlashJson, F("id"))); jsonWriteStr_(thisDevice, F("id"), jsonReadStr(settingsFlashJson, F("id")));
@@ -39,7 +39,7 @@ void asyncUdpInit() {
if (udpPacketValidation(data)) { if (udpPacketValidation(data)) {
SerialPrint("i", F("UDP"), "Udp packet received, IP: " + packet.remoteIP().toString() + ":" + String(packet.remotePort())); SerialPrint("i", F("UDP"), "Udp packet received, IP: " + packet.remoteIP().toString() + ":" + String(packet.remotePort()));
// Serial.println(data); // Serial.println(data);
jsonMergeArrays2(devListHeapJson, data); jsonMergeArrays(devListHeapJson, data);
// Serial.println(devListHeapJson); // Serial.println(devListHeapJson);
} else { } else {
SerialPrint("E", F("UDP"), F("Udp packet invalid")); SerialPrint("E", F("UDP"), F("Udp packet invalid"));
@@ -53,7 +53,7 @@ void asyncUdpInit() {
//будем отправлять каждые 60 секунд презентацию данного устройства //будем отправлять каждые 60 секунд презентацию данного устройства
ts.add( ts.add(
UDP, 60000, [&](void*) { UDP, 30000, [&](void*) {
SerialPrint("i", F("UDP"), F("Broadcast device presentation")); SerialPrint("i", F("UDP"), F("Broadcast device presentation"));
asyncUdp.broadcastTo(getThisDevice().c_str(), 4210); asyncUdp.broadcastTo(getThisDevice().c_str(), 4210);
// asyncUdp.broadcast("test"); // asyncUdp.broadcast("test");
@@ -72,74 +72,55 @@ bool udpPacketValidation(String& data) {
} }
} }
void jsonMergeArrays(String& arr1, String& arr2) { void jsonMergeArrays(String& existJson, String& incJson) {
DynamicJsonDocument doc(1024); DynamicJsonDocument incJsonDoc(1024);
DeserializationError error = deserializeJson(doc, arr1); DeserializationError incJsonError = deserializeJson(incJsonDoc, incJson);
if (error) { if (incJsonError) {
SerialPrint("E", F("UDP"), error.f_str()); SerialPrint("E", F("UDP"), "Invailed json in incomming udp packet " + String(incJsonError.f_str()));
jsonErrorDetected();
return;
} }
JsonArray jarr = doc.as<JsonArray>();
arr2.replace("[", "");
arr2.replace("]", "");
String incIP = jsonReadStr(arr2, "ip");
// Serial.println("incIP " + incIP); DynamicJsonDocument existJsonDoc(1024);
bool ipExistInList = false; DeserializationError existJsonError = deserializeJson(existJsonDoc, existJson);
for (JsonVariant value : jarr) { if (existJsonError) {
String locIP = value["ip"].as<String>(); SerialPrint("E", F("UDP"), "Invailed json in existing udp dev list " + String(incJsonError.f_str()));
// Serial.println("locIP " + locIP); jsonErrorDetected();
if (locIP == incIP) { return;
ipExistInList = true;
break;
} else {
ipExistInList = false;
} }
} JsonArray existJsonArr = existJsonDoc.as<JsonArray>();
if (!ipExistInList) {
arr1.replace("]", "");
arr1 = arr1 + "," + arr2 + "]";
}
}
void jsonMergeArrays2(String& arr1, String& arr2) { incJson.replace("[", "");
DynamicJsonDocument doc(1024); incJson.replace("]", "");
DeserializationError error = deserializeJson(doc, arr1); String incIP = jsonReadStr(incJson, "ip");
if (error) {
SerialPrint("E", F("UDP"), error.f_str());
}
JsonArray jarr = doc.as<JsonArray>();
arr2.replace("[", "");
arr2.replace("]", "");
String incIP = jsonReadStr(arr2, "ip");
String outArr = "["; String outArr = "[";
bool ipExistInList = false; bool ipExistInList = false;
for (JsonVariant value : jarr) { int i = 0;
for (JsonVariant value : existJsonArr) {
String locIP = value["ip"].as<String>(); String locIP = value["ip"].as<String>();
if (locIP == incIP) { if (locIP == incIP) {
outArr += "," + arr2; if (i == 0) {
outArr += incJson;
} else {
outArr += ("," + incJson);
}
ipExistInList = true; ipExistInList = true;
} else { } else {
if (i == 0) {
outArr += value.as<String>(); outArr += value.as<String>();
} else {
outArr += ("," + value.as<String>());
} }
} }
i++;
}
if (!ipExistInList) { if (!ipExistInList) {
outArr += "," + arr2; outArr += "," + incJson;
} }
outArr = outArr + "]"; outArr = outArr + "]";
arr1 = outArr; existJson = outArr;
} }
// void udpPacketParse(String& data) {
// if (data.indexOf("scen:") != -1) {
// data = deleteBeforeDelimiter(data, ":");
// writeFile(String(DEVICE_SCENARIO_FILE), data);
// loadScenario();
// } else if (data.indexOf("event:") != -1) {
// data = deleteBeforeDelimiter(data, ":");
// eventBuf += data;
// }
// }
String uint8tToString(uint8_t* data, size_t len) { String uint8tToString(uint8_t* data, size_t len) {
String ret; String ret;
while (len--) { while (len--) {

View File

@@ -23,9 +23,6 @@ void setup() {
//подключаемся к роутеру //подключаемся к роутеру
routerConnect(); routerConnect();
//синхронизация списка устройств
addThisDeviceToList();
//запустим один раз асинхронное сканирование сетей wifi для веба //запустим один раз асинхронное сканирование сетей wifi для веба
RouterFind(jsonReadStr(settingsFlashJson, F("routerssid"))); RouterFind(jsonReadStr(settingsFlashJson, F("routerssid")));
@@ -57,6 +54,9 @@ void setup() {
//окончательнаясинхронизация настроек //окончательнаясинхронизация настроек
syncSettingsFlashJson(); syncSettingsFlashJson();
//синхронизация списка устройств
addThisDeviceToList();
//запуск работы udp //запуск работы udp
asyncUdpInit(); asyncUdpInit();
@@ -95,5 +95,5 @@ void loop() {
IoTItems[i]->loop(); IoTItems[i]->loop();
} }
//iotScen.ExecScenario(); // iotScen.ExecScenario();
} }