mirror of
https://github.com/jhillyerd/inbucket.git
synced 2025-12-17 09:37:02 +00:00
- rest: improve error logging. - web: extract handlers/middleware into their own file. - web: log all requests, not just ones hitting our handlers. - test: improve integration test logging format.
51 lines
1.7 KiB
Go
51 lines
1.7 KiB
Go
package web
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
// Handler is a function type that handles an HTTP request in Inbucket.
|
|
type Handler func(http.ResponseWriter, *http.Request, *Context) error
|
|
|
|
// ServeHTTP builds the context and passes onto the real handler.
|
|
func (h Handler) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
|
// Create the context.
|
|
ctx, err := NewContext(req)
|
|
if err != nil {
|
|
log.Error().Str("module", "web").Err(err).Msg("HTTP failed to create context")
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
defer ctx.Close()
|
|
|
|
// Run the handler, grab the error, and report it.
|
|
err = h(w, req, ctx)
|
|
if err != nil {
|
|
log.Error().Str("module", "web").Str("path", req.RequestURI).Err(err).
|
|
Msg("Error handling request")
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
return
|
|
}
|
|
}
|
|
|
|
// noMatchHandler creates a handler to log requests that Gorilla mux is unable to route,
|
|
// returning specified statusCode to the client.
|
|
func noMatchHandler(statusCode int, message string) http.Handler {
|
|
return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
|
log.Warn().Str("module", "web").Str("remote", req.RemoteAddr).Str("proto", req.Proto).
|
|
Str("method", req.Method).Str("path", req.RequestURI).Msg(message)
|
|
w.WriteHeader(statusCode)
|
|
})
|
|
}
|
|
|
|
// requestLoggingWrapper returns middleware that logs client requests.
|
|
func requestLoggingWrapper(next http.Handler) http.Handler {
|
|
return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
|
|
log.Debug().Str("module", "web").Str("remote", req.RemoteAddr).Str("proto", req.Proto).
|
|
Str("method", req.Method).Str("path", req.RequestURI).Msg("Request")
|
|
next.ServeHTTP(w, req)
|
|
})
|
|
}
|