mirror of
https://github.com/kemko/icecast-ripper.git
synced 2026-01-01 15:55:42 +03:00
36 lines
702 B
Go
36 lines
702 B
Go
package logger
|
|
|
|
import (
|
|
"log/slog"
|
|
"os"
|
|
"strings"
|
|
)
|
|
|
|
// Setup initializes the structured logger with the specified log level
|
|
func Setup(logLevel string) {
|
|
level := parseLogLevel(logLevel)
|
|
|
|
handler := slog.NewJSONHandler(os.Stdout, &slog.HandlerOptions{
|
|
Level: level,
|
|
})
|
|
|
|
logger := slog.New(handler)
|
|
slog.SetDefault(logger)
|
|
|
|
slog.Info("Logger initialized", "level", level.String())
|
|
}
|
|
|
|
// parseLogLevel converts a string log level to slog.Level
|
|
func parseLogLevel(level string) slog.Level {
|
|
switch strings.ToLower(level) {
|
|
case "debug":
|
|
return slog.LevelDebug
|
|
case "warn", "warning":
|
|
return slog.LevelWarn
|
|
case "error":
|
|
return slog.LevelError
|
|
default:
|
|
return slog.LevelInfo
|
|
}
|
|
}
|