ctxzerolog

package
v0.1.0 Latest Latest
Warning

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

Go to latest
Published: Feb 15, 2022 License: Apache-2.0 Imports: 3 Imported by: 0

Documentation

Overview

Package ctxzerolog is a ctxlogger that is backed by zerolog.

It accepts a user-configured `zerolog.Context` that will be used for logging. The same Context will be populated into the `context.Context` passed into gRPC handler code.

You can use `ctxzerolog.Extract` to log into a request-scoped Context instance in your handler code.

As `ctxzerolog.Extract` will iterate on all tags from `grpc_ctxtags` it is therefore expensive so it is advised that you extract once at the start of the function from the context and reuse it for the remainder of the function (see examples).

Please see examples and tests for examples of use.

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

func AddFields

func AddFields(ctx context.Context, fields map[string]interface{})

AddFields adds zerolog fields to the Context.

func Extract

func Extract(ctx context.Context) *zerolog.Context

Extract takes the call-scoped zerolog.Context from ctxzerolog middleware.

If the ctxzerolog middleware wasn't used, a no-op `zerolog.Context` is returned. This makes it safe to use regardless.

Example (Unary)

Simple unary handler that adds custom fields to the requests's context. These will be used for all log statements.

package main

import (
	"context"

	grpc_ctxtags "github.com/grpc-ecosystem/go-grpc-middleware/tags"
	"github.com/winebarrel/grpc-zerolog/ctxzerolog"
)

func main() {
	ctx := context.Background()
	// setting tags will be added to the logger as log fields
	grpc_ctxtags.Extract(ctx).Set("custom_tags.string", "something").Set("custom_tags.int", 1337)
	// Extract a single request-scoped zerolog.Context and log messages.
	l := ctxzerolog.Extract(ctx).Logger()
	l.Info().Msg("some ping")
	l.Info().Msg("another ping")
}
Output:

func ToContext

func ToContext(ctx context.Context, logContext *zerolog.Context) context.Context

ToContext adds the zerolog.Contextd to the context for extraction later. Returning the new context that has been created.

Types

This section is empty.

Jump to

Keyboard shortcuts

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