From 841658d8493b5c514428311432eb81005cb55832 Mon Sep 17 00:00:00 2001 From: Pierre-Olivier Mercier Date: Wed, 2 Aug 2023 20:06:15 +0200 Subject: [PATCH] Treat config from environment variables --- config.go | 38 ++++++++++++++++++++++++++++++++++++++ main.go | 2 ++ 2 files changed, 40 insertions(+) create mode 100644 config.go diff --git a/config.go b/config.go new file mode 100644 index 0000000..f9ece2a --- /dev/null +++ b/config.go @@ -0,0 +1,38 @@ +package main + +import ( + "flag" + "fmt" + "os" + "strings" +) + +func parseEnvironmentVariables() (err error) { + for _, line := range os.Environ() { + if strings.HasPrefix(line, "LINKY2INFLUX_") { + err := parseConfigLine(line) + if err != nil { + return fmt.Errorf("error in environment (%q): %w", line, err) + } + } + } + return +} + +func parseConfigLine(line string) (err error) { + fields := strings.SplitN(line, "=", 2) + orig_key := strings.TrimSpace(fields[0]) + value := strings.TrimSpace(fields[1]) + + if len(value) == 0 { + return + } + + key := strings.TrimPrefix(orig_key, "LINKY2INFLUX_") + key = strings.Replace(key, "_", "-", -1) + key = strings.ToLower(key) + + err = flag.Set(key, value) + + return +} diff --git a/main.go b/main.go index 421a06c..46d27ee 100644 --- a/main.go +++ b/main.go @@ -180,6 +180,8 @@ type TICWriter interface { } func main() { + parseEnvironmentVariables() + var legacyMode = flag.Bool("legacy-mode", false, "Assume teleinformation in legacy mode") var pushFrequency = flag.Bool("push-frequency", false, "Also fetch data about the grid frequency") flag.Parse()