File: logger.go

package info (click to toggle)
zabbix 1%3A7.0.10%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 272,688 kB
  • sloc: sql: 946,050; ansic: 389,440; php: 292,698; javascript: 83,388; sh: 5,680; makefile: 3,285; java: 1,420; cpp: 694; perl: 64; xml: 56
file content (78 lines) | stat: -rw-r--r-- 2,563 bytes parent folder | download
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*
** Copyright (C) 2001-2025 Zabbix SIA
**
** Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
** documentation files (the "Software"), to deal in the Software without restriction, including without limitation the
** rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
** permit persons to whom the Software is furnished to do so, subject to the following conditions:
**
** The above copyright notice and this permission notice shall be included in all copies or substantial portions
** of the Software.
**
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
** WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
** COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
** SOFTWARE.
**/

package log

import "fmt"

var _ Logger = (*loggerImpl)(nil)

// Logger is the interface defines basic logging methods.
type Logger interface {
	Infof(format string, args ...any)
	Critf(format string, args ...any)
	Errf(format string, args ...any)
	Warningf(format string, args ...any)
	Debugf(format string, args ...any)
	Tracef(format string, args ...any)
}

type loggerImpl struct {
	prefix string
}

// New creates a new logger.
func New(module string) Logger { //nolint:ireturn
	var prefix string

	if module != "" {
		prefix = fmt.Sprintf("[%s] ", module)
	}

	return &loggerImpl{prefix: prefix}
}

// Infof logs a message with the Info level.
func (l *loggerImpl) Infof(format string, args ...any) {
	Infof(l.prefix+format, args...)
}

// Critf logs a message with the Critical level.
func (l *loggerImpl) Critf(format string, args ...any) {
	Critf(l.prefix+format, args...)
}

// Errf logs a message with the Error level.
func (l *loggerImpl) Errf(format string, args ...any) {
	Errf(l.prefix+format, args...)
}

// Warningf logs a message with the Warning level.
func (l *loggerImpl) Warningf(format string, args ...any) {
	Warningf(l.prefix+format, args...)
}

// Debugf logs a message with the Debug level.
func (l *loggerImpl) Debugf(format string, args ...any) {
	Debugf(l.prefix+format, args...)
}

// Tracef logs a message with the Trace level.
func (l *loggerImpl) Tracef(format string, args ...any) {
	Tracef(l.prefix+format, args...)
}