package logc import ( "context" "fmt" "github.com/zeromicro/go-zero/core/logx" ) type ( LogConf = logx.LogConf LogField = logx.LogField ) // AddGlobalFields adds global fields. func AddGlobalFields(fields ...LogField) { logx.AddGlobalFields(fields...) } // Alert alerts v in alert level, and the message is written to error log. func Alert(_ context.Context, v string) { logx.Alert(v) } // Close closes the logging. func Close() error { return logx.Close() } // Error writes v into error log. func Error(ctx context.Context, v ...interface{}) { getLogger(ctx).Error(v...) } // Errorf writes v with format into error log. func Errorf(ctx context.Context, format string, v ...interface{}) { getLogger(ctx).Errorf(fmt.Errorf(format, v...).Error()) } // Errorv writes v into error log with json content. // No call stack attached, because not elegant to pack the messages. func Errorv(ctx context.Context, v interface{}) { getLogger(ctx).Errorv(v) } // Errorw writes msg along with fields into error log. func Errorw(ctx context.Context, msg string, fields ...LogField) { getLogger(ctx).Errorw(msg, fields...) } // Field returns a LogField for the given key and value. func Field(key string, value interface{}) LogField { return logx.Field(key, value) } // Info writes v into access log. func Info(ctx context.Context, v ...interface{}) { getLogger(ctx).Info(v...) } // Infof writes v with format into access log. func Infof(ctx context.Context, format string, v ...interface{}) { getLogger(ctx).Infof(format, v...) } // Infov writes v into access log with json content. func Infov(ctx context.Context, v interface{}) { getLogger(ctx).Infov(v) } // Infow writes msg along with fields into access log. func Infow(ctx context.Context, msg string, fields ...LogField) { getLogger(ctx).Infow(msg, fields...) } // Must checks if err is nil, otherwise logs the error and exits. func Must(err error) { logx.Must(err) } // MustSetup sets up logging with given config c. It exits on error. func MustSetup(c logx.LogConf) { logx.MustSetup(c) } // SetLevel sets the logging level. It can be used to suppress some logs. func SetLevel(level uint32) { logx.SetLevel(level) } // SetUp sets up the logx. If already set up, just return nil. // we allow SetUp to be called multiple times, because for example // we need to allow different service frameworks to initialize logx respectively. // the same logic for SetUp func SetUp(c LogConf) error { return logx.SetUp(c) } // Slow writes v into slow log. func Slow(ctx context.Context, v ...interface{}) { getLogger(ctx).Slow(v...) } // Slowf writes v with format into slow log. func Slowf(ctx context.Context, format string, v ...interface{}) { getLogger(ctx).Slowf(format, v...) } // Slowv writes v into slow log with json content. func Slowv(ctx context.Context, v interface{}) { getLogger(ctx).Slowv(v) } // Sloww writes msg along with fields into slow log. func Sloww(ctx context.Context, msg string, fields ...LogField) { getLogger(ctx).Sloww(msg, fields...) } // getLogger returns the logx.Logger with the given ctx and correct caller. func getLogger(ctx context.Context) logx.Logger { return logx.WithContext(ctx).WithCallerSkip(1) }