запустил общение устройств по udp

This commit is contained in:
Dmitry Borisenko
2022-02-13 16:13:51 +01:00
parent ed78401762
commit caa2102eff
10 changed files with 143 additions and 48 deletions

View File

@@ -12,6 +12,8 @@
#define STANDARD_WEB_SERVER #define STANDARD_WEB_SERVER
#define STANDARD_WEB_SOCKETS #define STANDARD_WEB_SOCKETS
#define UDP_ENABLED
//#define REST_FILE_OPERATIONS //#define REST_FILE_OPERATIONS
#define MQTT_RECONNECT_INTERVAL 20000 #define MQTT_RECONNECT_INTERVAL 20000
@@ -31,7 +33,7 @@ enum TimerTask_t { WIFI_SCAN,
TIME, TIME,
TIME_SYNC, TIME_SYNC,
UPTIME, UPTIME,
SYGNAL, UDP,
TIMES, TIMES,
PTASK }; PTASK };

View File

@@ -1,4 +1,11 @@
#pragma once #pragma once
#include "Global.h" #include "Global.h"
#include "ESPAsyncUDP.h"
extern AsyncUDP asyncUdp;
extern void addThisDeviceToList(); extern void addThisDeviceToList();
extern void asyncUdpInit();
extern String uint8tToString(uint8_t* data, size_t len);
extern bool udpPacketValidation(String& data);
extern void udpPacketParse(String& data);
extern void jsonMergeArrays(String& arr1, String& arr2);

View File

@@ -25,6 +25,6 @@ extern bool jsonWriteBool_(String& json, String name, bool value);
extern bool jsonWriteInt_(String& json, String name, int value); extern bool jsonWriteInt_(String& json, String name, int value);
extern bool jsonWriteFloat_(String& json, String name, float value); extern bool jsonWriteFloat_(String& json, String name, float value);
void writeUint8tValueToJsonString(uint8_t* payload, size_t length, size_t headerLenth, String& json); void writeUint8tValueToJsonString(uint8_t* payload, size_t length, size_t headerLenth, String& json);
extern bool jsonMerge(String& json1, String& json2); extern bool jsonMergeObjects(String& json1, String& json2);
extern void jsonMergeDocs(JsonObject dest, JsonObjectConst src); extern void jsonMergeDocs(JsonObject dest, JsonObjectConst src);
extern void jsonErrorDetected(); extern void jsonErrorDetected();

View File

@@ -16,6 +16,7 @@ data_dir = data_svelte
lib_deps_external = lib_deps_external =
bblanchon/ArduinoJson @6.18.0 bblanchon/ArduinoJson @6.18.0
me-no-dev/ESP Async WebServer me-no-dev/ESP Async WebServer
me-no-dev/ESPAsyncUDP
Links2004/WebSockets Links2004/WebSockets
knolleary/PubSubClient knolleary/PubSubClient

View File

