From 45925cc73665aa465233826450c0b2b2930b5479 Mon Sep 17 00:00:00 2001
From: Zoe Pfister <zoe.pfister@student.uibk.ac.at>
Date: Wed, 25 Jan 2023 11:51:28 +0100
Subject: [PATCH] WIP: Rename Timemanager to NTPManager, move modem information
 logging to ConnectionManager

---
 .../NTPException.hpp                          |   0
 .../NTPManager.cpp}                           |  14 +-
 .../TimeManager.h => NTPManager/NTPManager.h} |  10 +-
 .../StringToTimeConversionException.hpp       |   4 +-
 .../ConnectionManager.cpp                     |  25 +++-
 .../ConnectionManager.h                       |   2 +
 host/host_central_mast/src/main.cpp           | 134 ++----------------
 7 files changed, 49 insertions(+), 140 deletions(-)
 rename host/host_central_mast/lib/{TimeManager => NTPManager}/NTPException.hpp (100%)
 rename host/host_central_mast/lib/{TimeManager/TimeManager.cpp => NTPManager/NTPManager.cpp} (85%)
 rename host/host_central_mast/lib/{TimeManager/TimeManager.h => NTPManager/NTPManager.h} (83%)
 rename host/host_central_mast/lib/{TimeManager => NTPManager}/StringToTimeConversionException.hpp (83%)

diff --git a/host/host_central_mast/lib/TimeManager/NTPException.hpp b/host/host_central_mast/lib/NTPManager/NTPException.hpp
similarity index 100%
rename from host/host_central_mast/lib/TimeManager/NTPException.hpp
rename to host/host_central_mast/lib/NTPManager/NTPException.hpp
diff --git a/host/host_central_mast/lib/TimeManager/TimeManager.cpp b/host/host_central_mast/lib/NTPManager/NTPManager.cpp
similarity index 85%
rename from host/host_central_mast/lib/TimeManager/TimeManager.cpp
rename to host/host_central_mast/lib/NTPManager/NTPManager.cpp
index 3509b80..f99ff9e 100644
--- a/host/host_central_mast/lib/TimeManager/TimeManager.cpp
+++ b/host/host_central_mast/lib/NTPManager/NTPManager.cpp
@@ -2,18 +2,18 @@
 // Created by zoe on 12/19/22.
 //
 
-#include "TimeManager.h"
+#include "NTPManager.h"
 
-TimeManager::TimeManager(TinyGsmSim7000 &modem) : modem(modem) {}
+NTPManager::NTPManager(TinyGsmSim7000 &modem) : modem(modem) {}
 
