// Copyright 2022 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package slog_test import ( "context" "log/slog" "net/http" "os" "time" ) func ExampleGroup() { r, _ := http.NewRequest("GET", "localhost", nil) // ... logger := slog.New( slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{ ReplaceAttr: func(groups []string, a slog.Attr) slog.Attr { if a.Key == slog.TimeKey && len(groups) == 0 { return slog.Attr{} } return a }, }), ) logger.Info("finished", slog.Group("req", slog.String("method", r.Method), slog.String("url", r.URL.String())), slog.Int("status", http.StatusOK), slog.Duration("duration", time.Second)) // Output: // level=INFO msg=finished req.method=GET req.url=localhost status=200 duration=1s } func ExampleGroupAttrs() { r, _ := http.NewRequest("POST", "localhost", http.NoBody) // ... logger := slog.New( slog.NewTextHandler(os.Stdout, &slog.HandlerOptions{ Level: slog.LevelDebug, ReplaceAttr: func(groups []string, a slog.Attr) slog.Attr { if a.Key == slog.TimeKey && len(groups) == 0 { return slog.Attr{} } return a }, }), ) // Use []slog.Attr to accumulate attributes. attrs := []slog.Attr{slog.String("method", r.Method)} attrs = append(attrs, slog.String("url", r.URL.String())) if r.Method == "POST" { attrs = append(attrs, slog.Int("content-length", int(r.ContentLength))) } // Group the attributes under a key. logger.LogAttrs(context.Background(), slog.LevelInfo, "finished", slog.Int("status", http.StatusOK), slog.GroupAttrs("req", attrs...), ) // Groups with empty keys are inlined. logger.LogAttrs(context.Background(), slog.LevelInfo, "finished", slog.Int("status", http.StatusOK), slog.GroupAttrs("", attrs...), ) // Output: // level=INFO msg=finished status=200 req.method=POST req.url=localhost req.content-length=0 // level=INFO msg=finished status=200 method=POST url=localhost content-length=0 }