middleware/logger.go

28 lines
545 B
Go
Raw Permalink Normal View History

2024-04-06 20:05:14 +03:00
package middleware
import (
"net/http"
"log/slog"
)
2024-04-06 20:39:09 +03:00
func Logger(logger *slog.Logger) Middleware {
return func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
next.ServeHTTP(w, r)
requestID := GetRequestID(r)
args := []any{
slog.String("proto", r.Proto),
slog.String("method", r.Method),
slog.String("request_uri", r.RequestURI),
2024-07-28 19:32:33 +03:00
slog.String("request_id", requestID),
2024-04-06 20:39:09 +03:00
}
logger.InfoContext(
r.Context(),
"request",
args...,
)
})
}
2024-04-06 20:05:14 +03:00
}