From 178e0bfc2d8709ae4d3abd7519b260df09b2d3b5 Mon Sep 17 00:00:00 2001 From: Marc Pervaz Boocha Date: Sat, 2 Aug 2025 22:23:13 +0530 Subject: Switched to go.sudomsg.com/kit --- logging/log.go | 56 -------------------------------------------------------- 1 file changed, 56 deletions(-) delete mode 100644 logging/log.go (limited to 'logging/log.go') diff --git a/logging/log.go b/logging/log.go deleted file mode 100644 index 8e3078f..0000000 --- a/logging/log.go +++ /dev/null @@ -1,56 +0,0 @@ -package logging - -import ( - "context" - "io" - "log/slog" - "os" - "runtime" -) - -type Config struct { - Level slog.Level `toml:"level"` - File string `toml:"file"` -} - -func SetupLogger(cfg Config) *slog.Logger { - opts := &slog.HandlerOptions{Level: cfg.Level} - var handler slog.Handler - - var writter io.Writer - writter = os.Stdout - if cfg.File != "" { - f, _ := os.OpenFile(cfg.File, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644) - writter = f - } - handler = slog.NewJSONHandler(writter, opts) - - logger := slog.New(handler) - slog.SetDefault(logger) - return logger -} - -type contextKeyType struct{} - -var contextKey contextKeyType - -func WithLogger(ctx context.Context, logger *slog.Logger) context.Context { - return context.WithValue(ctx, contextKey, logger) -} - -func FromContext(ctx context.Context) *slog.Logger { - if logger, ok := ctx.Value(contextKey).(*slog.Logger); ok { - return logger - } - return slog.Default() -} - -func RecoverLog(ctx context.Context, err any) { - logger := FromContext(ctx) - - const size = 64 << 10 - buf := make([]byte, size) - buf = buf[:runtime.Stack(buf, false)] - - logger.Log(ctx, slog.LevelError, "Program Paniced", "error", err, "stack", string(buf)) -} -- cgit v1.2.3-70-g09d2