-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathslog.go
253 lines (187 loc) · 6.64 KB
/
slog.go
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
/*
Package slog Lightweight, extensible, configurable logging library written in Go.
Source code and other details for the project are available at GitHub:
https://github.com/gookit/slog
Quick usage:
package main
import (
"github.com/gookit/slog"
)
func main() {
slog.Info("info log message")
slog.Warn("warning log message")
slog.Infof("info log %s", "message")
slog.Debugf("debug %s", "message")
}
More usage please see README.
*/
package slog
import (
"context"
"time"
"github.com/gookit/goutil"
"github.com/gookit/gsr"
)
// SLogger interface
type SLogger interface {
gsr.Logger
Log(level Level, v ...any)
Logf(level Level, format string, v ...any)
}
// LoggerFn func
type LoggerFn func(l *Logger)
//
// ------------------------------------------------------------
// Global std logger operate
// ------------------------------------------------------------
//
// std logger is an SugaredLogger.
// It is directly available without any additional configuration
var std = NewStdLogger()
// Std get std logger
func Std() *SugaredLogger { return std }
// Reset the std logger and reset exit handlers
func Reset() {
ResetExitHandlers(true)
// new std
std = NewStdLogger()
}
// Configure the std logger
func Configure(fn func(l *SugaredLogger)) { std.Config(fn) }
// SetExitFunc to the std logger
func SetExitFunc(fn func(code int)) { std.ExitFunc = fn }
// Exit runs all exit handlers and then terminates the program using os.Exit(code)
func Exit(code int) { std.Exit(code) }
// Close logger, flush and close all handlers.
//
// IMPORTANT: please call Close() before app exit.
func Close() error { return std.Close() }
// MustClose logger, flush and close all handlers.
//
// IMPORTANT: please call Close() before app exit.
func MustClose() { goutil.PanicErr(Close()) }
// Flush log messages
func Flush() error { return std.Flush() }
// MustFlush log messages
func MustFlush() { goutil.PanicErr(Flush()) }
// FlushTimeout flush logs with timeout.
func FlushTimeout(timeout time.Duration) { std.FlushTimeout(timeout) }
// FlushDaemon run flush handle on daemon.
//
// Usage please see slog_test.ExampleFlushDaemon()
func FlushDaemon(onStops ...func()) {
std.FlushDaemon(onStops...)
}
// StopDaemon stop flush daemon
func StopDaemon() { std.StopDaemon() }
// SetLogLevel max level for the std logger
func SetLogLevel(l Level) { std.Level = l }
// SetFormatter to std logger
func SetFormatter(f Formatter) { std.Formatter = f }
// GetFormatter of the std logger
func GetFormatter() Formatter { return std.Formatter }
// AddHandler to the std logger
func AddHandler(h Handler) { std.AddHandler(h) }
// PushHandler to the std logger
func PushHandler(h Handler) { std.AddHandler(h) }
// AddHandlers to the std logger
func AddHandlers(hs ...Handler) { std.AddHandlers(hs...) }
// PushHandlers to the std logger
func PushHandlers(hs ...Handler) { std.PushHandlers(hs...) }
// AddProcessor to the logger
func AddProcessor(p Processor) { std.AddProcessor(p) }
// AddProcessors to the logger
func AddProcessors(ps ...Processor) { std.AddProcessors(ps...) }
// -------------------------- New record with log data, fields -----------------------------
// WithExtra new record with extra data
func WithExtra(ext M) *Record {
return std.WithExtra(ext)
}
// WithData new record with data
func WithData(data M) *Record {
return std.WithData(data)
}
// WithValue new record with data value
func WithValue(key string, value any) *Record {
return std.WithValue(key, value)
}
// WithField new record with field.
//
// TIP: add field need config Formatter template fields.
func WithField(name string, value any) *Record {
return std.WithField(name, value)
}
// WithFields new record with fields
//
// TIP: add field need config Formatter template fields.
func WithFields(fields M) *Record {
return std.WithFields(fields)
}
// WithContext new record with context
func WithContext(ctx context.Context) *Record {
return std.WithContext(ctx)
}
// -------------------------- Add log messages with level -----------------------------
// Log logs a message with level
func Log(level Level, args ...any) { std.log(level, args) }
// Print logs a message at level PrintLevel
func Print(args ...any) { std.log(PrintLevel, args) }
// Println logs a message at level PrintLevel
func Println(args ...any) { std.log(PrintLevel, args) }
// Printf logs a message at level PrintLevel
func Printf(format string, args ...any) { std.logf(PrintLevel, format, args) }
// Trace logs a message at level Trace
func Trace(args ...any) { std.log(TraceLevel, args) }
// Tracef logs a message at level Trace
func Tracef(format string, args ...any) { std.logf(TraceLevel, format, args) }
// Info logs a message at level Info
func Info(args ...any) { std.log(InfoLevel, args) }
// Infof logs a message at level Info
func Infof(format string, args ...any) { std.logf(InfoLevel, format, args) }
// Notice logs a message at level Notice
func Notice(args ...any) { std.log(NoticeLevel, args) }
// Noticef logs a message at level Notice
func Noticef(format string, args ...any) { std.logf(NoticeLevel, format, args) }
// Warn logs a message at level Warn
func Warn(args ...any) { std.log(WarnLevel, args) }
// Warnf logs a message at level Warn
func Warnf(format string, args ...any) { std.logf(WarnLevel, format, args) }
// Error logs a message at level Error
func Error(args ...any) { std.log(ErrorLevel, args) }
// Errorf logs a message at level Error
func Errorf(format string, args ...any) { std.logf(ErrorLevel, format, args) }
// ErrorT logs a error type at level Error
func ErrorT(err error) {
if err != nil {
std.log(ErrorLevel, []any{err})
}
}
// EStack logs a error message and with call stack.
// func EStack(args ...any) {
// std.WithExtra(map[string]any{"stack": goinfo.GetCallerInfo(2)}).
// log(ErrorLevel, args)
// }
// Debug logs a message at level Debug
func Debug(args ...any) { std.log(DebugLevel, args) }
// Debugf logs a message at level Debug
func Debugf(format string, args ...any) { std.logf(DebugLevel, format, args) }
// Fatal logs a message at level Fatal
func Fatal(args ...any) { std.log(FatalLevel, args) }
// Fatalf logs a message at level Fatal
func Fatalf(format string, args ...any) { std.logf(FatalLevel, format, args) }
// FatalErr logs a message at level Fatal on err is not nil
func FatalErr(err error) {
if err != nil {
std.log(FatalLevel, []any{err})
}
}
// Panic logs a message at level Panic
func Panic(args ...any) { std.log(PanicLevel, args) }
// Panicf logs a message at level Panic
func Panicf(format string, args ...any) { std.logf(PanicLevel, format, args) }
// PanicErr logs a message at level Panic on err is not nil
func PanicErr(err error) {
if err != nil {
std.log(PanicLevel, []any{err})
}
}