Little SIM800L refactor
Signed-off-by: Martin Kolací <martin.kolaci@lmc.eu>
This commit is contained in:
145
evDash.ino
145
evDash.ino
@@ -30,8 +30,6 @@
|
||||
//#define BOARD_TTGO_T4
|
||||
#define BOARD_M5STACK_CORE
|
||||
|
||||
//#define SIM800L_ENABLED
|
||||
|
||||
////////////////////////////////////////////////////////////
|
||||
////////////////////////////////////////////////////////////
|
||||
|
||||
@@ -55,142 +53,11 @@
|
||||
#include "CarKiaDebugObd2.h"
|
||||
#include "CarBmwI3.h"
|
||||
|
||||
#ifdef SIM800L_ENABLED
|
||||
#include <ArduinoJson.h>
|
||||
#include "SIM800L.h"
|
||||
|
||||
SIM800L* sim800l;
|
||||
HardwareSerial SerialGPRS(2);
|
||||
#endif //SIM800L_ENABLED
|
||||
|
||||
// Board, Car, Livedata (params, settings)
|
||||
BoardInterface* board;
|
||||
CarInterface* car;
|
||||
LiveData* liveData;
|
||||
|
||||
/**
|
||||
SIM800L
|
||||
*/
|
||||
#ifdef SIM800L_ENABLED
|
||||
bool sim800lSetup() {
|
||||
Serial.println("Setting SIM800L module");
|
||||
|
||||
SerialGPRS.begin(9600);
|
||||
|
||||
sim800l = new SIM800L((Stream *)&SerialGPRS, SIM800L_RST, 512 , 512);
|
||||
// SIM800L DebugMode:
|
||||
//sim800l = new SIM800L((Stream *)&SerialGPRS, SIM800L_RST, 512 , 512, (Stream *)&Serial);
|
||||
|
||||
bool sim800l_ready = sim800l->isReady();
|
||||
for (uint8_t i = 0; i < 5 && !sim800l_ready; i++) {
|
||||
Serial.println("Problem to initialize SIM800L module, retry in 1 sec");
|
||||
delay(1000);
|
||||
sim800l_ready = sim800l->isReady();
|
||||
}
|
||||
|
||||
if (!sim800l_ready) {
|
||||
Serial.println("Problem to initialize SIM800L module");
|
||||
} else {
|
||||
Serial.println("SIM800L module initialized");
|
||||
|
||||
Serial.print("Setting GPRS APN to: ");
|
||||
Serial.println(liveData->settings.gprsApn);
|
||||
|
||||
bool sim800l_gprs = sim800l->setupGPRS(liveData->settings.gprsApn);
|
||||
for (uint8_t i = 0; i < 5 && !sim800l_gprs; i++) {
|
||||
Serial.println("Problem to set GPRS APN, retry in 1 sec");
|
||||
delay(1000);
|
||||
sim800l_gprs = sim800l->setupGPRS(liveData->settings.gprsApn);
|
||||
}
|
||||
|
||||
if (sim800l_gprs) {
|
||||
liveData->params.sim800l_enabled = true;
|
||||
Serial.println("GPRS APN set OK");
|
||||
} else {
|
||||
Serial.println("Problem to set GPRS APN");
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool sendDataViaGPRS() {
|
||||
Serial.println("Sending data via GPRS");
|
||||
|
||||
if (liveData->params.socPerc < 0) {
|
||||
Serial.println("No valid data, skipping data send");
|
||||
return false;
|
||||
}
|
||||
|
||||
NetworkRegistration network = sim800l->getRegistrationStatus();
|
||||
if (network != REGISTERED_HOME && network != REGISTERED_ROAMING) {
|
||||
Serial.println("SIM800L module not connected to network, skipping data send");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!sim800l->isConnectedGPRS()) {
|
||||
Serial.println("GPRS not connected... Connecting");
|
||||
bool connected = sim800l->connectGPRS();
|
||||
for (uint8_t i = 0; i < 5 && !connected; i++) {
|
||||
Serial.println("Problem to connect GPRS, retry in 1 sec");
|
||||
delay(1000);
|
||||
connected = sim800l->connectGPRS();
|
||||
}
|
||||
if (connected) {
|
||||
Serial.println("GPRS connected!");
|
||||
} else {
|
||||
Serial.println("GPRS not connected! Reseting SIM800L module!");
|
||||
sim800l->reset();
|
||||
sim800lSetup();
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
Serial.println("Start HTTP POST...");
|
||||
|
||||
StaticJsonDocument<512> jsonData;
|
||||
|
||||
jsonData["apikey"] = liveData->settings.remoteApiKey;
|
||||
jsonData["carType"] = liveData->settings.carType;
|
||||
jsonData["socPerc"] = liveData->params.socPerc;
|
||||
jsonData["sohPerc"] = liveData->params.sohPerc;
|
||||
jsonData["batPowerKw"] = liveData->params.batPowerKw;
|
||||
jsonData["batPowerAmp"] = liveData->params.batPowerAmp;
|
||||
jsonData["batVoltage"] = liveData->params.batVoltage;
|
||||
jsonData["auxVoltage"] = liveData->params.auxVoltage;
|
||||
jsonData["auxAmp"] = liveData->params.auxCurrentAmp;
|
||||
jsonData["batMinC"] = liveData->params.batMinC;
|
||||
jsonData["batMaxC"] = liveData->params.batMaxC;
|
||||
jsonData["batInletC"] = liveData->params.batInletC;
|
||||
jsonData["batFanStatus"] = liveData->params.batFanStatus;
|
||||
jsonData["speedKmh"] = liveData->params.speedKmh;
|
||||
jsonData["odoKm"] = liveData->params.odoKm;
|
||||
jsonData["cumulativeEnergyChargedKWh"] = liveData->params.cumulativeEnergyChargedKWh;
|
||||
jsonData["cumulativeEnergyDischargedKWh"] = liveData->params.cumulativeEnergyDischargedKWh;
|
||||
|
||||
char payload[512];
|
||||
serializeJson(jsonData, payload);
|
||||
|
||||
Serial.print("Sending payload: ");
|
||||
Serial.println(payload);
|
||||
|
||||
Serial.print("Remote API server: ");
|
||||
Serial.println(liveData->settings.remoteApiUrl);
|
||||
|
||||
uint16_t rc = sim800l->doPost(liveData->settings.remoteApiUrl, "application/json", payload, 10000, 10000);
|
||||
if (rc == 200) {
|
||||
Serial.println("HTTP POST successful");
|
||||
} else {
|
||||
// Failed...
|
||||
Serial.print("HTTP POST error: ");
|
||||
Serial.println(rc);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
#endif //SIM800L_ENABLED
|
||||
|
||||
/**
|
||||
Setup device
|
||||
*/
|
||||
@@ -247,10 +114,6 @@ void setup(void) {
|
||||
// Redraw screen
|
||||
board->redrawScreen();
|
||||
|
||||
#ifdef SIM800L_ENABLED
|
||||
sim800lSetup();
|
||||
#endif //SIM800L_ENABLED
|
||||
|
||||
// Finish board setup
|
||||
board->afterSetup();
|
||||
|
||||
@@ -262,13 +125,5 @@ void setup(void) {
|
||||
Main loop
|
||||
*/
|
||||
void loop() {
|
||||
|
||||
#ifdef SIM800L_ENABLED
|
||||
if (liveData->params.lastDataSent + SIM800L_TIMER < liveData->params.currentTime && liveData->params.sim800l_enabled) {
|
||||
sendDataViaGPRS();
|
||||
liveData->params.lastDataSent = liveData->params.currentTime;
|
||||
}
|
||||
#endif // SIM800L_ENABLED
|
||||
|
||||
board->mainLoop();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user