1
0
mirror of https://github.com/imgproxy/imgproxy.git synced 2025-01-23 11:14:48 +02:00
imgproxy/router/logging.go

63 lines
1.1 KiB
Go
Raw Normal View History

2021-04-26 17:52:50 +06:00
package router
import (
"net"
2021-04-26 17:52:50 +06:00
"net/http"
2021-09-30 20:23:30 +06:00
"github.com/imgproxy/imgproxy/v3/ierrors"
2021-04-26 17:52:50 +06:00
log "github.com/sirupsen/logrus"
)
func LogRequest(reqID string, r *http.Request) {
path := r.RequestURI
clientIP, _, _ := net.SplitHostPort(r.RemoteAddr)
2021-04-26 17:52:50 +06:00
log.WithFields(log.Fields{
"request_id": reqID,
"method": r.Method,
"client_ip": clientIP,
2021-04-26 17:52:50 +06:00
}).Infof("Started %s", path)
}
func LogResponse(reqID string, r *http.Request, status int, err *ierrors.Error, additional ...log.Fields) {
var level log.Level
switch {
case status >= 500:
level = log.ErrorLevel
case status >= 400:
level = log.WarnLevel
default:
level = log.InfoLevel
}
clientIP, _, _ := net.SplitHostPort(r.RemoteAddr)
2021-04-26 17:52:50 +06:00
fields := log.Fields{
"request_id": reqID,
"method": r.Method,
"status": status,
"client_ip": clientIP,
2021-04-26 17:52:50 +06:00
}
if err != nil {
fields["error"] = err
if stack := err.FormatStack(); len(stack) > 0 {
fields["stack"] = stack
}
}
for _, f := range additional {
for k, v := range f {
fields[k] = v
}
}
log.WithFields(fields).Logf(
level,
"Completed in %s %s", ctxTime(r.Context()), r.RequestURI,
)
}