blob: 2257fa07dc9646d4cc348e5effbfd11757a2bed5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
package log
import (
"net/http"
"github.com/rs/zerolog"
"github.com/xlgmokha/x/pkg/mapper"
)
func HTTP(logger *zerolog.Logger) func(http.Handler) http.Handler {
return func(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
ctx := logger.WithContext(r.Context())
defer func() {
WithFields(ctx, mapper.MapFrom[*http.Request, Fields](r))
zerolog.Ctx(ctx).Print()
}()
next.ServeHTTP(w, r.WithContext(ctx))
})
}
}
|