2 Star 0 Fork 0

TeamsHub/backend-gopkg

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
zapgorm.go 3.70 KB
一键复制 编辑 原始数据 按行查看 历史
HCY 提交于 2024-05-10 12:41 . c
package log
//
//import (
// "context"
// "errors"
// "fmt"
// "path/filepath"
// "runtime"
// "strings"
// "time"
//
// "go.uber.org/zap"
// "go.uber.org/zap/zapcore"
// "gorm.io/gorm"
// gormlogger "gorm.io/gorm/logger"
//)
//
//type ContextFn func(ctx context.Context) []zapcore.Field
//
//type GormLogger struct {
// ZapLogger *zap.Logger
// LogLevel gormlogger.LogLevel
// SlowThreshold time.Duration
// SkipCallerLookup bool
// IgnoreRecordNotFoundError bool
// Context ContextFn
//}
//
//func New(zapLogger *zap.Logger) GormLogger {
// return GormLogger{
// ZapLogger: zapLogger,
// LogLevel: gormlogger.Info,
// SlowThreshold: 100 * time.Millisecond,
// SkipCallerLookup: false,
// IgnoreRecordNotFoundError: false,
// Context: nil,
// }
//}
//
//func (l GormLogger) SetAsDefault() {
// gormlogger.Default = l
//}
//
//func (l GormLogger) LogMode(level gormlogger.LogLevel) gormlogger.Interface {
// return GormLogger{
// ZapLogger: l.ZapLogger,
// SlowThreshold: l.SlowThreshold,
// LogLevel: level,
// SkipCallerLookup: l.SkipCallerLookup,
// IgnoreRecordNotFoundError: l.IgnoreRecordNotFoundError,
// Context: l.Context,
// }
//}
//
//func (l GormLogger) Info(ctx context.Context, str string, args ...interface{}) {
// //if l.LogLevel < gormlogger.Info {
// // return
// //}
// l.logger(ctx).Sugar().Debugf(str, args...)
// fmt.Println("cccccccccc")
// NewSlsLogFormPrintf(zapcore.InfoLevel.String(), str, args...)
//}
//
//func (l GormLogger) Warn(ctx context.Context, str string, args ...interface{}) {
// //if l.LogLevel < gormlogger.Warn {
// // return
// //}
// l.logger(ctx).Sugar().Warnf(str, args...)
// NewSlsLogFormPrintf(zapcore.WarnLevel.String(), str, args...)
//}
//
//func (l GormLogger) Error(ctx context.Context, str string, args ...interface{}) {
// //if l.LogLevel < gormlogger.Error {
// // return
// //}
// l.logger(ctx).Sugar().Errorf(str, args...)
// NewSlsLogFormPrintf(zapcore.ErrorLevel.String(), str, args...)
//}
//
//func (l GormLogger) Trace(ctx context.Context, begin time.Time, fc func() (string, int64), err error) {
// //if l.LogLevel <= 0 {
// // return
// //}
// elapsed := time.Since(begin)
// logger := l.logger(ctx)
// switch {
// case err != nil && l.LogLevel >= gormlogger.Error && (!l.IgnoreRecordNotFoundError || !errors.Is(err, gorm.ErrRecordNotFound)):
// sql, rows := fc()
// logger.Error("trace", zap.Error(err), zap.Duration("elapsed", elapsed), zap.Int64("rows", rows), zap.String("sql", sql))
// case l.SlowThreshold != 0 && elapsed > l.SlowThreshold && l.LogLevel >= gormlogger.Warn:
// sql, rows := fc()
// logger.Warn("trace", zap.Duration("elapsed", elapsed), zap.Int64("rows", rows), zap.String("sql", sql))
// case l.LogLevel >= gormlogger.Info:
// sql, rows := fc()
// logger.Debug("trace", zap.Duration("elapsed", elapsed), zap.Int64("rows", rows), zap.String("sql", sql))
// }
//}
//
//var (
// gormPackage = filepath.Join("gorm.io", "gorm")
// zapgormPackage = filepath.Join("moul.io", "zapgorm2")
//)
//
//func (l GormLogger) logger(ctx context.Context) *zap.Logger {
// logger := l.ZapLogger
// if l.Context != nil {
// fields := l.Context(ctx)
// logger = logger.With(fields...)
// }
//
// if l.SkipCallerLookup {
// return logger
// }
//
// for i := 2; i < 15; i++ {
// _, file, _, ok := runtime.Caller(i)
// switch {
// case !ok:
// case strings.HasSuffix(file, "_test.go"):
// case strings.Contains(file, gormPackage):
// case strings.Contains(file, zapgormPackage):
// default:
// return logger.WithOptions(zap.AddCallerSkip(i))
// }
// }
// return logger
//}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wuzheng0709/backend-gopkg.git
git@gitee.com:wuzheng0709/backend-gopkg.git
wuzheng0709
backend-gopkg
backend-gopkg
v1.6.7

搜索帮助