gelf_slog

package module
v1.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 8, 2025 License: MIT Imports: 7 Imported by: 0

README

slog: Gelf (Graylog) handler

Go Version License

A Graylog Handler for slog Go library.

🚀 Install

go get github.com/eandr-67/gelf_slog

Compatibility: go >= 1.24

Причины создания

Исходный вариант пакета [] намертво прибит гвоздями к первой версии пакета Graylog2/go-gelf. Но существует вторая версия - тоже древняя но всё же более функциональная.

Хотелось и перейти на вторую версию транспортного пакета, и лучше приспособить адаптер для DI-контейнеров. Кроме того, в текущей реализации есть проблема

К сожалению, полностью отвязать адаптер от конкретной реализации транспорта

Для этого пришлось перейти от типа к интерфейсу. В сам же интерфейс добавить
и отвязать адаптер от транспорта. Для чего надо перейти от типа к интерфейсу - в обоих пакетах. Так что пришлось делать два форка: этот и enadr-67/gelf.

💡 Usage

Handler options
type Option struct {
    // log level (default: debug)
    Level slog.Leveler

    // connection to graylog
    Writer gelf.Writer

    // optional: customize json payload builder
    Converter Converter
    // optional: fetch attributes from context
    AttrFromContext []func(ctx context.Context) []slog.Attr

    // optional: see slog.HandlerOptions
    AddSource   bool
    ReplaceAttr func(groups []string, a slog.Attr) slog.Attr
}

Attributes will be injected in log "extra".

Other global parameters:

gelf_slog.SourceKey = "source"
gelf_slog.ErrorKeys = []string{"error", "err"}
gelf_slog.LogLevels = map[slog.Level]int32{...}
Example
import (
    "github.com/eandr-67/gelf"
    "github.com/eandr-67/gelf_log"
    "log/slog"
)

func main() {
    // docker-compose up -d
    // or
    // ncat -l 12201 -u
    gelfWriter, err := gelf.NewUDPWriter("localhost:12201")
    if err != nil {
        log.Fatalf("gelf.NewWriter: %s", err)
    }

	gelfWriter.CompressionType = gelf.CompressNone  // for debugging only

    logger := slog.New(sloggraylog.Option{Level: slog.LevelDebug, Writer: gelfWriter}.NewGraylogHandler())
    logger = logger.
        With("environment", "dev").
        With("release", "v1.0.0")

    // log error
    logger.
        With("category", "sql").
        With("query.statement", "SELECT COUNT(*) FROM users;").
        With("query.duration", 1*time.Second).
        With("error", fmt.Errorf("could not count users")).
        Error("caramba!")

    // log user signup
    logger.
        With(
            slog.Group("user",
                slog.String("id", "user-123"),
                slog.Time("created_at", time.Now()),
            ),
        ).
        Info("user registration")
}

Output:

{
    "timestamp":"2023-04-10T14:00:0.000000+00:00",
    "level":3,
    "message":"caramba!",
    "extra":{
        "error":{
            "error":"could not count users",
            "kind":"*errors.errorString",
            "stack":null
        },
        "environment":"dev",
        "release":"v1.0.0",
        "category":"sql",
        "query.statement":"SELECT COUNT(*) FROM users;",
        "query.duration": "1s"
    }
}


{
    "timestamp":"2023-04-10T14:00:0.000000+00:00",
    "level":6,
    "message":"user registration",
    "extra":{
        "environment":"dev",
        "release":"v1.0.0",
        "user":{
            "id":"user-123",
            "created_at":"2023-04-10T14:00:0.000000+00:00"
        }
    }
}

📝 License

Copyright © 2023 Samuel Berthe.

This project is MIT licensed.

Documentation

Index

Constants

This section is empty.

Variables

View Source
var SourceKey = "source"

Functions

func AttrsToMap added in v1.0.1

func AttrsToMap(attrs ...slog.Attr) map[string]any

func DefaultConverter

func DefaultConverter(
	addSource bool, replaceAttr func(groups []string, a slog.Attr) slog.Attr, loggerAttr []slog.Attr, groups []string,
	record *slog.Record) (extra map[string]any)

Types

type Converter

type Converter func(
	addSource bool, replaceAttr func(groups []string, a slog.Attr) slog.Attr, loggerAttr []slog.Attr, groups []string,
	record *slog.Record) (extra map[string]any)

type GraylogHandler

type GraylogHandler struct {
	// contains filtered or unexported fields
}

func (*GraylogHandler) Enabled

func (h *GraylogHandler) Enabled(_ context.Context, level slog.Level) bool

func (*GraylogHandler) Handle

func (h *GraylogHandler) Handle(ctx context.Context, record slog.Record) error

func (*GraylogHandler) WithAttrs

func (h *GraylogHandler) WithAttrs(attrs []slog.Attr) slog.Handler

func (*GraylogHandler) WithGroup

func (h *GraylogHandler) WithGroup(name string) slog.Handler

type Option

type Option struct {
	// log level (default: debug)
	Level slog.Leveler

	// connection to graylog
	Writer gelf.Writer

	// optional: customize json payload builder
	Converter Converter
	// optional: fetch attributes from context
	AttrFromContext []func(ctx context.Context) []slog.Attr

	// optional: see slog.HandlerOptions
	AddSource   bool
	ReplaceAttr func(groups []string, a slog.Attr) slog.Attr
	// contains filtered or unexported fields
}

func (Option) NewGraylogHandler

func (o Option) NewGraylogHandler() slog.Handler

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL