package main import ( "fmt" "log" "net/http" "os" "os/signal" "syscall" "github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus/promhttp" "gitlab.com/hectorjsmith/fail2ban-prometheus-exporter/cfg" "gitlab.com/hectorjsmith/fail2ban-prometheus-exporter/collector/f2b" "gitlab.com/hectorjsmith/fail2ban-prometheus-exporter/collector/textfile" "gitlab.com/hectorjsmith/fail2ban-prometheus-exporter/server" ) const ( metricsPath = "/metrics" ) var ( version = "dev" commit = "none" date = "unknown" builtBy = "unknown" ) func printAppVersion() { fmt.Println(version) fmt.Printf(" build date: %s\r\n commit hash: %s\r\n built by: %s\r\n", date, commit, builtBy) } func rootHtmlHandler(w http.ResponseWriter, r *http.Request) { _, err := w.Write([]byte( ` Fail2Ban Exporter

Fail2Ban Exporter

Metrics

`)) if err != nil { log.Printf("error handling root url: %v", err) w.WriteHeader(http.StatusInternalServerError) } } func metricHandler(w http.ResponseWriter, r *http.Request, collector *textfile.Collector) { promhttp.Handler().ServeHTTP(w, r) collector.WriteTextFileMetrics(w, r) } func main() { appSettings := cfg.Parse() if appSettings.VersionMode { printAppVersion() } else { handleGracefulShutdown() log.Printf("fail2ban exporter version %s", version) log.Printf("starting server at %s", appSettings.MetricsAddress) f2bCollector := f2b.NewExporter(appSettings, version) prometheus.MustRegister(f2bCollector) textFileCollector := textfile.NewCollector(appSettings) prometheus.MustRegister(textFileCollector) http.HandleFunc("/", server.BasicAuthMiddleware(rootHtmlHandler, appSettings.AuthProvider)) http.HandleFunc(metricsPath, server.BasicAuthMiddleware( func(w http.ResponseWriter, r *http.Request) { metricHandler(w, r, textFileCollector) }, appSettings.AuthProvider, )) log.Printf("metrics available at '%s'", metricsPath) svrErr := make(chan error) go func() { svrErr <- http.ListenAndServe(appSettings.MetricsAddress, nil) }() log.Print("ready") err := <-svrErr log.Fatal(err) } } func handleGracefulShutdown() { var signals = make(chan os.Signal) signal.Notify(signals, syscall.SIGTERM) signal.Notify(signals, syscall.SIGINT) go func() { sig := <-signals log.Printf("caught signal: %+v", sig) os.Exit(0) }() }