mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-27 14:42:18 +03:00
Меняем структуру FS для хранения модулей и добавляем скрипт сборки модулей для интеграции в меню и библиотеки
This commit is contained in:
72
src/modules/system/Mcp23017/Mcp23017.cpp
Normal file
72
src/modules/system/Mcp23017/Mcp23017.cpp
Normal file
@@ -0,0 +1,72 @@
|
||||
#include "Global.h"
|
||||
#include "classes/IoTItem.h"
|
||||
#include "classes/IoTGpio.h"
|
||||
#include <Adafruit_MCP23X17.h>
|
||||
|
||||
|
||||
class Mcp23017 : public IoTItem, IoTGpio {
|
||||
private:
|
||||
|
||||
public:
|
||||
Adafruit_MCP23X17 mcp;
|
||||
|
||||
Mcp23017(String parameters, int index): IoTItem(parameters), IoTGpio(index) {
|
||||
|
||||
}
|
||||
|
||||
void doByInterval() {
|
||||
|
||||
|
||||
//regEvent(value.valD, "Mcp23017");
|
||||
}
|
||||
|
||||
IoTGpio* getGpioDriver() {
|
||||
return this;
|
||||
}
|
||||
|
||||
void pinMode(uint8_t pin, uint8_t mode) {
|
||||
mcp.pinMode(pin, mode);
|
||||
}
|
||||
|
||||
void digitalWrite(uint8_t pin, uint8_t val) {
|
||||
mcp.digitalWrite(pin, val);
|
||||
}
|
||||
|
||||
int digitalRead(uint8_t pin) {
|
||||
return mcp.digitalRead(pin);
|
||||
}
|
||||
|
||||
void digitalInvert(uint8_t pin) {
|
||||
mcp.digitalWrite(pin, 1 - mcp.digitalRead(pin));
|
||||
}
|
||||
|
||||
~Mcp23017() {};
|
||||
};
|
||||
|
||||
|
||||
void* getAPI_Mcp23017(String subtype, String param) {
|
||||
if (subtype == F("Mcp23017")) {
|
||||
String addr;
|
||||
jsonRead(param, "addr", addr);
|
||||
Serial.printf("deviceAddress %s = %02x \n", addr.c_str(), hexStringToUint8(addr));
|
||||
|
||||
String index_str;
|
||||
jsonRead(param, "index", index_str);
|
||||
int index = index_str.toInt();
|
||||
if (index > 4) {
|
||||
Serial.println("MCP23X17 wrong index. Must be 0 - 4");
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
Mcp23017* newItem = new Mcp23017(param, index);
|
||||
if (!newItem->mcp.begin_I2C(hexStringToUint8(addr))) {
|
||||
Serial.println("MCP23X17 Init Error.");
|
||||
delete newItem;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
return newItem;
|
||||
} else {
|
||||
return nullptr;
|
||||
}
|
||||
}
|
||||
16
src/modules/system/Mcp23017/items.json
Normal file
16
src/modules/system/Mcp23017/items.json
Normal file
@@ -0,0 +1,16 @@
|
||||
[
|
||||
{
|
||||
"name": "Расширитель портов Mcp23017",
|
||||
"num": 29,
|
||||
"type": "Reading",
|
||||
"subtype": "Mcp23017",
|
||||
"id": "Mcp",
|
||||
"widget": "",
|
||||
"page": "",
|
||||
"descr": "",
|
||||
|
||||
"int": "0",
|
||||
"addr": "0x20",
|
||||
"index": 1
|
||||
}
|
||||
]
|
||||
8
src/modules/system/Mcp23017/platformio.ini
Normal file
8
src/modules/system/Mcp23017/platformio.ini
Normal file
@@ -0,0 +1,8 @@
|
||||
[env:esp8266_4mb]
|
||||
lib_deps =
|
||||
adafruit/Adafruit MCP23017 Arduino Library@^2.0.2
|
||||
|
||||
[env:esp32_4mb]
|
||||
lib_deps =
|
||||
adafruit/Adafruit MCP23017 Arduino Library@^2.0.2
|
||||
|
||||
65
src/modules/system/SysExt/SysExt.cpp
Normal file
65
src/modules/system/SysExt/SysExt.cpp
Normal file
@@ -0,0 +1,65 @@
|
||||
#include "Global.h"
|
||||
#include "classes/IoTItem.h"
|
||||
|
||||
// Пример модуля расширения возможностей системы на примере добавления новых команд в сценарии
|
||||
// При комбинации использования doByInterval() и execute() можно обеспечить интеграцию с внешними сервисами, такими как Telegram, например.
|
||||
//
|
||||
|
||||
class SysExt : public IoTItem {
|
||||
public:
|
||||
SysExt(String parameters): IoTItem(parameters) {
|
||||
// инициализация внутренних переменных и объектов для взаимодействия с внешними системами
|
||||
//jsonRead(parameters, "addr", addr); // получаем параметры из настроек модуля. Наименования могут быть любыми.
|
||||
}
|
||||
|
||||
void doByInterval() {
|
||||
// выполнение периодических проверок каждые Int секунд из настроек модуля
|
||||
|
||||
//regEvent(Значение, Описание); // регистрация найденного события после проверок для запуска сценариев и других реакций в системе
|
||||
}
|
||||
|
||||
//void loop() {
|
||||
// выполнение необходимых проверок в теле основного цикла программы.
|
||||
// ВАЖНО: 1. при использовании loop() отключается doByInterval()
|
||||
// 2. любые заминки в данном цикле повлияют на общую работу системы
|
||||
//}
|
||||
|
||||
IoTValue execute(String command, std::vector<IoTValue> ¶m) {
|
||||
// реакция на вызов команды модуля из сценария
|
||||
// String command - имя команды после ID. (ID.Команда())
|
||||
// param - вектор ("массив") значений параметров переданных вместе с командой: ID.Команда("пар1", 22, 33) -> param[0].ValS = "пар1", param[1].ValD = 22
|
||||
|
||||
if (command == "reboot") { // выполняем код при вызове спец команды из сценария: ID.reboot();
|
||||
ESP.restart();
|
||||
} else if (command == "digitalRead") {
|
||||
if (param.size()) {
|
||||
IoTgpio.pinMode(param[0].valD, INPUT);
|
||||
value.valD = IoTgpio.digitalRead(param[0].valD);
|
||||
return value;
|
||||
}
|
||||
} else if (command == "digitalWrite") {
|
||||
if (param.size() == 2) {
|
||||
IoTgpio.pinMode(param[0].valD, OUTPUT);
|
||||
IoTgpio.digitalWrite(param[0].valD, param[1].valD);
|
||||
return {};
|
||||
}
|
||||
} else if (command == "digitalInvert") {
|
||||
if (param.size()) {
|
||||
IoTgpio.pinMode(param[0].valD, OUTPUT);
|
||||
IoTgpio.digitalInvert(param[0].valD);
|
||||
return {};
|
||||
}
|
||||
}
|
||||
return {}; // команда поддерживает возвращаемое значения. Т.е. по итогу выполнения команды или общения с внешней системой, можно вернуть значение в сценарий для дальнейшей обработки
|
||||
}
|
||||
|
||||
~SysExt() {};
|
||||
};
|
||||
|
||||
void* getAPI_SysExt(String subtype, String param) {
|
||||
if (subtype == F("SysExt")) {
|
||||
return new SysExt(param);
|
||||
} else {
|
||||
return nullptr;
|
||||
}
|
||||
}
|
||||
13
src/modules/system/SysExt/items.json
Normal file
13
src/modules/system/SysExt/items.json
Normal file
@@ -0,0 +1,13 @@
|
||||
[
|
||||
{
|
||||
"name": "Доп. функции системы",
|
||||
"num": 27,
|
||||
"type": "Reading",
|
||||
"subtype": "SysExt",
|
||||
"id": "SysExt",
|
||||
"widget": "",
|
||||
"page": "",
|
||||
"descr": "",
|
||||
"int": 15
|
||||
}
|
||||
]
|
||||
21
src/modules/system/Variable/Variable.cpp
Normal file
21
src/modules/system/Variable/Variable.cpp
Normal file
@@ -0,0 +1,21 @@
|
||||
#include "Global.h"
|
||||
#include "classes/IoTItem.h"
|
||||
|
||||
|
||||
class Variable : public IoTItem {
|
||||
public:
|
||||
Variable(String parameters): IoTItem(parameters) { }
|
||||
|
||||
// особенность данного модуля - просто хранение значения для сценария, нет событий
|
||||
// void setValue(IoTValue Value) {
|
||||
// value = Value;
|
||||
// }
|
||||
};
|
||||
|
||||
void* getAPI_Variable(String subtype, String param) {
|
||||
if (subtype == F("Variable")) {
|
||||
return new Variable(param);
|
||||
} else {
|
||||
return nullptr;
|
||||
}
|
||||
}
|
||||
15
src/modules/system/Variable/items.json
Normal file
15
src/modules/system/Variable/items.json
Normal file
@@ -0,0 +1,15 @@
|
||||
[
|
||||
{
|
||||
"name": "Переменная",
|
||||
"num": 30,
|
||||
"type": "Reading",
|
||||
"subtype": "Variable",
|
||||
"id": "var",
|
||||
"widget": "",
|
||||
"page": "",
|
||||
"descr": "",
|
||||
|
||||
"int": "0",
|
||||
"val": "0"
|
||||
}
|
||||
]
|
||||
5
src/modules/system/items.json
Normal file
5
src/modules/system/items.json
Normal file
@@ -0,0 +1,5 @@
|
||||
[
|
||||
{
|
||||
"header": "Расширения"
|
||||
}
|
||||
]
|
||||
Reference in New Issue
Block a user