Merge pull request #68 from ytrikoz/beta

FS info
This commit is contained in:
Dmitry Borisenko
2020-12-18 20:26:33 +01:00
committed by GitHub
3 changed files with 87 additions and 12 deletions

View File

@@ -3,9 +3,11 @@
//===========Firmware=============================================================================================================================================
#define FIRMWARE_VERSION 273
//#define FLASH_SIZE_1MB true
//===========FileSystem==============================================================================================================================================
#define USE_LITTLEFS true
//==================================================================================================================================================================
#define NUM_BUTTONS 6
#define LED_PIN 2
#define LED_PIN LED_BUILTIN
//===========MQTT=================================================================================================================================================
#define MQTT_RECONNECT_INTERVAL 20000
//==========Telemetry=============================================================================================================================================

36
include/FileSystem.h Normal file
View File

@@ -0,0 +1,36 @@
#pragma once
#include "Consts.h"
#define FILE_READ "r"
#define FILE_WRITE "w"
#define FILE_APPEND "a"
#if USE_LITTLEFS
#include <LittleFS.h>
extern FS LittleFS;
using littlefs_impl::LittleFSConfig;
extern FS *filesystem;
#define FileFS LittleFS
#define FS_NAME "LittleFS"
#else
extern FS *filesystem;
#define FileFS SPIFFS
#define FS_NAME "SPIFFS"
#endif
/*
* Информация о ФС
size_t totalBytes; // всего
size_t usedBytes; // использовано
size_t maxOpenFiles; // лимит на открые файлы
size_t maxPathLength; // лимит на полное пути + имя файла
FSInfo buf;
getInfo(buf);
size_t freeBytes = buf.totalBytes - buf.usedBytes;
float freePer = buf.usedBytes / buf.totalBytes * 100;
*/
bool getInfo(FSInfo& info) {
return FileFS.info(info);
}

View File

@@ -6,8 +6,25 @@
#include "Global.h"
#include "Init.h"
enum MqttBroker {MQTT_PRIMARY, MQTT_RESERVE};
MqttBroker activeBroker = MQTT_PRIMARY;
String mqttPrefix;
String mqttRootDevice;
String mqttPass;
String mqttServer;
String mqttUser;
uint16_t mqttPort{0};
uint16_t reconnectionCounter{0};
bool primaryExist = false;
const String getParamName(const char* param, MqttBroker broker) {
return String("mqtt") + param + (broker == MQTT_RESERVE? "2": "");
}
bool checkBrokerParams(MqttBroker broker) {
return !jsonReadStr(configSetupJson, getParamName("Server", broker)).isEmpty();
}
void mqttInit() {
myNotAsyncActions->add(
@@ -29,6 +46,16 @@ void mqttInit() {
}
else {
SerialPrint("E", "MQTT", "lost connection");
if (reconnectionCounter++ > 5) {
if (activeBroker == MQTT_PRIMARY) {
if (checkBrokerParams(MQTT_RESERVE)) {
activeBroker = MQTT_RESERVE;
}
} else {
activeBroker = MQTT_PRIMARY;
}
reconnectionCounter = 0;
}
mqttConnect();
}
}
@@ -77,25 +104,35 @@ void mqttSubscribe() {
}
}
boolean mqttConnect() {
SerialPrint("I", "MQTT", "start connection");
String addr = jsonReadStr(configSetupJson, "mqttServer");
if (!addr) {
SerialPrint("E", "MQTT", "no broker address");
bool readBrokerParams(MqttBroker broker) {
if(!checkBrokerParams(broker)) {
return false;
}
int port = jsonReadInt(configSetupJson, "mqttPort");
String user = jsonReadStr(configSetupJson, "mqttUser");
String pass = jsonReadStr(configSetupJson, "mqttPass");
mqttServer = jsonReadStr(configSetupJson, getParamName("Server", broker));
mqttPort = jsonReadInt(configSetupJson, getParamName("Port", broker));
mqttUser = jsonReadStr(configSetupJson, getParamName("User", broker));
mqttPass = jsonReadStr(configSetupJson, getParamName("Pass", broker));
return true;
}
boolean mqttConnect() {
SerialPrint("I", "MQTT", String("use ") + (activeBroker == MQTT_PRIMARY? "primary": "reserve"));
if (!checkBrokerParams(activeBroker)) {
SerialPrint("E", "MQTT", "empty broker address");
return false;
}
readBrokerParams(activeBroker);
SerialPrint("I", "MQTT", "start connection");
mqttPrefix = jsonReadStr(configSetupJson, "mqttPrefix");
mqttRootDevice = mqttPrefix + "/" + chipId;
SerialPrint("I", "MQTT", "broker " + addr + ":" + String(port, DEC));
SerialPrint("I", "MQTT", "broker " + mqttServer + ":" + String(mqttPort, DEC));
SerialPrint("I", "MQTT", "topic " + mqttRootDevice);
setLedStatus(LED_FAST);
mqtt.setServer(addr.c_str(), port);
mqtt.setServer(mqttServer.c_str(), mqttPort);
bool res = false;
if (!mqtt.connected()) {
if (mqtt.connect(chipId.c_str(), user.c_str(), pass.c_str())) {
if (mqtt.connect(chipId.c_str(), mqttUser.c_str(), mqttPass.c_str())) {
SerialPrint("I", "MQTT", "connected");
setLedStatus(LED_OFF);
mqttSubscribe();