Files
argo-cd/util/log/logrus.go
Matthieu MOREL c1b2f78f46 chore: enable var-naming from revive (#21861)
Signed-off-by: Matthieu MOREL <matthieu.morel35@gmail.com>
2025-02-18 11:02:38 -05:00

76 lines
1.7 KiB
Go

package log
import (
"fmt"
"os"
"strings"
adapter "github.com/bombsimon/logrusr/v4"
"github.com/go-logr/logr"
"github.com/sirupsen/logrus"
"github.com/argoproj/argo-cd/v3/common"
)
const (
JsonFormat = "json" //nolint:revive //FIXME(var-naming)
TextFormat = "text"
)
func NewLogrusLogger(fieldLogger logrus.FieldLogger) logr.Logger {
return adapter.New(fieldLogger, adapter.WithFormatter(func(val any) any {
return fmt.Sprintf("%v", val)
}))
}
// NewWithCurrentConfig create logrus logger by using current configuration
func NewWithCurrentConfig() *logrus.Logger {
l := logrus.New()
l.SetFormatter(CreateFormatter(os.Getenv(common.EnvLogFormat)))
l.SetLevel(createLogLevel())
return l
}
// CreateFormatter create logrus formatter by string
func CreateFormatter(logFormat string) logrus.Formatter {
var formatType logrus.Formatter
switch strings.ToLower(logFormat) {
case JsonFormat:
formatType = &logrus.JSONFormatter{
TimestampFormat: checkTimestampFormat(),
}
case TextFormat:
formatType = &logrus.TextFormatter{
ForceColors: checkForceLogColors(),
FullTimestamp: checkEnableFullTimestamp(),
TimestampFormat: checkTimestampFormat(),
}
default:
formatType = &logrus.JSONFormatter{
TimestampFormat: checkTimestampFormat(),
}
}
return formatType
}
func createLogLevel() logrus.Level {
level, err := logrus.ParseLevel(os.Getenv(common.EnvLogLevel))
if err != nil {
level = logrus.InfoLevel
}
return level
}
func checkForceLogColors() bool {
return strings.ToLower(os.Getenv("FORCE_LOG_COLORS")) == "1"
}
func checkEnableFullTimestamp() bool {
return strings.ToLower(os.Getenv(common.EnvLogFormatEnableFullTimestamp)) == "1"
}
func checkTimestampFormat() string {
return os.Getenv(common.EnvLogFormatTimestamp)
}