Add request logs to the backend

This commit is contained in:
David Dworken 2022-04-15 23:19:39 -07:00
parent 6df100ebbd
commit df59b43e03

View File

@ -205,14 +205,26 @@ func attestationDownloadHandler(w http.ResponseWriter, r *http.Request) {
http.Redirect(w, r, fmt.Sprintf("https://github.com/ddworken/hishtory/releases/download/%s/hishtory-linux-amd64.intoto.jsonl", ReleaseVersion), http.StatusFound) http.Redirect(w, r, fmt.Sprintf("https://github.com/ddworken/hishtory/releases/download/%s/hishtory-linux-amd64.intoto.jsonl", ReleaseVersion), http.StatusFound)
} }
func withLogging(h func(rw http.ResponseWriter, r *http.Request)) http.Handler {
logFn := func(rw http.ResponseWriter, r *http.Request) {
start := time.Now()
h(rw, r)
duration := time.Since(start)
fmt.Printf("%s %s %#v %s\n", r.RemoteAddr, r.Method, r.RequestURI, duration.String())
}
return http.HandlerFunc(logFn)
}
func main() { func main() {
fmt.Println("Listening on localhost:8080") fmt.Println("Listening on localhost:8080")
http.HandleFunc("/api/v1/esubmit", apiESubmitHandler) http.Handle("/api/v1/esubmit", withLogging(apiESubmitHandler))
http.HandleFunc("/api/v1/equery", apiEQueryHandler) http.Handle("/api/v1/equery", withLogging(apiEQueryHandler))
http.HandleFunc("/api/v1/ebootstrap", apiEBootstrapHandler) http.Handle("/api/v1/ebootstrap", withLogging(apiEBootstrapHandler))
http.HandleFunc("/api/v1/eregister", apiERegisterHandler) http.Handle("/api/v1/eregister", withLogging(apiERegisterHandler))
http.HandleFunc("/api/v1/banner", apiBannerHandler) http.Handle("/api/v1/banner", withLogging(apiBannerHandler))
http.HandleFunc("/download/hishtory-linux-amd64", bindaryDownloadHandler) http.Handle("/download/hishtory-linux-amd64", withLogging(bindaryDownloadHandler))
http.HandleFunc("/download/hishtory-linux-amd64.intoto.jsonl", attestationDownloadHandler) http.Handle("/download/hishtory-linux-amd64.intoto.jsonl", withLogging(attestationDownloadHandler))
log.Fatal(http.ListenAndServe(":8080", nil)) log.Fatal(http.ListenAndServe(":8080", nil))
} }