forked from TrueCloudLab/distribution
e0281dc609
gofumpt (https://github.com/mvdan/gofumpt) provides a supserset of `gofmt` / `go fmt`, and addresses various formatting issues that linters may be checking for. We can consider enabling the `gofumpt` linter to verify the formatting in CI, although not every developer may have it installed, so for now this runs it once to get formatting in shape. Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
35 lines
852 B
Go
35 lines
852 B
Go
package api
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/distribution/distribution/v3/health"
|
|
)
|
|
|
|
var updater = health.NewStatusUpdater()
|
|
|
|
// DownHandler registers a manual_http_status that always returns an Error
|
|
func DownHandler(w http.ResponseWriter, r *http.Request) {
|
|
if r.Method == "POST" {
|
|
updater.Update(errors.New("manual Check"))
|
|
} else {
|
|
w.WriteHeader(http.StatusNotFound)
|
|
}
|
|
}
|
|
|
|
// UpHandler registers a manual_http_status that always returns nil
|
|
func UpHandler(w http.ResponseWriter, r *http.Request) {
|
|
if r.Method == "POST" {
|
|
updater.Update(nil)
|
|
} else {
|
|
w.WriteHeader(http.StatusNotFound)
|
|
}
|
|
}
|
|
|
|
// init sets up the two endpoints to bring the service up and down
|
|
func init() {
|
|
health.Register("manual_http_status", updater)
|
|
http.HandleFunc("/debug/health/down", DownHandler)
|
|
http.HandleFunc("/debug/health/up", UpHandler)
|
|
}
|