forked from nidayand/motor-on-roller-blind-ws
-
Notifications
You must be signed in to change notification settings - Fork 10
/
NidayandHelper.cpp
136 lines (112 loc) · 4 KB
/
NidayandHelper.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#include "Arduino.h"
#include "NidayandHelper.h"
NidayandHelper::NidayandHelper() {
this->_configfile = "/config.json";
this->_mqttclientid = ("ESPClient-" + String(ESP.getChipId()));
}
boolean NidayandHelper::loadconfig() {
File configFile = SPIFFS.open(this->_configfile, "r");
if (!configFile) {
Serial.println(F("Failed to open config file"));
return false;
}
size_t size = configFile.size();
if (size > 1024) {
Serial.println(F("Config file size is too large"));
return false;
}
// Allocate a buffer to store contents of the file.
//std::unique_ptr<char[]> buf(new char[size]);
// We don't use String here because ArduinoJson library requires the input
// buffer to be mutable. If you don't use ArduinoJson, you may as well
// use configFile.readString instead.
//configFile.readBytes(buf.get(), size);
//No more memory leaks
DynamicJsonBuffer jsonBuffer(300);
//Reading from buffer breaks first key
//this->_config = jsonBuffer.parseObject(buf.get());
//Reading directly from file DOES NOT cause currentPosition to break
this->_config = jsonBuffer.parseObject(configFile);
//Avoid leaving opened files
configFile.close();
if (!this->_config.success()) {
Serial.println("Failed to parse config file");
return false;
}
return true;
}
JsonVariant NidayandHelper::getconfig() {
return this->_config;
}
boolean NidayandHelper::saveconfig(JsonVariant json) {
File configFile = SPIFFS.open(this->_configfile, "w");
if (!configFile) {
Serial.println("Failed to open config file for writing");
return false;
}
json.printTo(configFile);
configFile.flush(); //Making sure it's saved
Serial.println("Saved JSON to SPIFFS");
json.printTo(Serial);
Serial.println();
return true;
}
String NidayandHelper::mqtt_gettopic(String type) {
return "/raw/esp8266/" + String(ESP.getChipId()) + "/" + type;
}
void NidayandHelper::mqtt_reconnect(PubSubClient& psclient) {
return mqtt_reconnect(psclient, String(NULL), String(NULL));
}
void NidayandHelper::mqtt_reconnect(PubSubClient& psclient, std::list<const char*> topics) {
return mqtt_reconnect(psclient, String(NULL), String(NULL), topics);
}
void NidayandHelper::mqtt_reconnect(PubSubClient& psclient, String uid, String pwd) {
std::list<const char*> mylist;
return mqtt_reconnect(psclient, uid, pwd, mylist);
}
void NidayandHelper::mqtt_reconnect(PubSubClient& psclient, String uid, String pwd, std::list<const char*> topics) {
// Loop until we're reconnected
boolean mqttLogon = false;
if (uid != NULL and pwd != NULL) {
mqttLogon = true;
}
while (!psclient.connected()) {
Serial.print("Attempting MQTT connection...");
// Attempt to connect
if ((mqttLogon ? psclient.connect(this->_mqttclientid.c_str(), uid.c_str(), pwd.c_str()) : psclient.connect(this->_mqttclientid.c_str()))) {
Serial.println("connected");
//Send register MQTT message with JSON of chipid and ip-address
this->mqtt_publish(psclient, "/raw/esp8266/register", "{ \"id\": \"" + String(ESP.getChipId()) + "\", \"ip\":\"" + WiFi.localIP().toString() + "\"}");
//Setup subscription
if (!topics.empty()) {
for (const char* t : topics) {
psclient.subscribe(t);
Serial.println("Subscribed to " + String(t));
}
}
} else {
Serial.print("failed, rc=");
Serial.print(psclient.state());
Serial.println(" try again in 5 seconds");
// Wait 5 seconds before retrying
ESP.wdtFeed();
delay(5000);
}
}
if (psclient.connected()) {
psclient.loop();
}
}
void NidayandHelper::mqtt_publish(PubSubClient& psclient, String topic, String payload) {
Serial.println("Trying to send msg..." + topic + ":" + payload);
//Send status to MQTT bus if connected
if (psclient.connected()) {
psclient.publish(topic.c_str(), payload.c_str());
} else {
Serial.println(F("PubSub client is not connected..."));
}
}
void NidayandHelper::resetsettings(WiFiManager& wifim) {
SPIFFS.format();
wifim.resetSettings();
}