43 lines
847 B
Go
43 lines
847 B
Go
package logs
|
|
|
|
import (
|
|
"github.com/lmittmann/tint"
|
|
"log/slog"
|
|
"os"
|
|
"platform/pkg/env"
|
|
)
|
|
|
|
func Init() {
|
|
|
|
var writer = os.Stdout
|
|
var timeFormat = "2006-01-02 15:04:05"
|
|
|
|
var handler slog.Handler
|
|
switch env.RunMode {
|
|
case "debug":
|
|
handler = tint.NewHandler(writer, &tint.Options{
|
|
Level: env.LogLevel,
|
|
TimeFormat: timeFormat,
|
|
ReplaceAttr: func(_ []string, attr slog.Attr) slog.Attr {
|
|
switch v := attr.Value.Any().(type) {
|
|
case error:
|
|
return tint.Err(v)
|
|
}
|
|
return attr
|
|
},
|
|
})
|
|
case "production":
|
|
handler = slog.NewJSONHandler(writer, &slog.HandlerOptions{
|
|
Level: env.LogLevel,
|
|
ReplaceAttr: func(_ []string, a slog.Attr) slog.Attr {
|
|
if a.Key == "time" {
|
|
return slog.String("time", a.Value.Time().Format(timeFormat))
|
|
}
|
|
return a
|
|
},
|
|
})
|
|
}
|
|
|
|
slog.SetDefault(slog.New(handler))
|
|
}
|