2019-01-11 21:01:48 +06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2019-05-08 17:42:48 +06:00
|
|
|
"net/http"
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
logrus "github.com/sirupsen/logrus"
|
2019-01-11 21:01:48 +06:00
|
|
|
)
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func initLog() {
|
|
|
|
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
|
|
|
|
2019-11-21 12:16:12 +01:00
|
|
|
logLevel := "info"
|
|
|
|
strEnvConfig(&logLevel, "IMGPROXY_LOG_LEVEL")
|
|
|
|
|
|
|
|
levelLogLevel, err := logrus.ParseLevel(logLevel)
|
|
|
|
if err != nil {
|
2019-11-21 17:19:14 +06:00
|
|
|
levelLogLevel = logrus.InfoLevel
|
2019-11-21 12:16:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
logrus.SetLevel(levelLogLevel)
|
2019-09-16 15:53:45 +06:00
|
|
|
|
|
|
|
if isSyslogEnabled() {
|
|
|
|
slHook, err := newSyslogHook()
|
|
|
|
if err != nil {
|
|
|
|
logFatal("Unable to connect to local syslog daemon")
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
logrus.AddHook(slHook)
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func logRequest(reqID string, r *http.Request) {
|
|
|
|
path := r.URL.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
|
|
|
|
2019-09-11 14:42:36 +06:00
|
|
|
switch {
|
|
|
|
case status >= 500:
|
2019-09-16 15:53:45 +06:00
|
|
|
level = logrus.ErrorLevel
|
2019-09-11 14:42:36 +06:00
|
|
|
case status >= 400:
|
2019-09-16 15:53:45 +06:00
|
|
|
level = logrus.WarnLevel
|
2019-09-11 14:42:36 +06:00
|
|
|
default:
|
2019-09-16 15:53:45 +06:00
|
|
|
level = logrus.InfoLevel
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
fields := logrus.Fields{
|
|
|
|
"request_id": reqID,
|
|
|
|
"method": r.Method,
|
|
|
|
"status": status,
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
if err != nil {
|
|
|
|
fields["error"] = err
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
if stack := err.FormatStack(); len(stack) > 0 {
|
|
|
|
fields["stack"] = stack
|
|
|
|
}
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
if imageURL != nil {
|
|
|
|
fields["image_url"] = *imageURL
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
if po != nil {
|
|
|
|
fields["processing_options"] = po
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
logrus.WithFields(fields).Logf(
|
|
|
|
level,
|
|
|
|
"Completed in %s %s", getTimerSince(r.Context()), r.URL.RequestURI(),
|
|
|
|
)
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func logNotice(f string, args ...interface{}) {
|
|
|
|
logrus.Infof(f, args...)
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func logWarning(f string, args ...interface{}) {
|
|
|
|
logrus.Warnf(f, args...)
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func logFatal(f string, args ...interface{}) {
|
|
|
|
logrus.Fatalf(f, args...)
|
|
|
|
}
|
2019-01-11 21:01:48 +06:00
|
|
|
|
2019-09-16 15:53:45 +06:00
|
|
|
func logDebug(f string, args ...interface{}) {
|
|
|
|
logrus.Debugf(f, args...)
|
2019-01-11 21:01:48 +06:00
|
|
|
}
|