[feature] migrate to monorepo
This commit is contained in:
commit
05ddc1f783
267 changed files with 75165 additions and 0 deletions
51
backend/pkg/logger/logger.go
Normal file
51
backend/pkg/logger/logger.go
Normal file
|
@ -0,0 +1,51 @@
|
|||
package logger
|
||||
|
||||
import (
|
||||
"os"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"github.com/rs/zerolog"
|
||||
"github.com/rs/zerolog/log"
|
||||
"tss-rocks-be/internal/config"
|
||||
)
|
||||
|
||||
// Setup configures the logger based on the provided configuration
|
||||
func Setup(cfg *config.Config) {
|
||||
// Set log level
|
||||
level := zerolog.InfoLevel
|
||||
if cfg.Logging.Level != "" {
|
||||
switch strings.ToLower(cfg.Logging.Level) {
|
||||
case "debug":
|
||||
level = zerolog.DebugLevel
|
||||
case "info":
|
||||
level = zerolog.InfoLevel
|
||||
case "warn":
|
||||
level = zerolog.WarnLevel
|
||||
case "error":
|
||||
level = zerolog.ErrorLevel
|
||||
case "fatal":
|
||||
level = zerolog.FatalLevel
|
||||
case "panic":
|
||||
level = zerolog.PanicLevel
|
||||
}
|
||||
}
|
||||
zerolog.SetGlobalLevel(level)
|
||||
|
||||
// Configure output format
|
||||
if cfg.Logging.Format == "console" {
|
||||
log.Logger = log.Output(zerolog.ConsoleWriter{
|
||||
Out: os.Stdout,
|
||||
TimeFormat: time.RFC3339,
|
||||
})
|
||||
} else {
|
||||
// Use JSON format by default
|
||||
zerolog.TimeFieldFormat = time.RFC3339
|
||||
log.Logger = zerolog.New(os.Stdout).With().Timestamp().Logger()
|
||||
}
|
||||
}
|
||||
|
||||
// GetLogger returns the global logger instance
|
||||
func GetLogger() *zerolog.Logger {
|
||||
return &log.Logger
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue