aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/middleware/log.go
blob: 9d3436fe8c4684fcf3833b329b9e1062f11f4af8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
package middleware

import (
	"log/slog"
	"net/http"
)

func Log(next http.Handler, logger *slog.Logger) http.Handler {
	return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {

		attrs := make([]slog.Attr, 0, 5)
		user, _, ok := r.BasicAuth()
		if ok {
			attrs = append(attrs, slog.String("user", user))
		}

		attrs = append(attrs, slog.Group("request", "Address", r.RemoteAddr, "method", r.Method, "url", r.URL))

		logger.LogAttrs(r.Context(), slog.LevelInfo, "Recieved Request", attrs...)

		next.ServeHTTP(w, r)
	})
}