mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-26 22:22:16 +03:00
запустил общение устройств по udp
This commit is contained in:
@@ -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 };
|
||||||
|
|
||||||
|
|||||||
@@ -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);
|
||||||
@@ -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();
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
@@ -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---------");
|
||||||
|
|||||||
@@ -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("\"", "");
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
//**сохранение**//
|
//**сохранение**//
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
|
||||||
// }
|
|
||||||
|
|||||||
Reference in New Issue
Block a user