2021-04-26 17:52:50 +06:00
|
|
|
package logger
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
logrus "github.com/sirupsen/logrus"
|
|
|
|
|
2021-09-30 20:23:30 +06:00
|
|
|
"github.com/imgproxy/imgproxy/v3/config/configurators"
|
2021-04-26 17:52:50 +06:00
|
|
|
)
|
|
|
|
|
|
|
|
func Init() error {
|
2022-03-16 14:17:32 +06:00
|
|
|
logrus.SetOutput(os.Stdout)
|
2021-04-26 17:52:50 +06:00
|
|
|
|
|
|
|
logFormat := "pretty"
|
|
|
|
logLevel := "info"
|
|
|
|
|
|
|
|
configurators.String(&logFormat, "IMGPROXY_LOG_FORMAT")
|
|
|
|
configurators.String(&logLevel, "IMGPROXY_LOG_LEVEL")
|
|
|
|
|
|
|
|
switch logFormat {
|
|
|
|
case "structured":
|
|
|
|
logrus.SetFormatter(&structuredFormatter{})
|
|
|
|
case "json":
|
|
|
|
logrus.SetFormatter(&logrus.JSONFormatter{})
|
|
|
|
default:
|
|
|
|
logrus.SetFormatter(newPrettyFormatter())
|
|
|
|
}
|
|
|
|
|
|
|
|
levelLogLevel, err := logrus.ParseLevel(logLevel)
|
|
|
|
if err != nil {
|
|
|
|
levelLogLevel = logrus.InfoLevel
|
|
|
|
}
|
|
|
|
|
|
|
|
logrus.SetLevel(levelLogLevel)
|
|
|
|
|
|
|
|
if isSyslogEnabled() {
|
|
|
|
slHook, err := newSyslogHook()
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Unable to connect to syslog daemon: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
logrus.AddHook(slHook)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|