summaryrefslogtreecommitdiff
path: root/vendor/github.com/xlgmokha/x/pkg/log/http.go
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))
		})
	}
}