2021-04-26 17:52:50 +06:00
|
|
|
package router
|
|
|
|
|
|
|
|
import (
|
2021-11-23 17:14:05 +06:00
|
|
|
"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
|
|
|
|
|
2021-11-23 17:14:05 +06:00
|
|
|
clientIP, _, _ := net.SplitHostPort(r.RemoteAddr)
|
|
|
|
|
2021-04-26 17:52:50 +06:00
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"request_id": reqID,
|
|
|
|
"method": r.Method,
|
2021-11-23 17:14:05 +06:00
|
|
|
"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
|
|
|
|
}
|
|
|
|
|
2021-11-23 17:14:05 +06:00
|
|
|
clientIP, _, _ := net.SplitHostPort(r.RemoteAddr)
|
|
|
|
|
2021-04-26 17:52:50 +06:00
|
|
|
fields := log.Fields{
|
|
|
|
"request_id": reqID,
|
|
|
|
"method": r.Method,
|
|
|
|
"status": status,
|
2021-11-23 17:14:05 +06:00
|
|
|
"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,
|
|
|
|
)
|
|
|
|
}
|