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

113 lines
2.1 KiB
Go
Raw Normal View History

2019-01-11 21:01:48 +06:00
package main
import (
2020-02-27 21:44:59 +06:00
"fmt"
"net/http"
2019-01-11 21:01:48 +06:00
logrus "github.com/sirupsen/logrus"
2019-01-11 21:01:48 +06:00
)
2020-02-27 21:44:59 +06:00
func initLog() error {
logFormat := "pretty"
strEnvConfig(&logFormat, "IMGPROXY_LOG_FORMAT")
switch logFormat {
case "structured":
logrus.SetFormatter(&logStructuredFormatter{})
case "json":
logrus.SetFormatter(&logrus.JSONFormatter{})
default:
logrus.SetFormatter(newLogPrettyFormatter())
}
2019-01-11 21:01:48 +06:00
logLevel := "info"
strEnvConfig(&logLevel, "IMGPROXY_LOG_LEVEL")
levelLogLevel, err := logrus.ParseLevel(logLevel)
if err != nil {
levelLogLevel = logrus.InfoLevel
}
logrus.SetLevel(levelLogLevel)
if isSyslogEnabled() {
slHook, err := newSyslogHook()
if err != nil {
2020-02-27 21:44:59 +06:00
return fmt.Errorf("Unable to connect to syslog daemon: %s", err)
}
2019-01-11 21:01:48 +06:00
logrus.AddHook(slHook)
2019-01-11 21:01:48 +06:00
}
2020-02-27 21:44:59 +06:00
return nil
2019-01-11 21:01:48 +06:00
}
func logRequest(reqID string, r *http.Request) {
path := r.RequestURI
logrus.WithFields(logrus.Fields{
"request_id": reqID,
"method": r.Method,
}).Infof("Started %s", path)
}
func logResponse(reqID string, r *http.Request, status int, err *imgproxyError, imageURL *string, po *processingOptions) {
var level logrus.Level
2019-01-11 21:01:48 +06:00
switch {
case status >= 500:
level = logrus.ErrorLevel
case status >= 400:
level = logrus.WarnLevel
default:
level = logrus.InfoLevel
2019-01-11 21:01:48 +06:00
}
fields := logrus.Fields{
"request_id": reqID,
"method": r.Method,
"status": status,
2019-01-11 21:01:48 +06:00
}
if err != nil {
fields["error"] = err
2019-01-11 21:01:48 +06:00
if stack := err.FormatStack(); len(stack) > 0 {
fields["stack"] = stack
}
}
2019-01-11 21:01:48 +06:00
if imageURL != nil {
fields["image_url"] = *imageURL
2019-01-11 21:01:48 +06:00
}
if po != nil {
fields["processing_options"] = po
}
2019-01-11 21:01:48 +06:00
logrus.WithFields(fields).Logf(
level,
"Completed in %s %s", getTimerSince(r.Context()), r.RequestURI,
)
}
2019-01-11 21:01:48 +06:00
func logNotice(f string, args ...interface{}) {
logrus.Infof(f, args...)
2019-01-11 21:01:48 +06:00
}
func logWarning(f string, args ...interface{}) {
logrus.Warnf(f, args...)
}
2019-01-11 21:01:48 +06:00
2020-02-27 21:44:59 +06:00
func logError(f string, args ...interface{}) {
logrus.Errorf(f, args...)
}
func logFatal(f string, args ...interface{}) {
logrus.Fatalf(f, args...)
}
2019-01-11 21:01:48 +06:00
func logDebug(f string, args ...interface{}) {
logrus.Debugf(f, args...)
2019-01-11 21:01:48 +06:00
}