@@ -1,10 +1,10 @@
#include "DeviceList.h" #include "DeviceList.h"
void addThisDeviceToList() { void addThisDeviceToList() {
jsonWriteStr_(devListHeapJson, "devicelist", ""); //метка для парсинга jsonWriteStr_(devListHeapJson, F("devicelist"), ""); //метка для парсинга
jsonWriteStr_(devListHeapJson, "ip", jsonReadStr(settingsFlashJson, "ip")); jsonWriteStr_(devListHeapJson, F("ip"), jsonReadStr(settingsFlashJson, F("ip")));
jsonWriteStr_(devListHeapJson, "id", jsonReadStr(settingsFlashJson, "id")); jsonWriteStr_(devListHeapJson, F("id"), jsonReadStr(settingsFlashJson, F("id")));
jsonWriteStr_(devListHeapJson, "name", jsonReadStr(settingsFlashJson, "name")); jsonWriteStr_(devListHeapJson, F("name"), jsonReadStr(settingsFlashJson, F("name")));
// для проверки // для проверки
// devListHeapJson = devListHeapJson + ","; // devListHeapJson = devListHeapJson + ",";
@@ -16,4 +16,114 @@ void addThisDeviceToList() {
devListHeapJson = "[" + devListHeapJson + "]"; devListHeapJson = "[" + devListHeapJson + "]";
Serial.println(devListHeapJson); Serial.println(devListHeapJson);
} }
#ifdef UDP_ENABLED
AsyncUDP asyncUdp;
void asyncUdpInit() {
if (asyncUdp.listenMulticast(IPAddress(239, 255, 255, 255), 4210)) {
asyncUdp.onPacket([](AsyncUDPPacket packet) {
// Serial.print("UDP Packet Type: ");
// Serial.println(packet.isBroadcast() ? "Broadcast" : packet.isMulticast() ? "Multicast" : "Unicast");
// Serial.print("From: ");
// Serial.print(packet.remoteIP());
// Serial.print(":");
// Serial.println(packet.remotePort());
// Serial.print("To: ");
// Serial.print(packet.localIP());
// Serial.print(":");
// Serial.println(packet.localPort());
// Serial.print(", Length: ");
// Serial.print(packet.length());
// Serial.print(", Data: ");
// Serial.write(packet.data(), packet.length());
String data = uint8tToString(packet.data(), packet.length());
SerialPrint("i", F("UDP"), "Udp packet received, IP: " + packet.remoteIP().toString() + ":" + String(packet.remotePort()));
Serial.println(data);
if (udpPacketValidation(data)) {
SerialPrint("i", F("UDP"), F("Device presentation received"));
jsonMergeArrays(devListHeapJson, data);
Serial.println(devListHeapJson);
} else {
SerialPrint("E", F("UDP"), F("Udp packet invalid"));
}
// reply to the client
// String ip = WiFi.localIP().toString();
// asyncUdp.broadcastTo(ip.c_str(), packet.remotePort());
// packet.printf(ip.c_str(), packet.length());
});
}
//будем отправлять каждые 10 секунд презентацию данного устройства
ts.add(
UDP, 10000, [&](void*) {
SerialPrint("i", F("UDP"), F("Broadcast device presentation"));
asyncUdp.broadcastTo(devListHeapJson.c_str(), 4210);
// asyncUdp.broadcast("test");
// asyncUdp.print("Hello Server!");
},
nullptr, true);
SerialPrint("I", F("UDP"), F("Udp Init"));
}
bool udpPacketValidation(String& data) {
if (data.indexOf("devicelist") != -1) {
return true;
} else {
return false;
}
}
void jsonMergeArrays(String& arr1, String& arr2) {
DynamicJsonDocument doc(1024);
DeserializationError error = deserializeJson(doc, arr1);
if (error) {
SerialPrint("E", F("UDP"), error.f_str());
}
JsonArray jarr = doc.as<JsonArray>();
arr2.replace("[", "");
arr2.replace("]", "");
String incIP = jsonReadStr(arr2, "ip");
Serial.println("incIP " + incIP);
bool ipExistInList = false;
for (JsonVariant value : jarr) {
String locIP = value["ip"].as<String>();
Serial.println("locIP " + locIP);
if (locIP == incIP) {
ipExistInList = true;
break;
} else {
ipExistInList = false;
}
}
if (!ipExistInList) {
arr1.replace("]", "");
arr1 = arr1 + "," + arr2 + "]";
}
}
// 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 ret;
while (len--) {
ret += (char)*data++;
}
return ret;
}
#endif

View File

