2019-12-24 11:53:26 +03:00
//===============================================ИНИЦИАЛИЗАЦИЯ================================================
void MQTT_init ( ) {
2020-03-22 01:50:31 +01:00
ts . add ( WIFI_MQTT_CONNECTION_CHECK , wifi_mqtt_reconnecting , [ & ] ( void * ) {
up_time ( ) ;
if ( WiFi . status ( ) = = WL_CONNECTED ) {
Serial . println ( " [V] WiFi-ok " ) ;
if ( client . connected ( ) ) {
Serial . println ( " [V] MQTT-ok " ) ;
} else {
MQTT_Connecting ( ) ;
if ( ! just_load ) mqtt_lost_error + + ;
}
} else {
Serial . println ( " [E] Lost WiFi connection " ) ;
wifi_lost_error + + ;
ts . remove ( WIFI_MQTT_CONNECTION_CHECK ) ;
StartAPMode ( ) ;
}
} , nullptr , true ) ;
2019-12-24 11:53:26 +03:00
2020-03-22 01:50:31 +01:00
server . on ( " /mqttSave " , HTTP_GET , [ ] ( AsyncWebServerRequest * request ) {
2019-12-24 11:53:26 +03:00
if ( request - > hasArg ( " mqttServer " ) ) {
2020-03-27 15:48:17 +01:00
jsonWriteStr ( configSetup , " mqttServer " , request - > getParam ( " mqttServer " ) - > value ( ) ) ;
2019-12-24 11:53:26 +03:00
}
if ( request - > hasArg ( " mqttPort " ) ) {
2020-02-22 03:34:44 +03:00
int port = ( request - > getParam ( " mqttPort " ) - > value ( ) ) . toInt ( ) ;
2020-03-27 15:48:17 +01:00
jsonWriteInt ( configSetup , " mqttPort " , port ) ;
2019-12-24 11:53:26 +03:00
}
2020-03-21 18:14:38 +01:00
if ( request - > hasArg ( " mqttPrefix " ) ) {
2020-03-27 15:48:17 +01:00
jsonWriteStr ( configSetup , " mqttPrefix " , request - > getParam ( " mqttPrefix " ) - > value ( ) ) ;
2020-03-21 18:14:38 +01:00
}
2019-12-24 11:53:26 +03:00
if ( request - > hasArg ( " mqttUser " ) ) {
2020-03-27 15:48:17 +01:00
jsonWriteStr ( configSetup , " mqttUser " , request - > getParam ( " mqttUser " ) - > value ( ) ) ;
2019-12-24 11:53:26 +03:00
}
if ( request - > hasArg ( " mqttPass " ) ) {
2020-03-27 15:48:17 +01:00
jsonWriteStr ( configSetup , " mqttPass " , request - > getParam ( " mqttPass " ) - > value ( ) ) ;
2019-12-24 11:53:26 +03:00
}
saveConfig ( ) ;
2020-03-22 22:41:52 +01:00
start_connecting_to_mqtt = true ;
2020-03-24 19:01:11 +01:00
2020-03-22 01:50:31 +01:00
request - > send ( 200 , " text/text " , " ok " ) ;
} ) ;
2019-12-24 11:53:26 +03:00
2020-03-22 01:50:31 +01:00
server . on ( " /mqttCheck " , HTTP_GET , [ ] ( AsyncWebServerRequest * request ) {
2019-12-24 11:53:26 +03:00
String tmp = " {} " ;
2020-03-27 15:48:17 +01:00
jsonWriteStr ( tmp , " title " , " <button class= \" close \" onclick= \" toggle('my-block') \" >× </button> " + stateMQTT ( ) ) ;
jsonWriteStr ( tmp , " class " , " pop-up " ) ;
2020-03-18 09:57:46 +01:00
request - > send ( 200 , " text/text " , tmp ) ;
2019-12-24 11:53:26 +03:00
} ) ;
2020-03-22 01:50:31 +01:00
}
2019-12-24 11:53:26 +03:00
2020-03-22 01:50:31 +01:00
void handle_connection ( ) {
2020-03-22 22:41:52 +01:00
if ( start_connecting_to_mqtt ) {
start_connecting_to_mqtt = false ;
2020-03-22 01:50:31 +01:00
client . disconnect ( ) ;
MQTT_Connecting ( ) ;
}
2019-12-24 11:53:26 +03:00
}
//================================================ОБНОВЛЕНИЕ====================================================
void handleMQTT ( ) {
if ( WiFi . status ( ) = = WL_CONNECTED ) {
if ( client . connected ( ) ) {
client . loop ( ) ;
}
}
}
//===============================================ПОДКЛЮЧЕНИЕ========================================================
2020-02-22 03:34:44 +03:00
boolean MQTT_Connecting ( ) {
2019-12-24 11:53:26 +03:00
String mqtt_server = jsonRead ( configSetup , " mqttServer " ) ;
if ( ( mqtt_server ! = " " ) ) {
2020-03-22 01:50:31 +01:00
Serial . println ( " [E] Lost MQTT connection, start reconnecting " ) ;
2019-12-24 11:53:26 +03:00
//ssl//espClient.setCACert(local_root_ca1);
client . setServer ( mqtt_server . c_str ( ) , jsonReadtoInt ( configSetup , " mqttPort " ) ) ;
if ( WiFi . status ( ) = = WL_CONNECTED ) {
if ( ! client . connected ( ) ) {
Serial . println ( " [V] Connecting to MQTT server commenced " ) ;
if ( client . connect ( chipID . c_str ( ) , jsonRead ( configSetup , " mqttUser " ) . c_str ( ) , jsonRead ( configSetup , " mqttPass " ) . c_str ( ) ) ) {
Serial . println ( " [V] MQTT connected " ) ;
client . setCallback ( callback ) ;
2020-03-21 18:14:38 +01:00
client . subscribe ( jsonRead ( configSetup , " mqttPrefix " ) . c_str ( ) ) ; // Для приема получения HELLOW и подтверждения связи
client . subscribe ( ( jsonRead ( configSetup , " mqttPrefix " ) + " / " + chipID + " /+/control " ) . c_str ( ) ) ; // Подписываемся на топики control
client . subscribe ( ( jsonRead ( configSetup , " mqttPrefix " ) + " / " + chipID + " /order " ) . c_str ( ) ) ; // Подписываемся на топики order
2019-12-24 11:53:26 +03:00
Serial . println ( " [V] Callback set, subscribe done " ) ;
2020-02-22 03:34:44 +03:00
return true ;
2019-12-24 11:53:26 +03:00
} else {
Serial . println ( " [E] try again in " + String ( wifi_mqtt_reconnecting / 1000 ) + " sec " ) ;
2020-02-22 03:34:44 +03:00
return false ;
2019-12-24 11:53:26 +03:00
}
}
}
} else {
Serial . println ( " [E] No date for MQTT connection " ) ;
2020-02-22 03:34:44 +03:00
return false ;
2019-12-24 11:53:26 +03:00
}
}
//=====================================================ВХОДЯЩИЕ ДАННЫЕ========================================================
void callback ( char * topic , byte * payload , unsigned int length ) {
Serial . print ( " [MQTT] " ) ;
Serial . print ( topic ) ;
String topic_str = String ( topic ) ;
String str ;
for ( int i = 0 ; i < length ; i + + ) {
str + = ( char ) payload [ i ] ;
}
Serial . println ( " => " + str ) ;
2020-02-22 03:34:44 +03:00
if ( str = = " HELLO " ) outcoming_date ( ) ; //превращает название топика в команду, а значение в параметр команды
2019-12-24 11:53:26 +03:00
2020-02-22 03:34:44 +03:00
if ( topic_str . indexOf ( " control " ) > 0 ) { //IoTmanager/800324-1458415/RelaySet1/control 1
2019-12-24 11:53:26 +03:00
//Serial.println(topic_str);
String topic = selectFromMarkerToMarker ( topic_str , " / " , 3 ) ; //RelaySet1
String number = selectToMarkerLast ( topic , " Set " ) ; //1
topic . replace ( number , " " ) ; //RelaySet
String final_line = topic + " " + number + " " + str ; //RelaySet 1 1
//Serial.println(final_line);
order_loop + = final_line + " , " ;
}
if ( topic_str . indexOf ( " order " ) > 0 ) {
str . replace ( " _ " , " " ) ;
//Serial.println(str);
order_loop + = str + " , " ;
}
}
//данные которые отправляем при подключении или отбновлении страницы
void outcoming_date ( ) {
sendAllWigets ( ) ;
sendAllData ( ) ;
2020-03-27 15:48:17 +01:00
choose_log_date_and_send ( ) ;
2019-12-24 11:53:26 +03:00
Serial . println ( " [V] Sending all date to iot manager completed " ) ;
}
2020-03-27 15:48:17 +01:00
2019-12-24 11:53:26 +03:00
//======================================CONFIG==================================================
boolean sendMQTT ( String end_of_topik , String data ) {
2020-03-21 18:14:38 +01:00
String topik = jsonRead ( configSetup , " mqttPrefix " ) + " / " + chipID + " / " + end_of_topik ;
2019-12-24 11:53:26 +03:00
boolean send_status = client . beginPublish ( topik . c_str ( ) , data . length ( ) , false ) ;
client . print ( data ) ;
client . endPublish ( ) ;
return send_status ;
}
2020-03-24 19:01:11 +01:00
boolean sendCHART ( String topik , String data ) {
topik = jsonRead ( configSetup , " mqttPrefix " ) + " / " + chipID + " / " + topik + " / " + " status " ;
boolean send_status = client . beginPublish ( topik . c_str ( ) , data . length ( ) , false ) ;
client . print ( data ) ;
client . endPublish ( ) ;
return send_status ;
}
2019-12-24 11:53:26 +03:00
//======================================STATUS==================================================
void sendSTATUS ( String topik , String state ) {
2020-03-21 18:14:38 +01:00
topik = jsonRead ( configSetup , " mqttPrefix " ) + " / " + chipID + " / " + topik + " / " + " status " ;
2019-12-24 11:53:26 +03:00
String json_ = " {} " ;
2020-03-27 15:48:17 +01:00
jsonWriteStr ( json_ , " status " , state ) ;
2019-12-24 11:53:26 +03:00
int send_status = client . publish ( topik . c_str ( ) , json_ . c_str ( ) , false ) ;
}
//======================================CONTROL==================================================
void sendCONTROL ( String id , String topik , String state ) {
2020-03-21 18:14:38 +01:00
String all_line = jsonRead ( configSetup , " mqttPrefix " ) + " / " + id + " / " + topik + " /control " ;
2019-12-24 11:53:26 +03:00
int send_status = client . publish ( all_line . c_str ( ) , state . c_str ( ) , false ) ;
}
//=====================================================ОТПРАВЛЯЕМ ВИДЖЕТЫ========================================================
void sendAllWigets ( ) {
2020-03-27 15:48:17 +01:00
# ifndef layout_in_rom
all_widgets = readFile ( " layout.txt " , 5000 ) ;
# endif
2020-03-24 19:01:11 +01:00
if ( all_widgets ! = " " ) {
2019-12-24 11:53:26 +03:00
int counter = 0 ;
String line ;
int psn_1 = 0 ;
int psn_2 ;
do {
2020-03-27 15:48:17 +01:00
psn_2 = all_widgets . indexOf ( " \r \n " , psn_1 ) ; //\r\n
2020-03-24 19:01:11 +01:00
line = all_widgets . substring ( psn_1 , psn_2 ) ;
2020-02-08 02:45:35 +03:00
line . replace ( " \n " , " " ) ;
2020-01-12 00:35:15 +03:00
line . replace ( " \r \n " , " " ) ;
2020-03-27 15:48:17 +01:00
//jsonWriteStr(line, "id", String(counter));
//jsonWriteStr(line, "pageId", String(counter));
2019-12-24 11:53:26 +03:00
counter + + ;
2020-02-22 03:34:44 +03:00
sendMQTT ( " config " , line ) ;
2019-12-24 11:53:26 +03:00
Serial . println ( " [V] " + line ) ;
psn_1 = psn_2 + 1 ;
2020-03-24 19:01:11 +01:00
} while ( psn_2 + 2 < all_widgets . length ( ) ) ;
getMemoryLoad ( " [i] after send all widgets " ) ;
2020-03-27 15:48:17 +01:00
# ifndef layout_in_rom
all_widgets = " " ;
# endif
2019-12-24 11:53:26 +03:00
}
}
2020-03-27 15:48:17 +01:00
/*
void sendAllWigets2 ( ) {
File configFile = SPIFFS . open ( " /layout.txt " , " r " ) ;
if ( ! configFile ) {
return ;
}
// while (str.length() != 0) {
// configFile.readStringUntil("\r\n");
// }
} */
2019-12-24 11:53:26 +03:00
//=====================================================ОТПРАВЛЯЕМ ДАННЫЕ В ВИДЖЕТЫ ПРИ ОБНОВЛЕНИИ СТРАНИЦЫ========================================================
void sendAllData ( ) { //берет строку json и ключи превращает в топики а значения колючей в них посылает
String current_config = configJson ; //{"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1"}
getMemoryLoad ( " [i] after send all date " ) ;
current_config . replace ( " { " , " " ) ;
current_config . replace ( " } " , " " ) ; //"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1"
current_config + = " , " ; //"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1",
while ( current_config . length ( ) ! = 0 ) {
String tmp = selectToMarker ( current_config , " , " ) ;
2020-02-22 03:34:44 +03:00
String topic = selectToMarker ( tmp , " : " ) ;
2020-02-13 21:18:51 +03:00
topic . replace ( " \" " , " " ) ;
String state = selectToMarkerLast ( tmp , " : " ) ;
2019-12-24 11:53:26 +03:00
state . replace ( " \" " , " " ) ;
if ( topic ! = ssdpS & & topic ! = " lang " & & topic ! = " ip " & & topic . indexOf ( " _in " ) < 0 ) {
sendSTATUS ( topic , state ) ;
//Serial.println("-->" + topic + " " + state);
}
current_config = deleteBeforeDelimiter ( current_config , " , " ) ;
}
}
String stateMQTT ( ) {
2020-02-22 03:34:44 +03:00
2019-12-24 11:53:26 +03:00
int state = client . state ( ) ;
switch ( state ) {
case - 4 : return " the server didn't respond within the keepalive time " ;
break ;
case - 3 : return " the network connection was broken " ;
break ;
case - 2 : return " the network connection failed " ;
break ;
case - 1 : return " the client is disconnected cleanly " ;
break ;
case 0 : return " the client is connected " ;
break ;
case 1 : return " the server doesn't support the requested version of MQTT " ;
break ;
case 2 : return " the server rejected the client identifier " ;
break ;
case 3 : return " the server was unable to accept the connection " ;
break ;
case 4 : return " the username/password were rejected " ;
break ;
case 5 : return " the client was not authorized to connect " ;
break ;
}
}
/*void scenario_devices_topiks_subscribe() {
//SCENARIO ANALOG > 5 800324-1458415 rel1 0
if ( jsonRead ( configSetup , " scenario " ) = = " 1 " ) {
2020-02-10 23:30:40 +03:00
//String all_text = readFile("firmware.scenario.txt", 1024) + "\r\n";
2019-12-24 11:53:26 +03:00
String all_text = scenario + " \r \n " ;
all_text . replace ( " \r \n " , " \n " ) ;
all_text . replace ( " \r " , " \n " ) ;
while ( all_text . length ( ) ! = 0 ) {
String line_ = selectToMarker ( all_text , " \n " ) ;
String id = selectFromMarkerToMarker ( line_ , " " , 4 ) ;
if ( id ! = " not found " ) {
2020-03-21 18:14:38 +01:00
client . subscribe ( ( jsonRead ( configSetup , " mqttPrefix " ) + " / " + id + " /+/status " ) . c_str ( ) , 0 ) ;
2019-12-24 11:53:26 +03:00
Serial . println ( " subscribed to device, id: " + id ) ;
}
all_text = deleteBeforeDelimiter ( all_text , " \n " ) ;
}
}
}
*/
/*void scenario_devices_test_msg_send() {
if ( jsonRead ( configSetup , " scenario " ) = = " 1 " ) {
String all_text = scenario + " \r \n " ;
all_text . replace ( " \r \n " , " \n " ) ;
all_text . replace ( " \r " , " \n " ) ;
while ( all_text . length ( ) ! = 0 ) {
String line_ = selectToMarker ( all_text , " \n " ) ;
String id = selectFromMarkerToMarker ( line_ , " " , 4 ) ;
if ( id ! = " not found " ) {
//Serial.println();
2020-03-21 18:14:38 +01:00
Serial . println ( client . publish ( ( jsonRead ( configSetup , " mqttPrefix " ) + " / " + id ) . c_str ( ) , " CHECK " , true ) ) ;
2019-12-24 11:53:26 +03:00
}
all_text = deleteBeforeDelimiter ( all_text , " \n " ) ;
}
}
} */
/*
//-----------------------------------------------------------------------------------------------------------------------------------------------
2020-03-27 15:48:17 +01:00
//jsonWriteStr(tmp, "status", "1");
2019-12-24 11:53:26 +03:00
String current_config = configJson ; //{"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1"}
current_config . replace ( " { " , " " ) ;
current_config . replace ( " } " , " " ) ; //"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1"
current_config + = " , " ; //"SSDP":"MODULES","lang":"","ip":"192.168.43.60","DS":"34.00","rel1":"1","rel2":"1",
while ( current_config . length ( ) ! = 0 ) {
String tmp = selectToMarker ( current_config , " , " ) ; //"rel1":"1"
String topic = selectToMarker ( tmp , " : " ) ; //"rel1"
topic . replace ( " \" " , " " ) ; //rel1
Serial . println ( topic ) ;
String state = selectToMarkerLast ( tmp , " : " ) ; //"1"
state . replace ( " \" " , " " ) ; //1
2020-03-24 19:01:11 +01:00
//if (widget.lastIndexOf(topic) > 0) {
2020-03-27 15:48:17 +01:00
jsonWriteStr ( tmp , " status " , state ) ;
2019-12-24 11:53:26 +03:00
//}
current_config = deleteBeforeDelimiter ( current_config , " , " ) ;
}
//-------------------------------------------------------------------------------------------------------------------------------------------------
*/