code
import (
"context"
"log/slog"
"github.com/n-r-w/ctxlog"
)
func main() {
// Parse level from environment variable
// (here we hardcode it for demonstration)
level, err := ctxlog.ParseLogLevel("DEBUG")
if err != nil {
panic(err)
}
// create context with logger
ctx := ctxlog.MustContext(
context.Background(),
ctxlog.WithName("myapp"),
ctxlog.WithLevel(level),
)
// simple format (key/value pairs)
ctxlog.Info(ctx, "starting application", "version", "1.0.0")
// slog attr fields
ctxlog.Debug(ctx, "connecting to database",
slog.String("host", "localhost"),
slog.Int("port", 5432),
)
// enrich context with more fields
ctx = ctxlog.WithGroup(ctx, "database")
ctx = ctxlog.With(ctx, "user_id", "12345", "ip", "192.168.1.1")
ctxlog.Error(ctx, "some error occurred")
// extract logger from context for direct usage
logger := ctxlog.FromContext(ctx)
logger.Warn(ctx, "direct usage of logger")
}
```
</example>