1. Bug修复: - 修复Markdown星号/下划线在小程序端原样显示问题(markdownToHtml增加__和_支持,contentParser增加Markdown格式剥离) - 修复@提及无反应(MentionSuggestion使用ref保持persons最新值,解决闭包捕获空数组问题) - 修复#链接标签点击"未找到小程序配置"(增加appId直接跳转降级路径) 2. 分享功能优化: - "分享到朋友圈"改为"分享给好友"(open-type从shareTimeline改为share) - 90%收益提示移到分享按钮下方 - 阅读20%后向上滑动弹出分享浮层提示(4秒自动消失) 3. 代付功能: - 后端:新增UserBalance/BalanceTransaction/GiftUnlock三个模型 - 后端:新增8个余额相关API(查询/充值/充值确认/代付/领取/退款/交易记录/礼物信息) - 小程序:阅读页新增"代付分享"按钮,支持用余额为好友解锁章节 - 分享链接携带gift参数,好友打开自动领取解锁 Made-with: Cursor
119 lines
3.9 KiB
Go
119 lines
3.9 KiB
Go
package database
|
||
|
||
import (
|
||
"log"
|
||
"os"
|
||
"strconv"
|
||
"strings"
|
||
"time"
|
||
|
||
"soul-api/internal/model"
|
||
|
||
"gorm.io/driver/mysql"
|
||
"gorm.io/gorm"
|
||
"gorm.io/gorm/logger"
|
||
)
|
||
|
||
var db *gorm.DB
|
||
|
||
// Init 使用 DSN 连接 MySQL,供 handler 通过 DB() 使用
|
||
func Init(dsn string) error {
|
||
// 慢查询阈值:默认 5 秒,避免 GORM 默认 200ms 导致控制台刷屏;可通过 SLOW_SQL_THRESHOLD_MS 覆盖
|
||
slowMs := 5000
|
||
if s := os.Getenv("SLOW_SQL_THRESHOLD_MS"); s != "" {
|
||
if n, e := strconv.Atoi(s); e == nil && n > 0 {
|
||
slowMs = n
|
||
}
|
||
}
|
||
gormLogger := logger.New(
|
||
log.New(os.Stdout, "\r\n", log.LstdFlags),
|
||
logger.Config{
|
||
SlowThreshold: time.Duration(slowMs) * time.Millisecond,
|
||
IgnoreRecordNotFoundError: true,
|
||
Colorful: true,
|
||
},
|
||
)
|
||
|
||
var err error
|
||
db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{Logger: gormLogger})
|
||
if err != nil {
|
||
return err
|
||
}
|
||
|
||
skipMigrate := strings.ToLower(strings.TrimSpace(os.Getenv("SKIP_AUTO_MIGRATE")))
|
||
if skipMigrate == "1" || skipMigrate == "true" || skipMigrate == "yes" {
|
||
log.Println("database: SKIP_AUTO_MIGRATE enabled, skipping schema migration")
|
||
log.Println("database: connected")
|
||
return nil
|
||
}
|
||
|
||
if err := db.AutoMigrate(&model.WechatCallbackLog{}); err != nil {
|
||
log.Printf("database: wechat_callback_logs migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.Withdrawal{}); err != nil {
|
||
log.Printf("database: withdrawals migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.MatchRecord{}); err != nil {
|
||
log.Printf("database: match_records migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.UserAddress{}); err != nil {
|
||
log.Printf("database: user_addresses migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.VipRole{}); err != nil {
|
||
log.Printf("database: vip_roles migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.Order{}); err != nil {
|
||
log.Printf("database: orders migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.Mentor{}); err != nil {
|
||
log.Printf("database: mentors migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.MentorConsultation{}); err != nil {
|
||
log.Printf("database: mentor_consultations migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.AuthorConfig{}); err != nil {
|
||
log.Printf("database: author_config migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.AdminUser{}); err != nil {
|
||
log.Printf("database: admin_users migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.CkbSubmitRecord{}); err != nil {
|
||
log.Printf("database: ckb_submit_records migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.CkbLeadRecord{}); err != nil {
|
||
log.Printf("database: ckb_lead_records migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.Person{}); err != nil {
|
||
log.Printf("database: persons migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.LinkTag{}); err != nil {
|
||
log.Printf("database: link_tags migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.UserBalance{}); err != nil {
|
||
log.Printf("database: user_balances migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.BalanceTransaction{}); err != nil {
|
||
log.Printf("database: balance_transactions migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.GiftUnlock{}); err != nil {
|
||
log.Printf("database: gift_unlocks migrate warning: %v", err)
|
||
}
|
||
// 以下表业务大量使用,必须参与 AutoMigrate,否则旧库缺字段会导致订单/用户/VIP 等接口报错
|
||
if err := db.AutoMigrate(&model.User{}); err != nil {
|
||
log.Printf("database: users migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.SystemConfig{}); err != nil {
|
||
log.Printf("database: system_config migrate warning: %v", err)
|
||
}
|
||
if err := db.AutoMigrate(&model.Chapter{}); err != nil {
|
||
log.Printf("database: chapters migrate warning: %v", err)
|
||
}
|
||
log.Println("database: connected")
|
||
return nil
|
||
}
|
||
|
||
// DB 返回全局 *gorm.DB,仅在 Init 成功后调用
|
||
func DB() *gorm.DB {
|
||
return db
|
||
}
|