netatmo-exporter/main.go

59 lines
1.4 KiB
Go
Raw Permalink Normal View History

2017-01-08 17:12:34 +00:00
package main
import (
"net/http"
"os"
2020-06-27 16:20:51 +00:00
"time"
2017-01-08 17:12:34 +00:00
netatmo "github.com/exzz/netatmo-api-go"
"github.com/prometheus/client_golang/prometheus"
2018-10-27 15:07:08 +00:00
"github.com/prometheus/client_golang/prometheus/promhttp"
2020-06-21 13:22:19 +00:00
"github.com/sirupsen/logrus"
2020-06-27 15:53:13 +00:00
"github.com/xperimental/netatmo-exporter/internal/collector"
2020-06-27 15:50:36 +00:00
"github.com/xperimental/netatmo-exporter/internal/config"
2020-06-21 13:22:19 +00:00
)
var (
log = &logrus.Logger{
Out: os.Stderr,
Formatter: &logrus.TextFormatter{
DisableTimestamp: true,
},
Level: logrus.InfoLevel,
ExitFunc: os.Exit,
ReportCaller: false,
}
2017-01-08 17:12:34 +00:00
)
func main() {
2020-06-27 15:50:36 +00:00
cfg, err := config.Parse(os.Args, os.Getenv)
2017-01-08 17:12:34 +00:00
if err != nil {
log.Fatalf("Error in configuration: %s", err)
}
2020-06-21 13:39:24 +00:00
log.SetLevel(logrus.Level(cfg.LogLevel))
2017-01-08 17:12:34 +00:00
2020-06-21 13:22:19 +00:00
log.Infof("Login as %s", cfg.Netatmo.Username)
2017-01-08 17:12:34 +00:00
client, err := netatmo.NewClient(cfg.Netatmo)
if err != nil {
log.Fatalf("Error creating client: %s", err)
}
2020-06-27 15:53:13 +00:00
metrics := &collector.NetatmoCollector{
Log: log,
ReadFunction: client.Read,
2020-06-27 15:53:13 +00:00
RefreshInterval: cfg.RefreshInterval,
StaleThreshold: cfg.StaleDuration,
2017-01-08 17:12:34 +00:00
}
prometheus.MustRegister(metrics)
2020-06-27 16:20:51 +00:00
// Trigger first refresh
metrics.RefreshData(time.Now())
2018-10-27 15:07:08 +00:00
http.Handle("/metrics", promhttp.HandlerFor(prometheus.DefaultGatherer, promhttp.HandlerOpts{}))
2020-06-21 13:26:53 +00:00
http.Handle("/version", versionHandler(log))
2017-01-08 17:12:34 +00:00
http.Handle("/", http.RedirectHandler("/metrics", http.StatusFound))
2020-06-21 13:22:19 +00:00
log.Infof("Listen on %s...", cfg.Addr)
2017-01-08 17:12:34 +00:00
log.Fatal(http.ListenAndServe(cfg.Addr, nil))
}