#include "ml307_board.h" #include "application.h" #include "display.h" #include "font_awesome_symbols.h" #include #include #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->SetStatus("初始化模块"); 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->SetStatus("等待网络..."); 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()); // Close all previous connections modem_.ResetConnections(); } Http* Ml307Board::CreateHttp() { return new Ml307Http(modem_); } WebSocket* Ml307Board::CreateWebSocket() { return new WebSocket(new Ml307SslTransport(modem_, 0)); } Mqtt* Ml307Board::CreateMqtt() { return new Ml307Mqtt(modem_, 0); } Udp* Ml307Board::CreateUdp() { return new Ml307Udp(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; } const char* Ml307Board::GetNetworkStateIcon() { if (!modem_.network_ready()) { return FONT_AWESOME_SIGNAL_OFF; } int csq = modem_.GetCsq(); if (csq == -1) { return FONT_AWESOME_SIGNAL_OFF; } else if (csq >= 0 && csq <= 9) { return FONT_AWESOME_SIGNAL_1; } else if (csq >= 10 && csq <= 14) { return FONT_AWESOME_SIGNAL_2; } else if (csq >= 15 && csq <= 19) { return FONT_AWESOME_SIGNAL_3; } else if (csq >= 20 && csq <= 24) { return FONT_AWESOME_SIGNAL_4; } else if (csq >= 25 && csq <= 31) { return FONT_AWESOME_SIGNAL_FULL; } ESP_LOGW(TAG, "Invalid CSQ: %d", csq); return FONT_AWESOME_SIGNAL_OFF; } std::string Ml307Board::GetBoardJson() { // Set the board type for OTA std::string board_type = BOARD_TYPE; std::string board_json = std::string("{\"type\":\"" + board_type + "\","); board_json += "\"revision\":\"" + modem_.GetModuleName() + "\","; board_json += "\"carrier\":\"" + modem_.GetCarrierName() + "\","; board_json += "\"csq\":\"" + std::to_string(modem_.GetCsq()) + "\","; board_json += "\"imei\":\"" + modem_.GetImei() + "\","; board_json += "\"iccid\":\"" + modem_.GetIccid() + "\"}"; return board_json; } void Ml307Board::SetPowerSaveMode(bool enabled) { // TODO: Implement power save mode for ML307 }