From d457c6a209acbeb495422479e0a13a605822f309 Mon Sep 17 00:00:00 2001
From: Jonas Leder <jonas@jonasled.de>
Date: Sat, 25 Jan 2025 14:03:39 +0100
Subject: [PATCH] add option to dump raw mqtt data to file

---
 .gitignore         |  3 ++-
 mqttclient/main.go | 18 ++++++++++++++++++
 2 files changed, 20 insertions(+), 1 deletion(-)

diff --git a/.gitignore b/.gitignore
index 998ebd1..0400075 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,2 +1,3 @@
 .env
-boiler.csv
\ No newline at end of file
+boiler.csv
+boiler.txt
\ No newline at end of file
diff --git a/mqttclient/main.go b/mqttclient/main.go
index 575d341..9809680 100644
--- a/mqttclient/main.go
+++ b/mqttclient/main.go
@@ -3,6 +3,7 @@ package mqttclient
 import (
 	"fmt"
 	"os"
+	"strings"
 
 	mqtt "github.com/eclipse/paho.mqtt.golang"
 	"jonasled.dev/jonasled/ems-esp-logger/csv"
@@ -18,6 +19,9 @@ var messagePubHandlerBoiler mqtt.MessageHandler = func(client mqtt.Client, msg m
 	log.Log.Debugf("Received message for boiler: %s from topic: %s\n", msg.Payload(), msg.Topic())
 	log.Log.Info("Received new boiler data")
 	csv.JsonToCsv(string(msg.Payload()))
+	if os.Getenv("OUTPUT_FILE_NAME_RAW") != "" {
+		dumpRawData(string(msg.Payload()), os.Getenv("OUTPUT_FILE_NAME_RAW"))
+	}
 
 }
 
@@ -46,3 +50,17 @@ func Init() {
 	}
 	client.Subscribe(os.Getenv("MQTT_TOPIC_BOILER"), 1, messagePubHandlerBoiler)
 }
+
+func dumpRawData(data string, filename string) {
+	data = strings.ReplaceAll(data, "\n", "")
+	data = strings.ReplaceAll(data, "\r", "")
+
+	file, err := os.OpenFile(filename, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
+	if err != nil {
+		panic(err)
+	}
+	defer file.Close()
+
+	file.WriteString(data)
+	file.WriteString("\n")
+}
-- 
GitLab