forked from patience4711/ESP32-read-APS-inverters
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathZIGBEE_HEALTH.ino
170 lines (137 loc) · 6.01 KB
/
ZIGBEE_HEALTH.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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
// *************************************************************************
// system healtcheck
//**************************************************************************
void healthCheck() {
if ( MQTT_Client.connected() ) {
char Mqtt_send[26];
strcpy( Mqtt_send, Mqtt_outTopic);
if(Mqtt_send[strlen(Mqtt_send)-1] == '/') {
strcat(Mqtt_send, "heap");
}
// we send an mqtt message about free stack an free heap
// the json to domoticz must be something like {"idx" : 7, "nvalue" : 0,"svalue" : "90;2975.00"}
char toMQTT[50]={0};
sprintf( toMQTT, "{\"idx\":%d,\"nvalue\":0,\"svalue\":\"%ld\"}", domIdx, esp_get_free_heap_size() );
if( diagNose != 0 ) consoleOut("Healtcheck mqtt heap, mess is : " + String(toMQTT) );
MQTT_Client.publish ( Mqtt_send, toMQTT, false);
}
if(!timeRetrieved) getTijd();
// reset the errorcode so that polling errors remain
if(errorCode >= 3000) errorCode -= 3000;
if(errorCode >= 200) errorCode -= 200;
if(errorCode >= 100) errorCode -= 100;
ZigbeePing();
switch(checkCoordinator() ) // send the 2700 command
{
case 0:
zigbeeUp = 1; // all oke
diagNose = 0; // reset diagNose as this costs cpu
break;
case 2:
//zigbeeUp = 0;
//String term = "zb down";
//Update_log("zigbee", "zb down" );
if(diagNose != 0) consoleOut("zb down");
resetCounter += 1;
resetValues(false, false); // reset all values, no mqtt
// try to start the coordinator
Serial.println("hc starting coordinator");
if (coordinator(true) ) zigbeeUp = 1; else zigbeeUp = 0;
}
}
int checkCoordinator() {
// this is basically the 2700 command
// the answer can mean that the coordinator is up, not yet started or no answer
// we evaluate that
// first empty serial2, comming from coordinator this is necessary;
//empty_serial2(); is done in the loop
char ecu_id_reverse[13];
ECU_REVERSE().toCharArray(ecu_id_reverse, 13);
char * tail;
// the response = 67 00, status 1 bt, IEEEAddr 8bt, ShortAddr 2bt, DeviceType 1bt, Device State 1bt
// FE0E 67 00 00 FFFF 80971B01A3D8 0000 0709001
// status = 00 means succes, IEEEAddress= FFFF80971B01A3D8, ShortAdr = 0000, devicetype=07 bits 0 to 2
//Device State 09 started as zigbeecoordinator
if (diagNose !=0) consoleOut("checkZigbeeRadio");
//if(log) Update_Log("zigbee", "checking zb module");
//check the radio, send FE00670067
// when ok the returned string = FE0E670000FFFF + ECU_ID REVERSE + 00000709001
// so we check if we have this
char checkCommand[10]; // we send 2700 to the zb
strncpy(checkCommand, "2700", 5);
char reCeived[254]={0}; // a buffer for the received message
char s_d[100]={0};
// now we do this 3 times
for (int x=1; x<4; x++)
{
sendZB( checkCommand );
s_d[0]='\0';
// now read the answer if there is one
strcpy(reCeived, readZB(s_d));
delayMicroseconds(250);
//if ( waitSerial2Available() ) { readZigbee(); } else { readCounter = 0;} // when nothing available we don't read
//if(diagNose == 1) Serial.println("cc inMessage = " + String(inMessage) + " rc = " + String(readCounter));
// we get this : FE0E670000 FFFF80971B01A3D8 0000 07090011 or
// received : FE0E670000 FFFF80971B01A3D6 0000 0709001F when ok
//check if ecu_id_reverse is in the string, then split it there + 2 bytes
if( strstr(reCeived, ecu_id_reverse) )
{
tail = split(reCeived, ecu_id_reverse + 4);
// the tail should contain 0709
if( strstr(tail, "0709") )
{
if( diagNose != 0 ) consoleOut("found 0709, running oke");
zigbeeUp = 1;
return 0;
}
}
delay(700);
reCeived[0] = '\0';
if( diagNose != 0 ) consoleOut("retrying..");
}
// if we come here 3 attempts failed
return 2;
}
void ZigbeePing() {
// if the ping command failed then we have to restart the coordinator
//Update_Log("zigbee", "check serial loopback");
// these commands already have the length 00 and checksum 20 resp 26
char pingCmd[5]={"2101"}; // ping
char s_d[200] = {0};
if(diagNose !=0 ) consoleOut(F("send zb ping"));
sendZB( pingCmd ); // answer should be FE02 6101 79 07 1C
// if ( waitSerial2Available() ) { readZigbee(); } else { readCounter = 0;} // when nothing available we don't read
// DebugPrintln("inMessage = " + String(inMessage) + " rc = " + String(readCounter));
char reCeived[254]={0};
strcpy(reCeived, readZB(s_d));
if (strstr(reCeived, "FE026101" ) == NULL)
{
if(diagNose != 0) consoleOut(F("no ping answer"));
} else {
if(diagNose != 0) consoleOut(F("ping ok"));
}
// we ignore the answer
}
// *************************************************************************
// hard reset the cc25xx
// *************************************************************************
void ZBhardReset()
{
digitalWrite(ZB_RESET, LOW);
delay(500);
digitalWrite(ZB_RESET, HIGH);
//char term[20] = {"ZBmodule hard reset"} ;
Update_Log("zigbee", "ZB module hard reset");
if(diagNose != 0) consoleOut("ZB module hard reset");
delay(2000); //wait for the cc2530 to reboot
}
// function to
void consoleOut(String toLog) {
if(diagNose == 1 )
{
Serial.println(toLog);
} else {
delay(100); // otherwise the socket cannot keep up
ws.textAll(toLog);
}
}