#include "ml307_board.h" #include "application.h" #include #include #include #include #include static const char *TAG = "Ml307Board"; static std::string csq_to_string(int csq) { if (csq == -1) { return "No network"; } else if (csq >= 0 && csq <= 9) { return "Very bad"; } else if (csq >= 10 && csq <= 14) { return "Bad"; } else if (csq >= 15 && csq <= 19) { return "Fair"; } else if (csq >= 20 && csq <= 24) { return "Good"; } else if (csq >= 25 && csq <= 31) { return "Very good"; } return "Invalid"; } Ml307Board::Ml307Board(gpio_num_t tx_pin, gpio_num_t rx_pin, size_t rx_buffer_size) : modem_(tx_pin, rx_pin, rx_buffer_size) { } void Ml307Board::StartNetwork() { auto display = Board::GetInstance().GetDisplay(); display->SetText(std::string("Starting modem")); modem_.SetDebug(false); modem_.SetBaudRate(921600); auto& application = Application::GetInstance(); // If low power, the material ready event will be triggered by the modem because of a reset modem_.OnMaterialReady([this, &application]() { ESP_LOGI(TAG, "ML307 material ready"); application.Schedule([this, &application]() { application.SetChatState(kChatStateIdle); WaitForNetworkReady(); }); }); WaitForNetworkReady(); } void Ml307Board::WaitForNetworkReady() { auto& application = Application::GetInstance(); auto display = Board::GetInstance().GetDisplay(); display->SetText(std::string("Wait for network\n")); int result = modem_.WaitForNetworkReady(); if (result == -1) { application.Alert("Error", "PIN is not ready"); return; } else if (result == -2) { application.Alert("Error", "Registration denied"); return; } // Print the ML307 modem information std::string module_name = modem_.GetModuleName(); std::string imei = modem_.GetImei(); std::string iccid = modem_.GetIccid(); ESP_LOGI(TAG, "ML307 Module: %s", module_name.c_str()); ESP_LOGI(TAG, "ML307 IMEI: %s", imei.c_str()); ESP_LOGI(TAG, "ML307 ICCID: %s", iccid.c_str()); } void Ml307Board::Initialize() { ESP_LOGI(TAG, "Initializing Ml307Board"); } Http* Ml307Board::CreateHttp() { return new Ml307Http(modem_); } WebSocket* Ml307Board::CreateWebSocket() { return new WebSocket(new Ml307SslTransport(modem_, 0)); } bool Ml307Board::GetNetworkState(std::string& network_name, int& signal_quality, std::string& signal_quality_text) { if (!modem_.network_ready()) { return false; } network_name = modem_.GetCarrierName(); signal_quality = modem_.GetCsq(); signal_quality_text = csq_to_string(signal_quality); return signal_quality != -1; } std::string Ml307Board::GetBoardJson() { // Set the board type for OTA std::string board_type = BOARD_TYPE; std::string module_name = modem_.GetModuleName(); std::string carrier_name = modem_.GetCarrierName(); std::string imei = modem_.GetImei(); std::string iccid = modem_.GetIccid(); int csq = modem_.GetCsq(); std::string board_json = std::string("{\"type\":\"" + board_type + "\","); board_json += "\"revision\":\"" + module_name + "\","; board_json += "\"carrier\":\"" + carrier_name + "\","; board_json += "\"csq\":\"" + std::to_string(csq) + "\","; board_json += "\"imei\":\"" + imei + "\","; board_json += "\"iccid\":\"" + iccid + "\"}"; return board_json; }