File: logging.go

package info (click to toggle)
incus 6.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,392 kB
  • sloc: sh: 16,313; ansic: 3,121; python: 457; makefile: 337; ruby: 51; sql: 50; lisp: 6
file content (48 lines) | stat: -rw-r--r-- 994 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package events

import (
	"fmt"

	"github.com/sirupsen/logrus"

	"github.com/lxc/incus/v6/shared/api"
)

// LoggingServer controls what server to use for messages coming from the logger.
var LoggingServer *Server

// Handler describes an event handler.
type Handler struct{}

// NewEventHandler creates and returns a new event handler.
func NewEventHandler() logrus.Hook {
	return &Handler{}
}

// Fire sends a new logging event.
func (h Handler) Fire(entry *logrus.Entry) error {
	if LoggingServer == nil {
		return nil
	}

	return LoggingServer.Send("", api.EventTypeLogging, api.EventLogging{
		Message: entry.Message,
		Level:   entry.Level.String(),
		Context: logContextMap(entry.Data),
	})
}

// Levels returns the list of supported log levels.
func (h Handler) Levels() []logrus.Level {
	return logrus.AllLevels
}

func logContextMap(ctx logrus.Fields) map[string]string {
	ctxMap := map[string]string{}

	for k, v := range ctx {
		ctxMap[k] = fmt.Sprintf("%v", v)
	}

	return ctxMap
}