From 9165b9ad8280384f44d05cb4887c7ce44c67930c 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..b8ebe04 100644 --- a/main.go +++ b/main.go @@ -184,6 +184,8 @@ func main() { var pushFrequency = flag.Bool("push-frequency", false, "Also fetch data about the grid frequency") flag.Parse() + parseEnvironmentVariables() + if len(flag.Args()) < 1 { log.Println("missing required argument: serial device (eg. /dev/ttyUSB0)") return