gatus/main.go

59 lines
1.6 KiB
Go
Raw Normal View History

2019-09-05 01:37:13 +02:00
package main
import (
"encoding/json"
2019-11-16 21:48:37 +01:00
"github.com/TwinProduction/gatus/config"
2019-10-06 04:20:36 +02:00
"github.com/TwinProduction/gatus/watchdog"
2019-11-16 21:48:37 +01:00
"github.com/prometheus/client_golang/prometheus/promhttp"
"log"
"net/http"
"os"
2019-09-05 01:37:13 +02:00
)
func main() {
cfg := loadConfiguration()
http.HandleFunc("/api/v1/results", serviceResultsHandler)
http.HandleFunc("/health", healthHandler)
2019-09-12 22:15:42 +02:00
http.Handle("/", http.FileServer(http.Dir("./static")))
if cfg.Metrics {
2019-11-16 21:48:37 +01:00
http.Handle("/metrics", promhttp.Handler())
}
2019-10-06 04:20:36 +02:00
log.Println("[main][main] Listening on port 8080")
go watchdog.Monitor(cfg)
2019-10-06 04:20:36 +02:00
log.Fatal(http.ListenAndServe(":8080", nil))
}
func loadConfiguration() *config.Config {
var err error
customConfigFile := os.Getenv("GATUS_CONFIG_FILE")
if len(customConfigFile) > 0 {
err = config.Load(customConfigFile)
} else {
err = config.LoadDefaultConfiguration()
}
if err != nil {
panic(err)
}
return config.Get()
}
2019-11-16 21:48:37 +01:00
func serviceResultsHandler(writer http.ResponseWriter, _ *http.Request) {
serviceResults := watchdog.GetServiceResults()
data, err := json.Marshal(serviceResults)
if err != nil {
log.Printf("[main][serviceResultsHandler] Unable to marshall object to JSON: %s", err.Error())
writer.WriteHeader(http.StatusInternalServerError)
_, _ = writer.Write([]byte("Unable to marshall object to JSON"))
return
}
writer.Header().Add("Content-type", "application/json")
writer.WriteHeader(http.StatusOK)
_, _ = writer.Write(data)
}
2019-11-16 21:48:37 +01:00
func healthHandler(writer http.ResponseWriter, _ *http.Request) {
writer.Header().Add("Content-type", "application/json")
writer.WriteHeader(http.StatusOK)
_, _ = writer.Write([]byte("{\"status\":\"UP\"}"))
2019-09-05 01:37:13 +02:00
}