switched mqtt client; implemented persistence

This commit is contained in:
Timo Volkmann 2020-07-02 21:50:12 +02:00
parent 861d8b527b
commit a6fbbfab73
5 changed files with 70 additions and 20 deletions

View File

@ -21,6 +21,7 @@ lib_deps =
AutoConnect@^1.1.7 AutoConnect@^1.1.7
AsyncMqttClient@^0.8.2 AsyncMqttClient@^0.8.2
ArduinoJson@^6.15.2 ArduinoJson@^6.15.2
MQTT@^2.4.7 ; MQTT@^2.4.7
; PubSubClient@^2.8 PubSubClient@^2.8
ArduinoNvs@^2.5
; ESPRandom@^1.3.3 ; ESPRandom@^1.3.3

View File

@ -1,5 +1,6 @@
#include <ArduinoJson.h> #include <ArduinoJson.h>
#include <MQTT.h> // #include <MQTT.h>
#include <PubSubClient.h>
#include <header.h> #include <header.h>
extern "C" { extern "C" {
@ -23,7 +24,8 @@ WiFiClient client;
AutoConnectConfig Config; AutoConnectConfig Config;
// Config.autoReconnect = true; // Config.autoReconnect = true;
// WiFi.config(Config); // WiFi.config(Config);
MQTTClient mqttClient; // MQTTClient mqttClient;
PubSubClient mqttClient(client);
void connectWiFi() { void connectWiFi() {
Serial.println("Start WiFi..."); Serial.println("Start WiFi...");
@ -33,15 +35,15 @@ void connectWiFi() {
} }
void mqttLoop(void *parameter) { void mqttLoop(void *parameter) {
bool x;
do { do {
x = mqttClient.loop(); mqttClient.loop();
delay(50); delay(50);
} while (mqttClient.connected()); } while (mqttClient.connected());
Serial.println("Disconnected from MQTT.");
if (!mqttClient.connected()) { if (!mqttClient.connected()) {
Serial.println("Disconnected from MQTT."); Serial.println("Checking WiFi Connection.");
if (WiFi.isConnected()) { if (WiFi.isConnected()) {
Serial.println("Starting reconnect timer for MQTT.");
xTimerStart(mqttReconnectTimer, 0); xTimerStart(mqttReconnectTimer, 0);
} }
} }
@ -50,14 +52,15 @@ void mqttLoop(void *parameter) {
void connectMQTT() { void connectMQTT() {
Serial.println("Connecting to MQTT..."); Serial.println("Connecting to MQTT...");
mqttClient.begin(MQTT_HOST, MQTT_PORT, client); // mqttClient.begin(MQTT_HOST, MQTT_PORT, client);
mqttClient.setServer(MQTT_HOST, MQTT_PORT);
mqttClient.connect(MQTT_DEVICE_ID); mqttClient.connect(MQTT_DEVICE_ID);
if (mqttClient.connected()) { if (mqttClient.connected()) {
Serial.println("Connected!"); Serial.println("Connected!");
} else { } else {
Serial.println("NOT Connected!"); Serial.println("NOT Connected!");
} }
mqttClient.subscribe(MQTT_PATH_SUB, 2); mqttClient.subscribe(MQTT_PATH_SUB);
Serial.print("subscribed to: "); Serial.print("subscribed to: ");
Serial.println(MQTT_PATH_SUB); Serial.println(MQTT_PATH_SUB);
xTaskCreate( xTaskCreate(
@ -88,7 +91,8 @@ void WiFiEvent(WiFiEvent_t event) {
} }
} }
void onMqttMessage(MQTTClient *client, char topic[], char payload[], int payload_length) { // void onMqttMessage(MQTTClient *client, char topic[], char payload[], int payload_length) {
void onMqttMessage(char *topic, byte *payload, unsigned int payload_length) {
Serial.print("Message arrived ["); Serial.print("Message arrived [");
Serial.print(topic); Serial.print(topic);
Serial.print("] "); Serial.print("] ");
@ -105,7 +109,8 @@ void onMqttMessage(MQTTClient *client, char topic[], char payload[], int payload
if (strcmp(topic, MQTT_SOIL_PROPERTIES) == 0) { if (strcmp(topic, MQTT_SOIL_PROPERTIES) == 0) {
Serial.println("receiving soil thresholds..."); Serial.println("receiving soil thresholds...");
Serial.println(topic); Serial.println(topic);
Serial.println(payload); //Serial.println(reinterpret_cast<const char *>(payload));
// Serial.println(payload);
// const int capacity = JSON_OBJECT_SIZE(3) + 2 * JSON_OBJECT_SIZE(1); // const int capacity = JSON_OBJECT_SIZE(3) + 2 * JSON_OBJECT_SIZE(1);
StaticJsonDocument<1024> doc; StaticJsonDocument<1024> doc;
DeserializationError err = deserializeJson(doc, payload); DeserializationError err = deserializeJson(doc, payload);
@ -133,11 +138,13 @@ void setupConnections() {
WiFi.onEvent(WiFiEvent); WiFi.onEvent(WiFiEvent);
mqttClient.onMessageAdvanced(onMqttMessage); // mqttClient.onMessageAdvanced(onMqttMessage);
mqttClient.setCallback(onMqttMessage);
connectWiFi(); connectWiFi();
} }
void publishMessage(const char *topic, const char *msg) { void publishMessage(const char *topic, const char *msg) {
mqttClient.publish(topic, msg, true, 1); mqttClient.publish(topic, msg);
// mqttClient.publish(topic, msg, true, 1);
} }

View File

@ -75,3 +75,4 @@ extern void publishMessage(const char *topic, const char *msg);
void readSensors(); void readSensors();
void toggleValve(); void toggleValve();
void setSoilProperties(int FC, int PWP, int SAT); void setSoilProperties(int FC, int PWP, int SAT);
void setupStore();

View File

@ -20,6 +20,7 @@ void setup() {
digitalWrite(PIN_VALVE, LOW); digitalWrite(PIN_VALVE, LOW);
setupStore();
setupConnections(); setupConnections();
setupLightSensor(); setupLightSensor();
setupTemperatureSensor(); setupTemperatureSensor();

View File

@ -1,4 +1,5 @@
#include <header.h> #include <header.h>
#include <ArduinoNvs.h>
#include <string> #include <string>
//using namespace std; //using namespace std;
@ -85,21 +86,60 @@ void toggleValve() {
xTaskCreate( xTaskCreate(
valveTask, /* Task function. */ valveTask, /* Task function. */
"valveTask", /* String with name of task. */ "valveTask", /* String with name of task. */
10000, /* Stack size in bytes. */ 512, /* Stack size in bytes. */
NULL, /* Parameter passed as input of the task */ NULL, /* Parameter passed as input of the task */
1, /* Priority of the task. */ 1, /* Priority of the task. */
NULL); /* Task handle. */ NULL); /* Task handle. */
} }
void persistSoilProps(int FC, int PWP, int SAT) {
Serial.println("persistSoilProps");
bool f = NVS.setInt("fieldCapacity", FC);
bool p = NVS.setInt("permanentWilt", PWP);
bool s = NVS.setInt("soilSaturation", SAT);
if (f && p && s) {
Serial.println("Soil properties sucessfully stored.");
NVS.commit();
}
else {
Serial.println("error occured while trying to persist soil properties");
}
}
void restoreSoilProps() {
Serial.println("restoreSoilProps");
int fc = NVS.getInt("fieldCapacity");
int pwp = NVS.getInt("permanentWilt");
int sat = NVS.getInt("soilSaturation");
if (fc != 0) {
fieldCapacity = fc;
}
if (pwp != 0) {
permanentWiltingPoint = pwp;
}
if (sat != 0) {
soilSaturation = sat;
}
Serial.print(fieldCapacity);
Serial.print(permanentWiltingPoint);
Serial.print(soilSaturation);
}
void setupStore() {
NVS.begin("store");
restoreSoilProps();
}
void setSoilProperties(int FC, int PWP, int SAT) { void setSoilProperties(int FC, int PWP, int SAT) {
fieldCapacity = FC; fieldCapacity = FC;
permanentWiltingPoint = PWP; permanentWiltingPoint = PWP;
soilSaturation = SAT; soilSaturation = SAT;
Serial.print("fieldCapacity: "); persistSoilProps(FC, PWP, SAT);
Serial.print("new fieldCapacity: ");
Serial.println(fieldCapacity); Serial.println(fieldCapacity);
Serial.print("permanentWiltingPoint: "); Serial.print("new permanentWiltingPoint: ");
Serial.println(permanentWiltingPoint); Serial.println(permanentWiltingPoint);
Serial.print("soilSaturation: "); Serial.print("new soilSaturation: ");
Serial.println(soilSaturation); Serial.println(soilSaturation);
// TODO save to nvs nonvolatile flash storage
} }