task-processor/config/logging.go

93 lines
1.9 KiB
Go
Raw Permalink Normal View History

2026-02-18 15:53:29 +03:00
package config
import (
"fmt"
"github.com/sirupsen/logrus"
"os"
"path/filepath"
"strings"
)
func LogSetup(mode, lvl string) {
l, err := logrus.ParseLevel(lvl)
if err != nil {
l = logrus.InfoLevel
}
logrus.SetLevel(l)
switch mode {
case "release":
case "dev":
{
logrus.SetReportCaller(true)
logrus.SetFormatter(&CustomFormatter{})
logrus.SetOutput(os.Stdout)
}
}
}
type CustomFormatter struct{}
func (f *CustomFormatter) Format(entry *logrus.Entry) ([]byte, error) {
timestamp := entry.Time.Format("2006-01-02 15:04:05")
level := strings.ToUpper(entry.Level.String())
msg := entry.Message
file := ""
line := 0
if entry.Caller != nil {
file = filepath.Base(entry.Caller.File)
line = entry.Caller.Line
}
2026-02-21 16:58:43 +03:00
colorCode := f.getLevelColor(entry.Level)
resetCode := "\033[0m"
coloredLevel := fmt.Sprintf("%s[%s]%s", colorCode, level, resetCode)
errVal := entry.Data["error"]
if errVal == nil {
errVal = "\n"
} else {
2026-04-02 17:59:57 +03:00
errVal = fmt.Sprintf("%v\n", errVal)
}
fieldsLine := "\n"
fields := entry.Data
if len(fields) > 0 {
fieldsLine = "| params: "
for key, val := range fields {
fieldsLine += fmt.Sprintf("\t%v=%v ", key, val)
}
2026-02-21 16:58:43 +03:00
}
cyanCode := f.getLevelColor(logrus.TraceLevel)
filename := fmt.Sprintf("%s[%s:%d]%s", cyanCode, file, line, resetCode)
2026-04-02 17:59:57 +03:00
logLine := fmt.Sprintf("%s[%s]%v %s\t%v %v",
coloredLevel, timestamp, filename, msg, fieldsLine, errVal)
2026-02-18 15:53:29 +03:00
return []byte(logLine), nil
}
2026-02-21 16:58:43 +03:00
func (f *CustomFormatter) getLevelColor(level logrus.Level) string {
switch level {
case logrus.PanicLevel:
return "\033[35m" // Magenta
case logrus.FatalLevel:
return "\033[35m" // Magenta
case logrus.ErrorLevel:
return "\033[31m" // Red
case logrus.WarnLevel:
return "\033[33m" // Yellow
case logrus.InfoLevel:
return "\033[32m" // Green
case logrus.DebugLevel:
return "\033[34m" // Blue
case logrus.TraceLevel:
return "\033[36m" // Cyan
default:
return "\033[0m" // No color
}
}