2024-02-08 09:20:01 -05:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
|
|
|
package logger
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"log/slog"
|
|
|
|
)
|
|
|
|
|
|
|
|
// LevelHandler copied from the official LevelHandler example in the slog package documentation.
|
|
|
|
|
2024-08-29 04:44:22 -04:00
|
|
|
// levelHandler wraps a Handler with an Enabled method
|
2024-02-08 09:20:01 -05:00
|
|
|
// that returns false for levels below a minimum.
|
2024-08-29 04:44:22 -04:00
|
|
|
type levelHandler struct {
|
2024-02-08 09:20:01 -05:00
|
|
|
level slog.Leveler
|
|
|
|
handler slog.Handler
|
|
|
|
}
|
|
|
|
|
2024-08-29 04:44:22 -04:00
|
|
|
// newLevelHandler returns a LevelHandler with the given level.
|
2024-02-08 09:20:01 -05:00
|
|
|
// All methods except Enabled delegate to h.
|
2024-08-29 04:44:22 -04:00
|
|
|
func newLevelHandler(level slog.Leveler, h slog.Handler) *levelHandler {
|
2024-02-08 09:20:01 -05:00
|
|
|
// Optimization: avoid chains of LevelHandlers.
|
2024-08-29 04:44:22 -04:00
|
|
|
if lh, ok := h.(*levelHandler); ok {
|
2024-02-08 09:20:01 -05:00
|
|
|
h = lh.Handler()
|
|
|
|
}
|
2024-08-29 04:44:22 -04:00
|
|
|
return &levelHandler{level, h}
|
2024-02-08 09:20:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Enabled implements Handler.Enabled by reporting whether
|
|
|
|
// level is at least as large as h's level.
|
2024-08-29 04:44:22 -04:00
|
|
|
func (h *levelHandler) Enabled(_ context.Context, level slog.Level) bool {
|
2024-02-08 09:20:01 -05:00
|
|
|
return level >= h.level.Level()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Handle implements Handler.Handle.
|
2024-08-29 04:44:22 -04:00
|
|
|
func (h *levelHandler) Handle(ctx context.Context, r slog.Record) error {
|
2024-02-08 09:20:01 -05:00
|
|
|
return h.handler.Handle(ctx, r)
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithAttrs implements Handler.WithAttrs.
|
2024-08-29 04:44:22 -04:00
|
|
|
func (h *levelHandler) WithAttrs(attrs []slog.Attr) slog.Handler {
|
|
|
|
return newLevelHandler(h.level, h.handler.WithAttrs(attrs))
|
2024-02-08 09:20:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// WithGroup implements Handler.WithGroup.
|
2024-08-29 04:44:22 -04:00
|
|
|
func (h *levelHandler) WithGroup(name string) slog.Handler {
|
|
|
|
return newLevelHandler(h.level, h.handler.WithGroup(name))
|
2024-02-08 09:20:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Handler returns the Handler wrapped by h.
|
2024-08-29 04:44:22 -04:00
|
|
|
func (h *levelHandler) Handler() slog.Handler {
|
2024-02-08 09:20:01 -05:00
|
|
|
return h.handler
|
|
|
|
}
|