From a7d9e8107ac9f16575e349503ac5ce1c3a866ec4 Mon Sep 17 00:00:00 2001 From: Eric Severance Date: Wed, 25 Dec 2024 06:33:53 -0800 Subject: [PATCH] More accurately determine if MQTT uses the default server (#5663) * More accurately determine if MQTT uses the default server * Channels::anyMqttEnabled() uses same logic * Remove previous static bool --- src/mesh/Channels.cpp | 2 +- src/mqtt/MQTT.cpp | 10 +++++----- src/mqtt/MQTT.h | 3 +++ 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/mesh/Channels.cpp b/src/mesh/Channels.cpp index 4bdd9e674a..4bc91ce4e6 100644 --- a/src/mesh/Channels.cpp +++ b/src/mesh/Channels.cpp @@ -318,7 +318,7 @@ bool Channels::anyMqttEnabled() { #if USERPREFS_EVENT_MODE // Don't publish messages on the public MQTT broker if we are in event mode - if (strcmp(moduleConfig.mqtt.address, default_mqtt_address) == 0) { + if (mqtt && mqtt.isUsingDefaultServer()) { return false; } #endif diff --git a/src/mqtt/MQTT.cpp b/src/mqtt/MQTT.cpp index ba47e26e3f..a8a3e49eaf 100644 --- a/src/mqtt/MQTT.cpp +++ b/src/mqtt/MQTT.cpp @@ -324,9 +324,10 @@ MQTT::MQTT() : concurrency::OSThread("mqtt"), mqttQueue(MAX_MQTT_QUEUE) moduleConfig.mqtt.map_report_settings.publish_interval_secs, default_map_publish_interval_secs); } + String host = parseHostAndPort(moduleConfig.mqtt.address).first; + isConfiguredForDefaultServer = host.length() == 0 || host == default_mqtt_address; IPAddress ip; - isMqttServerAddressPrivate = - ip.fromString(parseHostAndPort(moduleConfig.mqtt.address).first.c_str()) && isPrivateIpAddress(ip); + isMqttServerAddressPrivate = ip.fromString(host.c_str()) && isPrivateIpAddress(ip); #if HAS_NETWORKING if (!moduleConfig.mqtt.proxy_to_client_enabled) @@ -633,9 +634,8 @@ void MQTT::onSend(const meshtastic_MeshPacket &mp_encrypted, const meshtastic_Me return; } - if (strcmp(moduleConfig.mqtt.address, default_mqtt_address) == 0 && - (mp_decoded.decoded.portnum == meshtastic_PortNum_RANGE_TEST_APP || - mp_decoded.decoded.portnum == meshtastic_PortNum_DETECTION_SENSOR_APP)) { + if (isConfiguredForDefaultServer && (mp_decoded.decoded.portnum == meshtastic_PortNum_RANGE_TEST_APP || + mp_decoded.decoded.portnum == meshtastic_PortNum_DETECTION_SENSOR_APP)) { LOG_DEBUG("MQTT onSend - Ignoring range test or detection sensor message on public mqtt"); return; } diff --git a/src/mqtt/MQTT.h b/src/mqtt/MQTT.h index 81892f6f38..cb1fffcc97 100644 --- a/src/mqtt/MQTT.h +++ b/src/mqtt/MQTT.h @@ -79,6 +79,8 @@ class MQTT : private concurrency::OSThread void start() { setIntervalFromNow(0); }; + bool isUsingDefaultServer() { return isConfiguredForDefaultServer; } + protected: struct QueueEntry { std::string topic; @@ -87,6 +89,7 @@ class MQTT : private concurrency::OSThread PointerQueue mqttQueue; int reconnectCount = 0; + bool isConfiguredForDefaultServer = true; virtual int32_t runOnce() override;