diff --git a/cmd/timestamp-server/app/serve.go b/cmd/timestamp-server/app/serve.go index a7807b5e..47bb96e1 100644 --- a/cmd/timestamp-server/app/serve.go +++ b/cmd/timestamp-server/app/serve.go @@ -100,7 +100,6 @@ var serveCmd = &cobra.Command{ host := viper.GetString("host") port := int(viper.GetUint("port")) scheme := viper.GetStringSlice("scheme") - httpPingOnly := viper.GetBool("http-ping-only") server := server.NewRestAPIServer(host, port, scheme, httpPingOnly, readTimeout, writeTimeout) defer func() { if err := server.Shutdown(); err != nil { diff --git a/pkg/generated/restapi/configure_timestamp_server.go b/pkg/generated/restapi/configure_timestamp_server.go index 197dfc16..c602b812 100644 --- a/pkg/generated/restapi/configure_timestamp_server.go +++ b/pkg/generated/restapi/configure_timestamp_server.go @@ -103,15 +103,17 @@ func (l *logAdapter) Print(v ...interface{}) { log.Logger.Info(v...) } +const pingPath = "/ping" + // httpPingOnly custom middleware prohibits all entrypoints except // "/ping" on the http (non-HTTPS) server. -func httpPingOnly(endpoint string) func(http.Handler) http.Handler { +func httpPingOnly() func(http.Handler) http.Handler { f := func(h http.Handler) http.Handler { fn := func(w http.ResponseWriter, r *http.Request) { - if r.URL.Scheme != "https" && !strings.EqualFold(r.URL.Path, endpoint) { + if r.URL.Scheme != "https" && !strings.EqualFold(r.URL.Path, pingPath) { w.Header().Set("Content-Type", "text/plain") w.WriteHeader(http.StatusNotFound) - w.Write([]byte("http server supports only the /ping entrypoint")) //nolint:errcheck + w.Write([]byte("http server supports only the " + pingPath + " entrypoint")) //nolint:errcheck return } h.ServeHTTP(w, r) @@ -128,9 +130,9 @@ func setupGlobalMiddleware(handler http.Handler) http.Handler { &middleware.DefaultLogFormatter{Logger: &logAdapter{}}) returnHandler := middleware.Logger(handler) returnHandler = middleware.Recoverer(returnHandler) - returnHandler = middleware.Heartbeat("/ping")(returnHandler) + returnHandler = middleware.Heartbeat(pingPath)(returnHandler) if cmdparams.IsHTTPPingOnly { - returnHandler = httpPingOnly("/ping")(returnHandler) + returnHandler = httpPingOnly()(returnHandler) } handleCORS := cors.Default().Handler