5 Commits

Author SHA1 Message Date
zhaoyupeng
42331cde57 chore: add init db debug log 2025-10-31 22:23:35 +08:00
zhaoyupeng
36fd04cac9 feat: 修改 middleware logger 的格式 2025-08-08 15:46:55 +08:00
zhaoyupeng
956cf69a82 feat: 添加 resp RC 2025-08-06 15:57:49 +08:00
zhaoyupeng
61a115852e fix: 修复 resp RE 返回时 error 问题 2025-07-23 10:32:47 +08:00
zhaoyupeng
bb5dd2583d feat: 修改了 logger ctx 的 key
feat: logger trace-value 的格式
2025-07-18 09:52:30 +08:00
6 changed files with 52 additions and 34 deletions

View File

@@ -5,21 +5,21 @@ import (
)
func TestNew(t *testing.T) {
//mdb, err := New(WithMysql("127.0.0.1", 3306, "root", "MyPassw0rd", "mydb"))
//if err != nil {
// t.Fatal(err)
//}
//
//type User struct {
// Id uint64 `gorm:"primaryKey"`
// Username string `gorm:"unique"`
//}
//
//if err = mdb.Session(t.Context()).AutoMigrate(&User{}); err != nil {
// t.Fatal(err)
//}
//
//if err = mdb.Session(t.Context()).Create(&User{Username: "zyp"}).Error; err != nil {
// t.Fatal(err)
//}
mdb, err := New(WithMysql("127.0.0.1", 2881, "yizhi@test", "yizhi", "mie"))
if err != nil {
t.Fatal(err)
}
type User struct {
Id uint64 `gorm:"primaryKey"`
Username string `gorm:"unique"`
}
if err = mdb.Session(t.Context()).AutoMigrate(&User{}); err != nil {
t.Fatal(err)
}
if err = mdb.Session(t.Context()).Create(&User{Username: "zyp"}).Error; err != nil {
t.Fatal(err)
}
}

View File

@@ -3,6 +3,8 @@ package db
import (
"context"
"fmt"
"gitea.loveuer.com/yizhisec/packages/logger"
)
type config struct {
@@ -25,6 +27,7 @@ func WithCtx(ctx context.Context) OptionFn {
func WithMysql(host string, port int, user string, password string, database string) OptionFn {
return func(c *config) {
dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8mb4&parseTime=True&loc=Local", user, password, host, port, database)
logger.Debug("db init with mysql, dsn: %s", dsn)
c.mysql = &dsn
}
}
@@ -32,6 +35,7 @@ func WithMysql(host string, port int, user string, password string, database str
func WithPg(host string, port int, user string, password string, database string) OptionFn {
return func(c *config) {
dsn := fmt.Sprintf("host=%s user=%s password=%s dbname=%s port=%d sslmode=disable TimeZone=Asia/Shanghai", host, user, password, database, port)
logger.Debug("db init with pg, dsn: %s", dsn)
c.pg = &dsn
}
}
@@ -39,6 +43,7 @@ func WithPg(host string, port int, user string, password string, database string
func WithSqlite(path string) OptionFn {
return func(c *config) {
if path != "" {
logger.Debug("db init with sqlite, path: %s", path)
c.sqlite = &path
}
}

View File

@@ -2,17 +2,20 @@ package logger
import (
"context"
"gitea.loveuer.com/yizhisec/packages/opt"
uuid2 "github.com/google/uuid"
)
type _traceId struct{}
var TraceId = _traceId{}
func traceId(ctx context.Context) string {
if ctx == nil {
uuid, _ := uuid2.NewV7()
return uuid.String()
}
if id, _ := ctx.Value(opt.TraceKey).(string); id != "" {
if id, _ := ctx.Value(TraceId).(string); id != "" {
return id
}
@@ -21,30 +24,30 @@ func traceId(ctx context.Context) string {
}
func DebugCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Debug(msg, data...)
}
func InfoCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Info(msg, data...)
}
func WarnCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Warn(msg, data...)
}
func ErrorCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Error(msg, data...)
}
func PanicCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Panic(msg, data...)
}
func FatalCtx(ctx context.Context, msg string, data ...any) {
msg = "[" + traceId(ctx) + "] " + msg
msg = traceId(ctx) + " | " + msg
DefaultLogger.Fatal(msg, data...)
}

View File

@@ -2,7 +2,6 @@ package logger
import (
"context"
"gitea.loveuer.com/yizhisec/packages/opt"
"testing"
)
@@ -11,7 +10,7 @@ func TestCtxLog(t *testing.T) {
InfoCtx(nil, "hello %s", "world")
WarnCtx(context.Background(), "hello %s", "world")
ctx := context.Background()
ctx = context.WithValue(ctx, opt.TraceKey, "value")
ctx = context.WithValue(ctx, TraceId, "value")
SetLogLevel(LogLevelDebug)
DebugCtx(ctx, "hello %s", "world")
ErrorCtx(ctx, "hello %s", "world")

View File

@@ -53,9 +53,8 @@ func New() gin.HandlerFunc {
b := stringBuilderPool.Get().(*strings.Builder)
b.Reset()
b.WriteString("[")
b.WriteString(fmt.Sprintf("%36s", trace))
b.WriteString("] | ")
b.WriteString(" | ")
b.WriteString(fmt.Sprintf("%3d", status))
b.WriteString(" | ")
b.WriteString(fmt.Sprintf("%15s", ip))

View File

@@ -30,6 +30,18 @@ func R200(c *gin.Context, data any, msgs ...string) {
c.AbortWithStatusJSON(200, r)
}
func RC(c *gin.Context, status int, args ...any) {
code := 1
if status != 200 {
code = -1
}
_r(c, &res{
Status: status,
Code: code,
}, args...)
}
func RE(c *gin.Context, err error) {
var re *Error
@@ -68,11 +80,7 @@ H4:
r.Code = code
}
H3:
if es, ok := args[2].(error); ok {
r.Err = es.Error()
} else {
r.Err = args[2]
}
H2:
r.Data = args[1]
H1:
@@ -86,6 +94,10 @@ END:
r.Msg = Msg(r.Status)
}
if ce, ok := r.Err.(error); ok {
r.Err = ce.Error()
}
c.AbortWithStatusJSON(r.Status, r)
}