diff --git a/include/classes/IoTItem.h b/include/classes/IoTItem.h index f08b22aa..168feef2 100644 --- a/include/classes/IoTItem.h +++ b/include/classes/IoTItem.h @@ -60,11 +60,12 @@ class IoTItem { int _map4; int _round; // 1, 10, 100, 1000, 10000 - bool _global = false; // характеристика айтема, что ему нужно слать и принимать события из внешнего мира + bool _global = false; // характеристика айтема, что ему нужно слать и принимать события из внешнего мира }; IoTItem* findIoTItem(String name); // поиск экземпляра элемента модуля по имени String getItemValue(String name); // поиск плюс получение значения +bool isItemExist(String name); // существует ли айтем StaticJsonDocument* getLocalItemsAsJSON(); // сбор всех локальных занчений Items class externalVariable : IoTItem { // объект, создаваемый при получении информации о событии на другом контроллере для хранения информации о событии указанное время diff --git a/src/MqttClient.cpp b/src/MqttClient.cpp index 02697985..5fc36311 100644 --- a/src/MqttClient.cpp +++ b/src/MqttClient.cpp @@ -319,8 +319,13 @@ void sendAllFilesToMQTT() { while (dir.next()) { String fname = dir.fileName(); String id = selectToMarker(fname, "-"); - SerialPrint("I", "Loging", fname); - sendLogData("/logs/" + fname, id); + if (isItemExist(id)) { + SerialPrint("I", "Loging", fname); + sendLogData("/logs/" + fname, id); + } else { + SerialPrint("i", "Loging", "file '" + fname + "' not used, deleted"); + removeFile(directory + "/" + fname); + } } } diff --git a/src/classes/IoTItem.cpp b/src/classes/IoTItem.cpp index 93213c9e..ed38505b 100644 --- a/src/classes/IoTItem.cpp +++ b/src/classes/IoTItem.cpp @@ -182,6 +182,15 @@ String getItemValue(String name) { return ""; } +// существует ли айтем +bool isItemExist(String name) { + IoTItem* tmp = findIoTItem(name); + if (tmp) + return true; + else + return false; +} + StaticJsonDocument docForExport; StaticJsonDocument* getLocalItemsAsJSON() {