@@ -46,13 +46,18 @@ void setup() {
//инициализация mqtt //инициализация mqtt
mqttInit(); mqttInit();
//настраиваем микроконтроллер
configure("/config.json"); configure("/config.json");
syncSettingsFlashJson();
//инициализация задач переодического выполнения //инициализация задач переодического выполнения
periodicTasksInit(); periodicTasksInit();
//окончательнаясинхронизация настроек
syncSettingsFlashJson();
//запуск работы udp
asyncUdpInit();
// test // test
Serial.println("-------test start--------"); Serial.println("-------test start--------");
Serial.println("--------test end---------"); Serial.println("--------test end---------");

View File

@@ -255,7 +255,7 @@ void publishWidgets() {
return; return;
} }
size_t size = file.size(); size_t size = file.size();
DynamicJsonDocument doc(size * 1.5); DynamicJsonDocument doc(size * 2);
DeserializationError error = deserializeJson(doc, file); DeserializationError error = deserializeJson(doc, file);
if (error) { if (error) {
SerialPrint("E", F("MQTT"), error.f_str()); SerialPrint("E", F("MQTT"), error.f_str());
@@ -270,8 +270,8 @@ void publishWidgets() {
void publishState() { void publishState() {
String json = "{}"; String json = "{}";
jsonMerge(json, paramsHeapJson); jsonMergeObjects(json, paramsHeapJson);
jsonMerge(json, paramsFlashJson); jsonMergeObjects(json, paramsFlashJson);
json.replace("{", ""); json.replace("{", "");
json.replace("}", ""); json.replace("}", "");
json.replace("\"", ""); json.replace("\"", "");

View File

@@ -52,8 +52,8 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t* payload, size_t length)
if (headerStr == "/|") { if (headerStr == "/|") {
sendFileToWs("/layout.json", num, 1024); sendFileToWs("/layout.json", num, 1024);
String json = "{}"; String json = "{}";
jsonMerge(json, paramsHeapJson); jsonMergeObjects(json, paramsHeapJson);
jsonMerge(json, paramsFlashJson); jsonMergeObjects(json, paramsFlashJson);
standWebSocket.sendTXT(num, json); standWebSocket.sendTXT(num, json);
} }
//**сохранение**// //**сохранение**//

View File

@@ -163,10 +163,10 @@ void writeUint8tValueToJsonString(uint8_t* payload, size_t length, size_t header
for (size_t i = headerLenth; i < length; i++) { for (size_t i = headerLenth; i < length; i++) {
payloadStr += (char)payload[i]; payloadStr += (char)payload[i];
} }
jsonMerge(json, payloadStr); jsonMergeObjects(json, payloadStr);
} }
bool jsonMerge(String& json1, String& json2) { bool jsonMergeObjects(String& json1, String& json2) {
bool ret = true; bool ret = true;
DynamicJsonDocument doc1(JSON_BUFFER_SIZE); DynamicJsonDocument doc1(JSON_BUFFER_SIZE);
DeserializationError error1 = deserializeJson(doc1, json1); DeserializationError error1 = deserializeJson(doc1, json1);
@@ -174,7 +174,7 @@ bool jsonMerge(String& json1, String& json2) {
DeserializationError error2 = deserializeJson(doc2, json2); DeserializationError error2 = deserializeJson(doc2, json2);
jsonMergeDocs(doc1.as<JsonObject>(), doc2.as<JsonObject>()); jsonMergeDocs(doc1.as<JsonObject>(), doc2.as<JsonObject>());
if (error1 || error2) { if (error1 || error2) {
SerialPrint("EE", F("json"), "jsonMerge error"); SerialPrint("EE", F("json"), "jsonMergeObjects error");
jsonErrorDetected(); jsonErrorDetected();
ret = false; ret = false;
} }

View File

@@ -138,33 +138,3 @@ uint8_t RSSIquality() {
} }
return res; return res;
} }
// void wifiSignalInit() {
// ts.add(
// SYGNAL, 1000 * 60, [&](void*) {
// switch (RSSIquality()) {
// case 0:
// jsonWriteStr(settingsFlashJson, F("signal"), F("не подключено к роутеру"));
// break;
// case 1:
// jsonWriteStr(settingsFlashJson, F("signal"), F("нет сигнала"));
// break;
// case 2:
// jsonWriteStr(settingsFlashJson, F("signal"), F("очень низкий"));
// break;
// case 3:
// jsonWriteStr(settingsFlashJson, F("signal"), F("низкий"));
// break;
// case 4:
// jsonWriteStr(settingsFlashJson, F("signal"), F("хороший"));
// break;
// case 5:
// jsonWriteStr(settingsFlashJson, F("signal"), F("очень хороший"));
// break;
// case 6:
// jsonWriteStr(settingsFlashJson, F("signal"), F("отличный"));
// break;
// }
// },
// nullptr, true);
// }