forked from rvdbreemen/OTGW-firmware
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandleDebug.ino
116 lines (114 loc) · 4.67 KB
/
handleDebug.ino
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
void handleDebug(){
if (TelnetStream.available()>0){
//read the next
char c;
c = TelnetStream.read();
switch (c){
case 'h':
Debugln();
Debugln(F("---===[ Debug Help Menu ]===---"));
Debugf(PSTR("1) Toggle debuglog - OT message parsing: %s\r\n"), CBOOLEAN(bDebugOTmsg));
Debugf(PSTR("2) Toggle debuglog - API handeling: %s\r\n"), CBOOLEAN(bDebugRestAPI));
Debugf(PSTR("3) Toggle debuglog - MQTT module: %s\r\n"), CBOOLEAN(bDebugMQTT));
Debugf(PSTR("4) Toggle debuglog - Sensor modules: %s\r\n"), CBOOLEAN(bDebugSensors));
Debugln(F("q) Force read settings"));
Debugln(F("m) Force MQTT discovery"));
Debugln(F("r) Reconnect wifi, telnet, otgwstream and mqtt"));
Debugln(F("p) Reset PIC manually"));
Debugln(F("a) Send PR=A command to ID PIC firmware version and type"));
Debugln();
break;
case 'p':
DebugTln(F("Manual reset PIC"));
detectPIC();
break;
case 'a':
DebugTln(F("Send PR=A command, to ID the chip"));
getpicfwversion();
DebugTln("Debug --> PR=A report firmware version, type");
sPICfwversion = String(OTGWSerial.firmwareVersion());
OTGWDebugTf(PSTR("Current firmware version: %s\r\n"), CSTR(sPICfwversion));
sPICdeviceid = OTGWSerial.processorToString();
OTGWDebugTf(PSTR("Current device id: %s\r\n"), CSTR(sPICdeviceid));
sPICtype = OTGWSerial.firmwareToString();
OTGWDebugTf(PSTR("Current firmware type: %s\r\n"), CSTR(sPICtype));
break;
case 'q':
DebugTln(F("Read settings"));
readSettings(true);
break;
case 'm':
DebugTln(F("Configure MQTT Discovery"));
DebugTf(PSTR("Enable MQTT: %s\r\n"), CBOOLEAN(settingMQTTenable));
doAutoConfigure();
break;
case 'r':
if (WiFi.status() != WL_CONNECTED)
{
DebugTln(F("Reconnecting to wifi"));
startWiFi(CSTR(settingHostname), 240);
//check OTGW and telnet
startTelnet();
startOTGWstream();
} else DebugTln(F("Wifi is connected"));
if (!statusMQTTconnection) {
DebugTln(F("Reconnecting MQTT"));
startMQTT();
} else DebugTln(F("MQTT is connected"));
break;
case '1':
bDebugOTmsg = !bDebugOTmsg;
DebugTf(PSTR("\r\nDebug OTmsg: %s\r\n"), CBOOLEAN(bDebugOTmsg));
break;
case '2':
bDebugRestAPI = !bDebugRestAPI;
DebugTf(PSTR("\r\nDebug RestAPI: %s\r\n"), CBOOLEAN(bDebugRestAPI));
break;
case '3':
bDebugMQTT = !bDebugMQTT;
DebugTf(PSTR("\r\nDebug MQTT: %s\r\n"), CBOOLEAN(bDebugMQTT));
break;
case '4':
bDebugSensors = !bDebugSensors;
DebugTf(PSTR("\r\nDebug Sensors: %s\r\n"), CBOOLEAN(bDebugSensors));
break;
case 'b':
DebugTln(F("Blink led 1"));
blinkLED(LED1, 5, 500);
break;
case 'i':
DebugTln(F("relay init"));
initOutputs();
break;
case 'u':
DebugTln(F("gpio output on "));
digitalWrite(settingGPIOOUTPUTSpin, ON);
break;
case 'j':
DebugTf(PSTR("read gpio output state (0== led ON): %d \r\n"), digitalRead(settingGPIOOUTPUTSpin));
break;
case 'k':
DebugTln(F("read settings"));
readSettings(true);
break;
case 'o':
DebugTln("gpio output off");
digitalWrite(settingGPIOOUTPUTSpin, OFF);
break;
case 'l':
DebugTln("MyDEBUG =true");
settingMyDEBUG = true;
break;
case 'f':
if(settingMyDEBUG)
{
DebugTln(F("MyDEBUG = true"));
}else{
DebugTln(F("MyDEBUG = false"));
}
break;
default:
break;
}
}
}