mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-27 06:32:19 +03:00
Merge pull request #310 from Mit4el/ver4dev
Add board 16m, Add wifi multi point
This commit is contained in:
@@ -104,35 +104,43 @@
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8266_4mb": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8266_1mb": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8266_1mb_ota": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8285_1mb": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8285_1mb_ota": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8266_2mb": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
],
|
||||
"esp8266_2mb_ota": [
|
||||
"https://github.com/maxint-rd/TM16xx",
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5"
|
||||
"adafruit/Adafruit GFX Library @ ^1.11.5",
|
||||
"adafruit/Adafruit BusIO @ ^1.13.2"
|
||||
]
|
||||
}
|
||||
}
|
||||
@@ -46,7 +46,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -45,7 +45,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -49,6 +49,9 @@
|
||||
"esp8266_4mb": [
|
||||
"gyverlibs/EncButton @ ^2.0"
|
||||
],
|
||||
"esp8266_16mb": [
|
||||
"gyverlibs/EncButton @ ^2.0"
|
||||
],
|
||||
"esp8266_1mb": [
|
||||
"gyverlibs/EncButton @ ^2.0"
|
||||
],
|
||||
|
||||
@@ -35,7 +35,9 @@
|
||||
"defActive": false,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": []
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": []
|
||||
}
|
||||
}
|
||||
@@ -58,6 +58,9 @@
|
||||
"esp32_4mb": [
|
||||
"CTBot @2.1.9"
|
||||
],
|
||||
"esp32_16mb": [
|
||||
"CTBot @2.1.9"
|
||||
],
|
||||
"esp8266_4mb": [
|
||||
"CTBot @2.1.9"
|
||||
]
|
||||
|
||||
@@ -52,8 +52,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -69,6 +69,11 @@
|
||||
"descr": "Отправить значение в топик MQTT",
|
||||
"params": ["Топик", "Значение"]
|
||||
},
|
||||
{
|
||||
"name": "mqttIsConnect",
|
||||
"descr": "Получить состояние подключения к MQTT",
|
||||
"params": []
|
||||
},
|
||||
{
|
||||
"name": "getHours",
|
||||
"descr": "Получить текущее число часов. Если время не получено из сети Интернет или внешнего RTC, то условие пропускается",
|
||||
|
||||
@@ -7,16 +7,16 @@
|
||||
#include "Global.h"
|
||||
#include "classes/IoTItem.h"
|
||||
|
||||
//!Здесь подключаем стороннюю библиотеку при необходимости (ExternalLibrary заменить)
|
||||
//#include <ExternalLibrary.h>
|
||||
#include "ExternalLibrary.h" //удалить, только для примера. Внешние библиотеки правильно в <>
|
||||
//! Здесь подключаем стороннюю библиотеку при необходимости (ExternalLibrary заменить)
|
||||
// #include <ExternalLibrary.h>
|
||||
#include "ExternalLibrary.h" //удалить, только для примера. Внешние библиотеки правильно в <>
|
||||
|
||||
//! Объяевляем класс IoTGpio для работы с GPIO
|
||||
//! Объяевляем класс IoTGpio для работы с GPIO
|
||||
extern IoTGpio IoTgpio;
|
||||
|
||||
//=========================================================================================================
|
||||
//=========================================================================================================
|
||||
// Объявление сторонней библиотекит с использованием глобавльных объектов
|
||||
// Объявление сторонней библиотекит с использованием глобавльных объектов
|
||||
//=======================================================================================================
|
||||
//! Объявляем стороннюю библиотеку при необходимости (ExternalLibrary заменить)
|
||||
// !!! ЗДЕСЬ И ДАЛЕЕ libXX НАЗВАТЬ уникальным именем)
|
||||
@@ -25,9 +25,15 @@ ExternalLibrary *libXX = nullptr;
|
||||
// Функция инициализации библиотечного класса, возвращает Единстрвенный указать на библиотеку
|
||||
// instanceLibXX НАЗВАТЬ по наименованию модуля (instanceДатчикХ)
|
||||
// ПРИ НЕОБХДИМОСТИ передаем любые нужные параметры для инициализации библиотеки (в данном случае PIN)
|
||||
// !!! ВЫзвать данную функцию нужно хотябы один раз,
|
||||
//
|
||||
// !!! ВЫзвать данную функцию нужно хотябы один раз,
|
||||
// но в каждом конструкторе класса модуля ExampleModule_A, ExampleModule_B и т.д.
|
||||
// или можно вывывать постоянно при обращении к библиотеке, типа: instanceLibXX().READ_LIB_DATA_OTHER();
|
||||
//
|
||||
// !!!!!! В деструкторах ~ExampleModule_B() и ~ExampleModule_A() надо УДАЛЯТЬ объект libXX, ЕСЛИ в функцию instanceLibXX чтото передается.
|
||||
// Удаляем класс библиотеки, а то при переконфигурации в нем не поменяются PIN и дугие параметры передаваемые в библиотеку.
|
||||
// P.S. Не для всех, если используется map или vector то лучше не надо.
|
||||
|
||||
ExternalLibrary *instanceLibXX(int pin)
|
||||
{
|
||||
if (!libXX)
|
||||
@@ -39,7 +45,6 @@ ExternalLibrary *instanceLibXX(int pin)
|
||||
return libXX;
|
||||
}
|
||||
|
||||
|
||||
//=========================================================================================================
|
||||
//=========================================================================================================
|
||||
// Первый класс модуля для определения 1-го элемента (параметра)
|
||||
@@ -69,7 +74,7 @@ public:
|
||||
// jsonReadStr, jsonReadBool, jsonReadInt
|
||||
ExampleModule_A(String parameters) : IoTItem(parameters)
|
||||
{
|
||||
//Читаем пользовательскую переменную PIN, должна быть объявлена в в modeinfo.json
|
||||
// Читаем пользовательскую переменную PIN, должна быть объявлена в в modeinfo.json
|
||||
_pin = jsonReadInt(parameters, "pin");
|
||||
// другой вариант чтения парметров модуля
|
||||
jsonRead(parameters, F("int"), _interval, false);
|
||||
@@ -111,7 +116,12 @@ public:
|
||||
}
|
||||
}
|
||||
|
||||
~ExampleModule_A(){};
|
||||
~ExampleModule_A()
|
||||
{
|
||||
// Удаляем класс библиотеки, а то при переконфигурации в нем не поменяются PIN и дугие параметры передаваемые в библиотеку.
|
||||
delete libXX;
|
||||
libXX = nullptr;
|
||||
};
|
||||
};
|
||||
|
||||
//=========================================================================================================
|
||||
@@ -126,14 +136,15 @@ public:
|
||||
class ExampleModule_B : public IoTItem
|
||||
{
|
||||
private:
|
||||
//Пользовательские переменные
|
||||
// Пользовательские переменные
|
||||
unsigned int _pin;
|
||||
|
||||
public:
|
||||
ExampleModule_B(String parameters) : IoTItem(parameters)
|
||||
{
|
||||
//Читаем пользовательскую переменную PIN, должна быть объявлена в в modeinfo.json
|
||||
// Читаем пользовательскую переменную PIN, должна быть объявлена в в modeinfo.json
|
||||
_pin = jsonReadInt(parameters, "pin");
|
||||
//Можно инициализировать библиотеку один раз, а потом используем указатель
|
||||
// Можно инициализировать библиотеку один раз, а потом используем указатель
|
||||
instanceLibXX(_pin);
|
||||
libXX->READ_LIB_DATA_OTHER();
|
||||
}
|
||||
@@ -146,7 +157,7 @@ public:
|
||||
regEvent(value.valD, "ExampleModule"); // обязательный вызов хотяб один для регистрации события в ядре IoTM
|
||||
}
|
||||
|
||||
//================ обработка кнопок из конфигурации ===================
|
||||
//================ обработка кнопок из конфигурации ===================
|
||||
// Хук (переопределение виртуальной функции) для обработки кнопки (в value будут данные с собственной панели ввода)
|
||||
// Что бы кнопка была без поля ввода, нужно в modeinfo.json указать "btn-Example": nil
|
||||
void onModuleOrder(String &key, String &value)
|
||||
@@ -158,7 +169,7 @@ public:
|
||||
}
|
||||
}
|
||||
|
||||
//================ обработка команд из сценария===================
|
||||
//================ обработка команд из сценария===================
|
||||
// Хук (переопределение виртуальной функции) для обработки команды из сценария (в param будут даныые переданные в функции в сценарии)
|
||||
IoTValue execute(String command, std::vector<IoTValue> ¶m)
|
||||
{
|
||||
@@ -204,10 +215,14 @@ public:
|
||||
// Прсото пример кокой-то функции
|
||||
}
|
||||
|
||||
~ExampleModule_B(){};
|
||||
~ExampleModule_B()
|
||||
{
|
||||
// Удаляем класс библиотеки, а то при переконфигурации в нем не поменяются PIN и дугие параметры передаваемые в библиотеку.
|
||||
delete libXX;
|
||||
libXX = nullptr;
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
//=========================================================================================================
|
||||
//=========================================================================================================
|
||||
// Функция для связи модуля с ядром IoTM
|
||||
|
||||
@@ -13,16 +13,24 @@ private:
|
||||
int red = 0;
|
||||
int offline = 0;
|
||||
bool dataFromNode = false;
|
||||
String _topic = "";
|
||||
bool _isJson;
|
||||
bool _addPrefix;
|
||||
bool _debug;
|
||||
|
||||
public:
|
||||
ExternalMQTT(String parameters) : IoTItem(parameters)
|
||||
{
|
||||
_MAC = jsonReadStr(parameters, "MAC");
|
||||
_sensor = jsonReadStr(parameters, "sensor");
|
||||
jsonRead(parameters, F("orange"), orange);
|
||||
jsonRead(parameters, F("red"), red);
|
||||
jsonRead(parameters, F("offline"), offline);
|
||||
_topic = jsonReadStr(parameters, "topic");
|
||||
_isJson = jsonReadBool(parameters, "isJson");
|
||||
_addPrefix = jsonReadBool(parameters, "addPrefix");
|
||||
_debug = jsonReadBool(parameters, "debug");
|
||||
dataFromNode = false;
|
||||
mqttSubscribeExternal(_topic, _addPrefix);
|
||||
}
|
||||
char *TimeToString(unsigned long t)
|
||||
{
|
||||
@@ -38,38 +46,58 @@ public:
|
||||
{
|
||||
if (msg.indexOf("HELLO") == -1)
|
||||
{
|
||||
|
||||
// SerialPrint("i", "onMqttRecive", "Прилетело " + topic);
|
||||
// SerialPrint("i", "onMqttRecive", "Прилетело " + msg);
|
||||
if (_debug)
|
||||
{
|
||||
SerialPrint("i", "onMqttRecive", "Прилетело " + topic + " msg: " + msg);
|
||||
// SerialPrint("i", "onMqttRecive", "Прилетело " + msg);
|
||||
}
|
||||
String dev = selectToMarkerLast(topic, "/");
|
||||
dev.toUpperCase();
|
||||
dev.replace(":", "");
|
||||
if (_MAC == "")
|
||||
if (_topic != topic)
|
||||
{
|
||||
SerialPrint("i", "onMqttRecive", dev + " --> " + msg);
|
||||
return;
|
||||
}
|
||||
DynamicJsonDocument doc(JSON_BUFFER_SIZE);
|
||||
DeserializationError error = deserializeJson(doc, msg);
|
||||
if (error)
|
||||
if (_isJson)
|
||||
{
|
||||
SerialPrint("E", F("onMqttRecive"), error.f_str());
|
||||
}
|
||||
JsonObject jsonObject = doc.as<JsonObject>();
|
||||
|
||||
for (JsonPair kv : jsonObject)
|
||||
{
|
||||
String key = kv.key().c_str();
|
||||
String val = kv.value();
|
||||
if (_MAC == dev && _sensor == key)
|
||||
DynamicJsonDocument doc(JSON_BUFFER_SIZE);
|
||||
DeserializationError error = deserializeJson(doc, msg);
|
||||
if (error)
|
||||
{
|
||||
dataFromNode = true;
|
||||
_minutesPassed = 0;
|
||||
setValue(val);
|
||||
// setNewWidgetAttributes();
|
||||
SerialPrint("E", F("onMqttRecive"), error.f_str());
|
||||
}
|
||||
JsonObject jsonObject = doc.as<JsonObject>();
|
||||
|
||||
// Serial.println("Key: " + key);
|
||||
// Serial.println("Value: " + val);
|
||||
for (JsonPair kv : jsonObject)
|
||||
{
|
||||
String key = kv.key().c_str();
|
||||
String val = kv.value();
|
||||
if (_debug)
|
||||
{
|
||||
SerialPrint("i", "onMqttRecive", "Прилетело MAC: " + dev + " key=" + key + " val=" + val);
|
||||
}
|
||||
if (_sensor == key)
|
||||
{
|
||||
dataFromNode = true;
|
||||
_minutesPassed = 0;
|
||||
setValue(val);
|
||||
// setNewWidgetAttributes();
|
||||
}
|
||||
|
||||
// Serial.println("Key: " + key);
|
||||
// Serial.println("Value: " + val);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (_debug)
|
||||
{
|
||||
SerialPrint("i", "onMqttRecive", "Прилетело MAC: " + dev + " val=" + msg);
|
||||
}
|
||||
dataFromNode = true;
|
||||
_minutesPassed = 0;
|
||||
setValue(msg);
|
||||
// setNewWidgetAttributes();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -116,7 +144,22 @@ public:
|
||||
}
|
||||
sendSubWidgetsValues(_id, json);
|
||||
}
|
||||
|
||||
/*
|
||||
IoTValue execute(String command, std::vector<IoTValue> ¶m)
|
||||
{
|
||||
if (command == "mqttSubscribe")
|
||||
{
|
||||
if (param.size() == 2)
|
||||
{
|
||||
if (!param[0].isDecimal && param[1].isDecimal)
|
||||
{
|
||||
mqttSubscribeExternal(param[0].valS, (bool)param[0].valD);
|
||||
}
|
||||
}
|
||||
}
|
||||
return {};
|
||||
}
|
||||
*/
|
||||
~ExternalMQTT(){};
|
||||
};
|
||||
|
||||
|
||||
@@ -10,13 +10,16 @@
|
||||
"widget": "",
|
||||
"page": "",
|
||||
"descr": "",
|
||||
"MAC": "",
|
||||
"sensor": "",
|
||||
"topic": "",
|
||||
"addPrefix": 0,
|
||||
"isJson": 1,
|
||||
"round": "",
|
||||
"orange": 60,
|
||||
"red": 120,
|
||||
"offline": 180,
|
||||
"int": 60
|
||||
"int": 60,
|
||||
"debug": 0
|
||||
}
|
||||
],
|
||||
"about": {
|
||||
@@ -25,7 +28,7 @@
|
||||
"authorGit": "https://github.com/avaksru",
|
||||
"specialThanks": "",
|
||||
"moduleName": "ExternalMQTT",
|
||||
"moduleVersion": "1",
|
||||
"moduleVersion": "1.2",
|
||||
"usedRam": {
|
||||
"esp32_4mb": 15,
|
||||
"esp8266_4mb": 15
|
||||
@@ -38,13 +41,18 @@
|
||||
"orange": "количество минут после которого окрасить виджет в оранжевый цвет",
|
||||
"red": "количество минут после которого окрасить виджет в красный цвет",
|
||||
"offline": "количество минут после которого отобразить что устройство offline, если все три orange red и offline поставить в ноль - то функция окраски выключится",
|
||||
"MAC": "MAC адрес беспроводного датчика",
|
||||
"sensor": "Тип сенсора: температура / влажность / время / ... "
|
||||
"sensor": "Тип сенсора: температура / влажность / время / ... Он же ключ в json пакете ",
|
||||
"topic":"Подписаться на произвольный топик (полный путь), в модуле данный топик буде проверяться с отправителем, например homed/fd/zigbee/temp",
|
||||
"addPrefix":"1 (число), будет добавлен стандартный префикс из настроек, 0 - не добавлять префикс",
|
||||
"isJson":"1 - ожидаем в топике json, 0 - в топике просто значение (при 0 поле sensor заполнять не требуется)",
|
||||
"debug":"1 - выводить дополнительный лог в сериал"
|
||||
}
|
||||
|
||||
},
|
||||
"defActive": false,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
|
||||
@@ -235,7 +235,11 @@ public:
|
||||
}
|
||||
}
|
||||
}
|
||||
~ld2410m(){};
|
||||
~ld2410m()
|
||||
{
|
||||
delete ld2410;
|
||||
radar = nullptr;
|
||||
};
|
||||
};
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
@@ -291,7 +295,11 @@ public:
|
||||
}
|
||||
}
|
||||
|
||||
~ld2410t(){};
|
||||
~ld2410t()
|
||||
{
|
||||
delete ld2410;
|
||||
radar = nullptr;
|
||||
};
|
||||
};
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
@@ -346,7 +354,11 @@ public:
|
||||
}
|
||||
}
|
||||
}
|
||||
~ld2410d(){};
|
||||
~ld2410d()
|
||||
{
|
||||
delete ld2410;
|
||||
radar = nullptr;
|
||||
};
|
||||
};
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
@@ -404,7 +416,11 @@ public:
|
||||
}
|
||||
}
|
||||
}
|
||||
~ld2410e(){};
|
||||
~ld2410e()
|
||||
{
|
||||
delete ld2410;
|
||||
radar = nullptr;
|
||||
};
|
||||
};
|
||||
//---------------------------------------------------------------------------
|
||||
void *getAPI_ld2410(String subtype, String param)
|
||||
|
||||
@@ -50,8 +50,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -51,8 +51,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -44,8 +44,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -74,8 +74,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -36,8 +36,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -96,8 +96,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -35,8 +35,10 @@
|
||||
"defActive": true,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
@@ -40,8 +40,10 @@
|
||||
"defActive": false,
|
||||
"usedLibs": {
|
||||
"esp32_4mb": [],
|
||||
"esp32_16mb": [],
|
||||
"esp32s2_4mb": [],
|
||||
"esp8266_4mb": [],
|
||||
"esp8266_16mb": [],
|
||||
"esp8266_1mb": [],
|
||||
"esp8266_1mb_ota": [],
|
||||
"esp8285_1mb": [],
|
||||
|
||||
Reference in New Issue
Block a user