-void TimeManager::syncNTP(const std::string &ntpServer, const std::string &backupNtpServer) {
+void NTPManager::syncNTP(const std::string &ntpServer, const std::string &backupNtpServer) {
     // create list of ntp servers
     std::vector<std::string> ntpServers;
     ntpServers.push_back(ntpServer);
     ntpServers.push_back(backupNtpServer);
     tryNtpServerSync(backupNtpServer, ntpServers);
 }
-void TimeManager::tryNtpServerSync(const std::string &backupNtpServer,
+void NTPManager::tryNtpServerSync(const std::string &backupNtpServer,
                                    std::vector<std::string> &ntpServers) { // try to sync ntp with each server
     for (const auto &server : ntpServers) {
         try {
@@ -29,7 +29,7 @@ void TimeManager::tryNtpServerSync(const std::string &backupNtpServer,
         }
     }
 }
-void TimeManager::synchronizeNTPWithModem(const std::string &ntpServer) {
+void NTPManager::synchronizeNTPWithModem(const std::string &ntpServer) {
     esp_log_write(ESP_LOG_DEBUG, TAG_TIMEMANAGER, "NTP Server Syncing...\n");
 
     long error = modem.NTPServerSync(ntpServer.c_str(), timeZone);
@@ -51,7 +51,7 @@ void TimeManager::synchronizeNTPWithModem(const std::string &ntpServer) {
     }
 }
 
-time_t TimeManager::timeToUnixEpochSeconds(const std::string &time, const std::string &format) {
+time_t NTPManager::timeToUnixEpochSeconds(const std::string &time, const std::string &format) {
     //	22/10/27,10:16:20+00
     struct tm tm {};
     time_t dateInEpoch = 0;
@@ -78,7 +78,7 @@ time_t TimeManager::timeToUnixEpochSeconds(const std::string &time, const std::s
     return dateInEpoch;
 }
 
-void TimeManager::writeModemTimeToRTC() {
+void NTPManager::writeModemTimeToRTC() {
     auto gsmDateTimeString = modem.getGSMDateTime(DATE_FULL);
     esp_log_write(ESP_LOG_DEBUG, TAG_TIMEMANAGER, "GSM DateTime: %s\n", gsmDateTimeString.c_str());
     time_t time = timeToUnixEpochSeconds(gsmDateTimeString.c_str());
diff --git a/host/host_central_mast/lib/TimeManager/TimeManager.h b/host/host_central_mast/lib/NTPManager/NTPManager.h
similarity index 83%
rename from host/host_central_mast/lib/TimeManager/TimeManager.h
rename to host/host_central_mast/lib/NTPManager/NTPManager.h
index a5e5cca..37a2a19 100644
--- a/host/host_central_mast/lib/TimeManager/TimeManager.h
+++ b/host/host_central_mast/lib/NTPManager/NTPManager.h
@@ -2,8 +2,8 @@
 // Created by zoe on 12/19/22.
 //
 
-#ifndef HOST_CENTRAL_MAST_TIMEMANAGER_H
-#define HOST_CENTRAL_MAST_TIMEMANAGER_H
+#ifndef HOST_CENTRAL_MAST_NTPMANAGER_H
+#define HOST_CENTRAL_MAST_NTPMANAGER_H
 
 #define TINY_GSM_MODEM_SIM7000
 
@@ -15,9 +15,9 @@
 #include <iomanip>
 #include <string>
 
-class TimeManager {
+class NTPManager {
   public:
-    explicit TimeManager(TinyGsmSim7000 &modem);
+    explicit NTPManager(TinyGsmSim7000 &modem);
 
   private:
     int timeZone = 0;
@@ -39,4 +39,4 @@ class TimeManager {
     void writeModemTimeToRTC();
 };
 
-#endif // HOST_CENTRAL_MAST_TIMEMANAGER_H
\ No newline at end of file
+#endif // HOST_CENTRAL_MAST_NTPMANAGER_H
\ No newline at end of file
diff --git a/host/host_central_mast/lib/TimeManager/StringToTimeConversionException.hpp b/host/host_central_mast/lib/NTPManager/StringToTimeConversionException.hpp
similarity index 83%
rename from host/host_central_mast/lib/TimeManager/StringToTimeConversionException.hpp
rename to host/host_central_mast/lib/NTPManager/StringToTimeConversionException.hpp
index 32e63f4..f93acc3 100644
--- a/host/host_central_mast/lib/TimeManager/StringToTimeConversionException.hpp
+++ b/host/host_central_mast/lib/NTPManager/StringToTimeConversionException.hpp
@@ -5,16 +5,16 @@
 #ifndef HOST_CENTRAL_MAST_STRINGTOTIMECONVERSIONEXCEPTION_HPP
 #define HOST_CENTRAL_MAST_STRINGTOTIMECONVERSIONEXCEPTION_HPP
 
+#include "NTPManager.h"
 #include <exception>
 #include <string>
-#include "TimeManager.h"
 
 class StringToTimeConversionException : public std::exception {
 public:
     explicit StringToTimeConversionException(const std::string &message) : message(message) {}
 
     const char *what() const noexcept override {
-        esp_log_write(ESP_LOG_ERROR, "TimeManager", "Error converting time to epoch: %s",
+        esp_log_write(ESP_LOG_ERROR, "NTPManager", "Error converting time to epoch: %s",
                       message.c_str());
         return message.c_str();
     }
diff --git a/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.cpp b/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.cpp
index a8424ed..4ad6b4f 100644
--- a/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.cpp
+++ b/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.cpp
@@ -4,7 +4,6 @@
 
 #include "ConnectionManager.h"
 
-
 ConnectionManager::ConnectionManager(TinyGsm &modem, GPRSCredentials credentials, ModemPins modemPins)
     : modem(modem), credentials(std::move(credentials)), modemPins(modemPins) {}
 
@@ -127,6 +126,8 @@ void ConnectionManager::modemPowerOn() {
 }
 
 void ConnectionManager::modemPowerOff() {
+    // Try to power-off (modem may decide to restart automatically)
+    // To turn off modem completely, please use Reset/Enable pins
     modem.sendAT("+CPOWD=1");
     if (modem.waitResponse(10000L) != 1) {
         esp_log_write(ESP_LOG_WARN, TAG_GSM, "Failed to power off modem\n");
@@ -153,3 +154,25 @@ bool ConnectionManager::waitForNetwork() {
 bool ConnectionManager::gprsDisconnect() {
     return modem.gprsDisconnect();
 }
+void ConnectionManager::logModemInformation() {
+    bool res = modem.isGprsConnected();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "GPRS connected: %s\n", res ? "true" : "false");
+
+    String ccid = modem.getSimCCID();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "CCID: %s\n", ccid.c_str());
+
+    String imei = modem.getIMEI();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "IMEI: %s\n", imei.c_str());
+
+    String imsi = modem.getIMSI();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "IMSI: %s\n", imsi.c_str());
+
+    String cop = modem.getOperator();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Operator: %s\n", cop.c_str());
+
+    IPAddress local = modem.localIP();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Local IP: %s\n", local.toString().c_str());
+
+    int csq = modem.getSignalQuality();
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Signal quality: %d\n", csq);
+}
diff --git a/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.h b/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.h
index 9ed10f3..6b0d364 100644
--- a/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.h
+++ b/host/host_central_mast/lib/NetworkConnectionManager/ConnectionManager.h
@@ -67,6 +67,8 @@ class ConnectionManager {
 
     void unlockSimCard();
     bool waitForNetwork();
+
+    void logModemInformation();
 };
 
 #endif // HOST_CENTRAL_MAST_CONNECTIONMANAGER_H
diff --git a/host/host_central_mast/src/main.cpp b/host/host_central_mast/src/main.cpp
index 97ec545..2cdbcfb 100644
--- a/host/host_central_mast/src/main.cpp
+++ b/host/host_central_mast/src/main.cpp
@@ -13,7 +13,7 @@
 #include <ArduinoJson.h>
 #include <Definitions.h>
 #include <ESP32Time.h>
-#include <TimeManager.h>
+#include <NTPManager.h>
 #include <TinyGsmClient.h>
 #include <WiFi.h>
 #include <esp_log.h>
@@ -21,7 +21,6 @@
 #include <queue>
 #include <sys/unistd.h>
 
-// TODO: TimeManager should handle this or rename TimeManager to NTPManager
 ESP32Time rtc;
 
 #define TINY_GSM_RX_BUFFER 1024 // Set RX buffer to 1Kb
@@ -40,7 +39,7 @@ const GPRSCredentials gprsCredentials = GPRSCredentials("m2m.public.at", "", "")
 ConnectionManager connectionManager{modem, gprsCredentials,
                                     ConnectionManager::ModemPins{PIN_DTR, PIN_TX, PIN_RX, PWR_PIN}};
 
-TimeManager timeManager{modem};
+NTPManager ntpManager{modem};
 
 uint8_t BROADCAST_MAC[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
 esp_now_peer_info_t broadcast = {};
@@ -201,17 +200,16 @@ void loop() {
     connectionManager.disableGPS();
 
     try {
+        // may fail if already set
         connectionManager.setNetworkMode(LTE_ONLY);
         connectionManager.setPreferredMode(CAT_M);
     } catch (const std::exception &e) {
         esp_log_write(ESP_LOG_ERROR, TAG_GSM, "Error setting network mode: %s\n", e.what());
     }
 
-    String name = modem.getModemName();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Modem Name: %s\n", name.c_str());
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Modem Name: %s\n", modem.getModemName().c_str());
 
-    String modemInfo = modem.getModemInfo();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Modem Info: %s\n", modemInfo.c_str());
+    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Modem Info: %s\n", modem.getModemInfo().c_str());
 
     connectionManager.unlockSimCard();
 
@@ -232,31 +230,12 @@ void loop() {
         return;
     }
 
-    bool res = modem.isGprsConnected();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "GPRS connected: %s\n", res ? "true" : "false");
+    connectionManager.logModemInformation();
 
-    String ccid = modem.getSimCCID();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "CCID: %s\n", ccid.c_str());
-
-    String imei = modem.getIMEI();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "IMEI: %s\n", imei.c_str());
-
-    String imsi = modem.getIMSI();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "IMSI: %s\n", imsi.c_str());
-
-    String cop = modem.getOperator();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Operator: %s\n", cop.c_str());
-
-    IPAddress local = modem.localIP();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Local IP: %s\n", local.toString().c_str());
-
-    int csq = modem.getSignalQuality();
-    esp_log_write(ESP_LOG_DEBUG, TAG_GSM, "Signal quality: %d\n", csq);
-
-    timeManager.syncNTP("pool.ntp.org", "at.pool.ntp.org");
+    ntpManager.syncNTP("pool.ntp.org", "at.pool.ntp.org");
 
     try {
-        timeManager.writeModemTimeToRTC();
+        ntpManager.writeModemTimeToRTC();
     } catch (const std::exception &e) {
         esp_log_write(ESP_LOG_ERROR, TAG_GSM, "Error writing time to rtc: %s\n", e.what());
     }
@@ -276,100 +255,5 @@ void loop() {
 
     connectionManager.modemPowerOff();
 
-    // put readings into array
-    // protocol address
-    // hardware name != sensor name
-
-    //
-    //    connectionManager.setBand(ConnectionManager::BAND_CAT_M, 20);
-    //
-    //    delay(200);
-    //
-    //    connectionManager.setModemFunctionalityLevel(ModemFunctionalityLevel::FULL);
-    //    delay(200);
-
-    //	modem.disableGPS();
-    //    delay(200);
-    //    esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "%s\n", String(modem.getSignalQuality()).c_str());
-    //
-    //    esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "Trying to connect to network\n");
-    //
-    //    Serial.println("\n\n\nWaiting for network...");
-    //    if (!modem.waitForNetwork()) {
-    //        delay(10000);
-    //        return;
-    //    }
-
-    //    esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "Waiting for network...\n");
-    //    if (!connectionManager.isNetworkConnected()) {
-    //        esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "Network not connected\n");
-    //        return;
-    //    } else {
-    //        esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "Network connected\n");
-    //        delay(200);
-    //        connectionManager.gprsConnect();
-    //        delay(200);
-    //        delay(200);
-    //        syncUTCTimeToRTC();
-    //
-    //        // quality
-    //        esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "%s\n", String(modem.getSignalQuality()).c_str());
-    //        // make a http post request
-    //        String url = "influxdb.qe-forte.uibk.ac.at";
-    //        String path = "/api/v2/write?org=QE&bucket=esp32test&precision=s";
-    //        Serial.print("Connecting to ");
-    //        esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "%s\n", url.c_str());
-    //        // Use WiFiClient class to create TCP connections
-    //
-    //        while (!queue.empty()) {
-    //
-    //            xSemaphoreTake(xMutex, portMAX_DELAY);
-    //            String lineData = queue.front();
-    //            queue.pop();
-    //            xSemaphoreGive(xMutex);
-    //            String method = "POST";
-    //
-    //            RequestInformation requestInformation = RequestInformation(method, url, path, lineData);
-    //
-    //            //"sensorName":"DRS26","timestamp":1666872216,"protocol":"I2C","value":0,"channel":0,"measurementType":"CIRCUMFERENCE_INCREMENT"
-    //
-    //            String request = buildRequest(requestInformation);
-    //            esp_log_write(ESP_LOG_VERBOSE, TAG_MAIN, "request: %s\n", request.c_str());
-    //
-    //            connectionManager.connect(80, requestInformation);
-    //            //            TinyGsmClient client{modem};
-    //            //            const int httpPort = 80;
-    //            //            if (!client.connect(url.c_str(), httpPort)) {
-    //            //                esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "connection failed\n");
-    //            //                return;
-    //            //            }
-    //            //
-    //            //            client.print(request);
-    //            //
-    //            //            // print response
-    //            //            while (client.connected()) {
-    //            //                String line = client.readStringUntil('\n');
-    //            //                if (line == "\r") {
-    //            //                    esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "headers received\n");
-    //            //                    break;
-    //            //                }
-    //            //            }
-    //            //            client.stop();
-    //            delay(1000);
-    //        }
-    //        DBG("Network connected");
-    //    }
-
-#if TINY_GSM_POWERDOWN
-    // Try to power-off (modem may decide to restart automatically)
-    // To turn off modem completely, please use Reset/Enable pins
-    //	modem.sendAT("+CPOWD=1");
-    //	if (modem.waitResponse(10000L) != 1) {
-    //		DBG("+CPOWD=1");
-    //	}
-    //	modem.poweroff();
-    esp_log_write(ESP_LOG_DEBUG, TAG_MAIN, "Poweroff.");
-#endif
-
-    delay(5000);
+    delay(60000);
 }
-- 
GitLab