secondtruth / go-logger

πŸ“– Common interface for logging facilities in Go

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Go Logger interface with implementations

This library provides a common interface for logging in Go. It also provides an implementation of the interface for slog, which is part of the standard library.

Coming soon in independent repositories: Implementations for two other popular log libraries: Logrus and zap.

Why is this interface useful?

When we create libraries in general we shouldn't be logging but at times we do have to log, debug what the library is doing or trace the log.

We cannot implement a library with one log library and expect other applications to use the same log library. Here is where this interface comes in. It allows others to change the log library at any time without changing the code.

Installation

To install go-logger, use the following command:

go get -u github.com/secondtruth/go-logger

Quick Start

Example for slog

package main

import (
	"os"
	"log/slog"

	"github.com/secondtruth/go-logger/logger"
)

func main() {
	slogHandler := slog.NewJSONHandler(os.Stdout, &slog.HandlerOptions{
		Level: slog.LevelDebug,
	})
	slogLog := slog.New(slogHandler)
	log, _ := logger.NewSlogLogger(slogLog)
	
	log.WithFields(logger.Fields{
		"foo": "bar",
	}).Info("message")
}

About

πŸ“– Common interface for logging facilities in Go

License:MIT License


Languages

Language:Go 92.6%Language:Makefile 7.4%