From beae09fdd8aa8abdfad46c86f45c03dafa66b07e Mon Sep 17 00:00:00 2001 From: shenjiachi Date: Fri, 3 Jan 2025 10:59:31 +0800 Subject: [PATCH 1/3] feat:add user egg energy aggregation when user virtual flow change --- ..._virtual_ coin_flow_aggregation_consume.go | 72 ++++++++++++++++++- ...ual_ coin_flow_aggregation_consume_test.go | 28 +++++--- consume/egg_energy_deal_user_ecpm_test.go | 2 +- go.mod | 2 +- 4 files changed, 90 insertions(+), 14 deletions(-) diff --git a/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume.go b/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume.go index c95bd37..12b225e 100644 --- a/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume.go +++ b/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume.go @@ -70,7 +70,7 @@ func handleEggCanalUserVirtualCoinFlowAggregationConsume(msg []byte) error { return err } aggregationDb := implement.NewUserVirtualCoinFlowAggregationDb(db.Db) - now := time.Now() + now := time.Now().AddDate(0, 0, 1) if canalMsg.Data[0].CoinId == utils2.IntToStr(basicSetting.PersonEggEnergyCoinId) { userVirtualCoinFlowAggregation, err1 := aggregationDb.UserVirtualCoinFlowAggregationGetOneByParams(map[string]interface{}{ @@ -100,7 +100,7 @@ func handleEggCanalUserVirtualCoinFlowAggregationConsume(msg []byte) error { amount, _ := decimal.NewFromString(canalMsg.Data[0].Amount) todayData, _ := decimal.NewFromString(userVirtualCoinFlowAggregation.TodayData) thisWeekData, _ := decimal.NewFromString(userVirtualCoinFlowAggregation.ThisWeekData) - thisMonthData, _ := decimal.NewFromString(userVirtualCoinFlowAggregation.ThisWeekData) + thisMonthData, _ := decimal.NewFromString(userVirtualCoinFlowAggregation.ThisMonthData) userVirtualCoinFlowAggregation.TodayData = todayData.Add(amount).String() userVirtualCoinFlowAggregation.ThisWeekData = thisWeekData.Add(amount).String() userVirtualCoinFlowAggregation.ThisMonthData = thisMonthData.Add(amount).String() @@ -110,6 +110,74 @@ func handleEggCanalUserVirtualCoinFlowAggregationConsume(msg []byte) error { return err2 } } + + // 更新 user_egg_energy_aggregation + uid := utils2.StrToInt64(canalMsg.Data[0].Uid) + year, week := now.ISOWeek() + _, month, day := now.Date() + energyAggregationDb := implement.NewUserEggEnergyAggregationDb(db.Db) + energyAggregation, err3 := energyAggregationDb.UserEggEnergyAggregationGetOneByTime(day, week, int(month), year, uid) + if err3 != nil { + return err3 + } + amount, _ := decimal.NewFromString(canalMsg.Data[0].Amount) + if energyAggregation == nil { + // 不存在当天数据 创建新数据 + nowStr := now.Format("2006-01-02 15:04:05") + m := model.UserEggEnergyAggregation{ + Uid: uid, + TodayData: canalMsg.Data[0].Amount, + Day: day, + Week: week, + Month: int(month), + Year: year, + CreateAt: nowStr, + UpdateAt: nowStr, + } + + // 读取最新数据 + lastEnergyAggregation, err4 := energyAggregationDb.UserEggEnergyAggregationGetLastOneByUid(uid) + if err4 != nil { + return err4 + } + // 判断是否上条数据是否在本周 + if lastEnergyAggregation != nil { + if lastEnergyAggregation.Week == week && lastEnergyAggregation.Year == year { + // 周数相同 累加上周数据 + thisWeekData, _ := decimal.NewFromString(lastEnergyAggregation.ThisWeekData) + m.ThisWeekData = thisWeekData.Add(amount).String() + } else { + m.ThisWeekData = amount.String() + } + if lastEnergyAggregation.Month == int(month) && lastEnergyAggregation.Year == year { + // 月份相同 累加上月数据 + thisMonthData, _ := decimal.NewFromString(lastEnergyAggregation.ThisMonthData) + m.ThisMonthData = thisMonthData.Add(amount).String() + } else { + m.ThisMonthData = amount.String() + } + } else { + m.ThisWeekData = amount.String() + m.ThisMonthData = amount.String() + } + + _, err5 := energyAggregationDb.UserEggEnergyAggregationInsert(&m) + if err5 != nil { + return err5 + } + } else { + // 存在当天数据累加数据 + todayData, _ := decimal.NewFromString(energyAggregation.TodayData) + thisWeekData, _ := decimal.NewFromString(energyAggregation.ThisWeekData) + thisMonthData, _ := decimal.NewFromString(energyAggregation.ThisMonthData) + energyAggregation.TodayData = todayData.Add(amount).String() + energyAggregation.ThisWeekData = thisWeekData.Add(amount).String() + energyAggregation.ThisMonthData = thisMonthData.Add(amount).String() + _, err5 := energyAggregationDb.UserEggEnergyAggregationUpdate(energyAggregation.Id, energyAggregation, "today_data", "this_week_data", "this_month_data") + if err5 != nil { + return err5 + } + } } } return nil diff --git a/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume_test.go b/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume_test.go index aa9c28f..16405af 100644 --- a/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume_test.go +++ b/consume/egg_cannal_user_virtual_ coin_flow_aggregation_consume_test.go @@ -1,21 +1,34 @@ package consume import ( + "applet/app/cfg" + "applet/app/db" "applet/consume/md" - md2 "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule/egg_energy/md" - "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit" + "encoding/json" "testing" "time" ) func TestSendMessageToUserVirtualCoinFlowAggregationConsume(t *testing.T) { + dbcfg := cfg.DBCfg{ + Host: "119.23.182.117:3306", + Name: "egg", + User: "root", + Psw: "Fnuo123com@", + ShowLog: true, + MaxLifetime: 30, + MaxOpenConns: 100, + MaxIdleConns: 100, + Path: "tmp/%s.log", + } + db.InitDB(&dbcfg) data := md.CanalUserVirtualCoinFlowAggregation{ Id: "1", Uid: "19", CoinId: "1", Direction: "1", Title: "兑换到个人蛋蛋能量", - Amount: "40", + Amount: "20", BeforeAmount: "0", AfterAmount: "80", SysFee: "0", @@ -35,15 +48,10 @@ func TestSendMessageToUserVirtualCoinFlowAggregationConsume(t *testing.T) { Type: "INSERT", } - err := rabbit.Init("120.77.153.180", "5672", "guest", "guest") - if err != nil { - return - } - ch, err := rabbit.Cfg.Pool.GetChannel() + m, _ := json.Marshal(message) + err := handleEggCanalUserVirtualCoinFlowAggregationConsume(m) if err != nil { return } - defer ch.Release() - ch.Publish(md2.EggCanalExchange, message, "egg_canal_user_virtual_coin_flow") } diff --git a/consume/egg_energy_deal_user_ecpm_test.go b/consume/egg_energy_deal_user_ecpm_test.go index df82039..5cc684d 100644 --- a/consume/egg_energy_deal_user_ecpm_test.go +++ b/consume/egg_energy_deal_user_ecpm_test.go @@ -16,7 +16,7 @@ func TestHandleEggEnergyDealUserECPMConsume(t *testing.T) { Ecpm: "101.4", } bytes, err := json.Marshal(m) - err = handleTemporaryEggEnergyDealUserECPMConsume(bytes) + err = handleTemporaryEggEnergyDealUserECPMConsume(bytes, nil) if err != nil { fmt.Println(err) return diff --git a/go.mod b/go.mod index 44a2192..5d00aed 100644 --- a/go.mod +++ b/go.mod @@ -2,7 +2,7 @@ module applet go 1.19 -// replace code.fnuoos.com/EggPlanet/egg_models.git => E:/company/Egg/egg_models +replace code.fnuoos.com/EggPlanet/egg_models.git => E:/company/Egg/egg_models // replace code.fnuoos.com/EggPlanet/egg_system_rules.git => E:/company/Egg/egg_system_rules From 5bd69cf118cf29fdcb871bfa56a7f407ad42a445 Mon Sep 17 00:00:00 2001 From: shenjiachi Date: Fri, 3 Jan 2025 11:03:06 +0800 Subject: [PATCH 2/3] fix: update model version --- go.mod | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/go.mod b/go.mod index 5d00aed..4088164 100644 --- a/go.mod +++ b/go.mod @@ -2,12 +2,12 @@ module applet go 1.19 -replace code.fnuoos.com/EggPlanet/egg_models.git => E:/company/Egg/egg_models +// replace code.fnuoos.com/EggPlanet/egg_models.git => E:/company/Egg/egg_models // replace code.fnuoos.com/EggPlanet/egg_system_rules.git => E:/company/Egg/egg_system_rules require ( - code.fnuoos.com/EggPlanet/egg_models.git v0.2.1-0.20250102033457-e7921b94d2fb + code.fnuoos.com/EggPlanet/egg_models.git v0.2.1-0.20250103030157-3dd56831ac87 code.fnuoos.com/EggPlanet/egg_system_rules.git v0.0.4-0.20250102013515-7dc14a5d08f2 code.fnuoos.com/go_rely_warehouse/zyos_go_es.git v1.0.1-0.20241118083738-0f22da9ba0be code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git v0.0.5 From 0d49358106a73b1e5e52adf4a2dafb14fc4930b5 Mon Sep 17 00:00:00 2001 From: dengbiao Date: Fri, 3 Jan 2025 15:19:42 +0800 Subject: [PATCH 3/3] update --- ...public_platoon_user_relation_commission.go | 42 +++++++++++-------- go.mod | 4 +- 2 files changed, 26 insertions(+), 20 deletions(-) diff --git a/consume/add_public_platoon_user_relation_commission.go b/consume/add_public_platoon_user_relation_commission.go index 4d946d5..2d96ed3 100644 --- a/consume/add_public_platoon_user_relation_commission.go +++ b/consume/add_public_platoon_user_relation_commission.go @@ -85,25 +85,31 @@ func handleAddPublicPlatoonUserRelationCommissionConsume(msgData []byte) error { return err } if eggEnergyBasicSetting != nil { - var newUserRewardRules *md2.NewUserRewardRules - err = json.Unmarshal([]byte(eggEnergyBasicSetting.NewUserIncentiveRules), &newUserRewardRules) - if err != nil { - fmt.Println("handleAddPublicPlatoonUserRelationCommissionConsume___ERR>>>>", err.Error()) - } - rewardValue := newUserRewardRules.InviteUserRewardValue - session := db.Db.NewSession() - err = rule.DealUserVirtualCoin(session, md3.DealUserVirtualCoinReq{ - Kind: "add", - Title: enum.UserVirtualAmountFlowTransferType.String(enum.EggEnergyRecruitNewUsersReward), - TransferType: int(enum.EggEnergyRecruitNewUsersReward), - CoinId: eggEnergyBasicSetting.PersonEggPointsCoinId, - Uid: utils.StrToInt64(msg.RecommendUid), - Amount: float64(rewardValue), - }) - if err != nil { - return err + userDeleteInfoDb := implement.NewUserDeleteInfoDb(db.Db) + fmt.Println("userDelete>>>>>>>>>>>>>>>", msg.Phone) + userDelete := userDeleteInfoDb.GetUserDeleteInfo(msg.Phone) + fmt.Println("userDelete>>>>>>>>>>>>>>>", userDelete) + if userDelete == nil { + var newUserRewardRules *md2.NewUserRewardRules + err = json.Unmarshal([]byte(eggEnergyBasicSetting.NewUserIncentiveRules), &newUserRewardRules) + if err != nil { + fmt.Println("handleAddPublicPlatoonUserRelationCommissionConsume___ERR>>>>", err.Error()) + } + rewardValue := newUserRewardRules.InviteUserRewardValue + session := db.Db.NewSession() + err = rule.DealUserVirtualCoin(session, md3.DealUserVirtualCoinReq{ + Kind: "add", + Title: enum.UserVirtualAmountFlowTransferType.String(enum.EggEnergyRecruitNewUsersReward), + TransferType: int(enum.EggEnergyRecruitNewUsersReward), + CoinId: eggEnergyBasicSetting.PersonEggPointsCoinId, + Uid: utils.StrToInt64(msg.RecommendUid), + Amount: float64(rewardValue), + }) + if err != nil { + return err + } + session.Commit() } - session.Commit() } return nil } diff --git a/go.mod b/go.mod index 4088164..fe7a0da 100644 --- a/go.mod +++ b/go.mod @@ -7,8 +7,8 @@ go 1.19 // replace code.fnuoos.com/EggPlanet/egg_system_rules.git => E:/company/Egg/egg_system_rules require ( - code.fnuoos.com/EggPlanet/egg_models.git v0.2.1-0.20250103030157-3dd56831ac87 - code.fnuoos.com/EggPlanet/egg_system_rules.git v0.0.4-0.20250102013515-7dc14a5d08f2 + code.fnuoos.com/EggPlanet/egg_models.git v0.2.1-0.20250103070955-c99c05f090ab + code.fnuoos.com/EggPlanet/egg_system_rules.git v0.0.4-0.20250103065342-d24e5cb92e4b code.fnuoos.com/go_rely_warehouse/zyos_go_es.git v1.0.1-0.20241118083738-0f22da9ba0be code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git v0.0.5 github.com/boombuler/barcode v1.0.1