2021-03-14 15:36:00 +08:00
|
|
|
package log
|
|
|
|
|
|
|
|
import (
|
2021-06-03 16:56:55 +08:00
|
|
|
"context"
|
2021-03-14 15:36:00 +08:00
|
|
|
"runtime"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
2021-05-01 01:15:30 +08:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2021-08-31 10:14:57 +08:00
|
|
|
defaultDepth = 3
|
2021-05-01 01:15:30 +08:00
|
|
|
// DefaultCaller is a Valuer that returns the file and line.
|
2021-08-31 10:14:57 +08:00
|
|
|
DefaultCaller = Caller(defaultDepth)
|
2021-05-01 01:15:30 +08:00
|
|
|
|
|
|
|
// DefaultTimestamp is a Valuer that returns the current wallclock time.
|
|
|
|
DefaultTimestamp = Timestamp(time.RFC3339)
|
2021-03-14 15:36:00 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// Valuer is returns a log value.
|
2021-06-03 16:56:55 +08:00
|
|
|
type Valuer func(ctx context.Context) interface{}
|
2021-03-14 15:36:00 +08:00
|
|
|
|
|
|
|
// Value return the function value.
|
2021-06-03 16:56:55 +08:00
|
|
|
func Value(ctx context.Context, v interface{}) interface{} {
|
2021-03-14 15:36:00 +08:00
|
|
|
if v, ok := v.(Valuer); ok {
|
2021-06-03 16:56:55 +08:00
|
|
|
return v(ctx)
|
2021-03-14 15:36:00 +08:00
|
|
|
}
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
// Caller returns returns a Valuer that returns a pkg/file:line description of the caller.
|
|
|
|
func Caller(depth int) Valuer {
|
2021-06-03 16:56:55 +08:00
|
|
|
return func(context.Context) interface{} {
|
2022-01-17 21:00:22 +08:00
|
|
|
d := depth
|
|
|
|
_, file, line, _ := runtime.Caller(d)
|
2021-06-14 11:12:58 +08:00
|
|
|
if strings.LastIndex(file, "/log/filter.go") > 0 {
|
2022-01-17 21:00:22 +08:00
|
|
|
d++
|
|
|
|
_, file, line, _ = runtime.Caller(d)
|
2021-06-14 10:25:59 +08:00
|
|
|
}
|
2021-06-14 11:12:58 +08:00
|
|
|
if strings.LastIndex(file, "/log/helper.go") > 0 {
|
2022-01-17 21:00:22 +08:00
|
|
|
d++
|
|
|
|
_, file, line, _ = runtime.Caller(d)
|
2021-06-14 00:35:39 +08:00
|
|
|
}
|
2021-03-14 15:36:00 +08:00
|
|
|
idx := strings.LastIndexByte(file, '/')
|
|
|
|
return file[idx+1:] + ":" + strconv.Itoa(line)
|
|
|
|
}
|
|
|
|
}
|
2021-05-01 01:15:30 +08:00
|
|
|
|
|
|
|
// Timestamp returns a timestamp Valuer with a custom time format.
|
|
|
|
func Timestamp(layout string) Valuer {
|
2021-06-03 16:56:55 +08:00
|
|
|
return func(context.Context) interface{} {
|
2021-05-01 01:15:30 +08:00
|
|
|
return time.Now().Format(layout)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-03 16:56:55 +08:00
|
|
|
func bindValues(ctx context.Context, keyvals []interface{}) {
|
2021-05-01 01:15:30 +08:00
|
|
|
for i := 1; i < len(keyvals); i += 2 {
|
|
|
|
if v, ok := keyvals[i].(Valuer); ok {
|
2021-06-03 16:56:55 +08:00
|
|
|
keyvals[i] = v(ctx)
|
2021-05-01 01:15:30 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func containsValuer(keyvals []interface{}) bool {
|
|
|
|
for i := 1; i < len(keyvals); i += 2 {
|
|
|
|
if _, ok := keyvals[i].(Valuer); ok {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|