2024-12-27 18:03:46 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (app *application) recoverPanic(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
defer func() {
|
|
|
|
if err := recover(); err != nil {
|
|
|
|
w.Header().Set("Connection", "close")
|
|
|
|
app.serverError(w, r, fmt.Errorf("%s", err))
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (app *application) logRequest(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
var (
|
2025-02-01 17:07:24 +01:00
|
|
|
ip = realIP(r)
|
2024-12-27 18:03:46 +01:00
|
|
|
proto = r.Proto
|
|
|
|
method = r.Method
|
|
|
|
uri = r.URL.RequestURI()
|
|
|
|
)
|
|
|
|
app.logger.Info("received request", "ip", ip, "proto", proto, "method", method, "uri", uri)
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
})
|
|
|
|
}
|
2025-01-14 13:43:16 +01:00
|
|
|
|
|
|
|
func (app *application) cacheStatic(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
w.Header().Set("Cache-Control", "public, max-age=86400")
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
})
|
|
|
|
}
|