|
- package egg_energy
-
- import (
- "code.fnuoos.com/EggPlanet/egg_models.git/src/implement"
- "code.fnuoos.com/EggPlanet/egg_models.git/src/model"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/enum"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/md"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule"
- md2 "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule/egg_energy/md"
- egg_system_rules "code.fnuoos.com/EggPlanet/egg_system_rules.git/utils"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/utils/cache"
- zhios_order_relate_logx "code.fnuoos.com/EggPlanet/egg_system_rules.git/utils/logx"
- "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit"
- "encoding/json"
- "errors"
- "fmt"
- "github.com/shopspring/decimal"
- "strings"
- "time"
- "xorm.io/xorm"
- )
-
- // SettlementGiveActivityCoin 结算观看激励广告得到蛋蛋积分
- func SettlementGiveActivityCoin(engine *xorm.Engine, uid int64, ch *rabbit.Channel) (err error) {
- //1、查找 `egg_energy_basic_setting` 基础设置
- eggEnergyBasicSettingDb := implement.NewEggEnergyBasicSettingDb(engine)
- eggEnergyBasicSetting, err := eggEnergyBasicSettingDb.EggEnergyBasicSettingGetOneByParams(map[string]interface{}{
- "key": "is_open",
- "value": 1,
- })
- if err != nil {
- return
- }
- if eggEnergyBasicSetting == nil {
- err = errors.New("蛋蛋能量设置未开启!")
- return
- }
- if eggEnergyBasicSetting.VideoRewardIsOpen == 1 {
- var videoRewardSystem *md2.VideoRewardSystemStruct
- err = json.Unmarshal([]byte(eggEnergyBasicSetting.VideoRewardSystem), &videoRewardSystem)
- if err != nil {
- return
- }
- if videoRewardSystem.RewardValue == "" || videoRewardSystem.RewardTotalNum == "" || videoRewardSystem.IntervalMinutes == "" || videoRewardSystem.EachRoundHour == "" {
- err = errors.New("视屏奖励机制设置未完全!")
- return
- }
- var rewardSystem []*md2.RewardSystemStruct
- err = json.Unmarshal([]byte(eggEnergyBasicSetting.RewardSystem), &rewardSystem)
- if err != nil {
- return
- }
- if len(rewardSystem) == 0 {
- err = errors.New("未设置奖励机制!")
- return
- }
- rewardValue := egg_system_rules.StrToFloat64(videoRewardSystem.RewardValue) //奖励多少个活跃积分
- var rewardSystemMap = map[int]*md2.RewardSystemStruct{}
- for _, v := range rewardSystem {
- rewardSystemMap[v.Level] = v
- }
- publicPlatoonUserRelationDb := implement.NewPublicPlatoonUserRelationDb(engine)
- publicPlatoonUserRelation, err1 := publicPlatoonUserRelationDb.PublicPlatoonUserRelationGetOneByParams(map[string]interface{}{
- "key": "uid",
- "value": uid,
- })
- if err1 != nil {
- return err1
- }
-
- var rewardFather []struct {
- Uid int64 `json:"uid"` //用户id
- RewardValue float64 `json:"reward_value"` //奖励值
- }
-
- var fatherUids []string
- if publicPlatoonUserRelation != nil {
- fatherUids = strings.Split(publicPlatoonUserRelation.FatherUid, "-")
- }
- for k, id := range fatherUids {
- tmpOneCirclesPublicPlatoonUserRelation, err11 := publicPlatoonUserRelationDb.PublicPlatoonUserRelationGetOneByParams(map[string]interface{}{
- "key": "id",
- "value": id,
- })
- if err11 != nil {
- return err11
- }
- if tmpOneCirclesPublicPlatoonUserRelation == nil {
- continue
- }
- if tmpOneCirclesPublicPlatoonUserRelation.Uid <= 0 {
- //待填充位
- continue
- }
-
- fatherUid := egg_system_rules.Int64ToStr(tmpOneCirclesPublicPlatoonUserRelation.Uid)
- fatherReward := rewardSystemMap[k+1]
- //TODO::判断是否活跃
- var m model.EggSignIn
- has, err33 := engine.Where("uid =?", fatherUid).And("end_time >=?", time.Now().Format("2006-01-02 15:04:05")).Get(&m)
- if err33 != nil {
- return err33
- }
- if !has {
- //不活跃不需要奖励
- continue
- }
- //判断是否满足奖励条件
- userRelateDb := implement.NewUserRelateDb(engine)
- userCount, _, err2 := userRelateDb.SumUserRelateByParentUid(fatherUid)
- if err2 != nil {
- return err2
- }
-
- if fatherReward != nil && userCount >= egg_system_rules.StrToInt64(fatherReward.RewardCondition) {
- fatherRewardValue := rewardValue * (egg_system_rules.StrToFloat64(fatherReward.RewardValue) / 100)
- rewardFather = append(rewardFather, struct {
- Uid int64 `json:"uid"` //用户id
- RewardValue float64 `json:"reward_value"` //奖励值
- }{
- Uid: egg_system_rules.StrToInt64(fatherUid),
- RewardValue: fatherRewardValue,
- })
- }
- }
-
- //增加 egg_user_watch_records 记录
- eggEnergyUserWatchRecordsDb := implement.NewEggEnergyUserWatchRecordsDb(engine)
- eggEnergyUserWatchRecords, err1 := eggEnergyUserWatchRecordsDb.EggEnergyUserWatchRecordsGetOneByParams(map[string]interface{}{
- "key": "uid",
- "value": uid,
- })
- if err1 != nil {
- return err1
- }
- now := time.Now()
- if eggEnergyUserWatchRecords == nil {
- residueWatchAdNum := egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum) - 1
- if residueWatchAdNum < 0 {
- residueWatchAdNum = egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum)
- }
- _, err2 := eggEnergyUserWatchRecordsDb.EggEnergyUserWatchRecordsInsert(&model.EggEnergyUserWatchRecords{
- Uid: uid,
- NextWatchAdDate: now.Add(time.Hour * time.Duration(egg_system_rules.StrToInt(videoRewardSystem.EachRoundHour))),
- ResidueWatchAdNum: egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum) - 1,
- CreateAt: now.Format("2006-01-02 15:04:05"),
- UpdateAt: now.Format("2006-01-02 15:04:05"),
- })
- if err2 != nil {
- return err2
- }
- } else {
- residueWatchAdNum := eggEnergyUserWatchRecords.ResidueWatchAdNum - 1
- nextWatchAdDate := eggEnergyUserWatchRecords.NextWatchAdDate
- if residueWatchAdNum == 0 { //最后一条广告
- residueWatchAdNum = egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum)
- }
- if residueWatchAdNum == egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum)-1 { //第一条广告
- nextWatchAdDate = now.Add(time.Hour * time.Duration(egg_system_rules.StrToInt(videoRewardSystem.EachRoundHour)))
- }
- eggEnergyUserWatchRecords.ResidueWatchAdNum = residueWatchAdNum
- eggEnergyUserWatchRecords.NextWatchAdDate = nextWatchAdDate
- _, err2 := eggEnergyUserWatchRecordsDb.EggEnergyUserWatchRecordsUpdate(eggEnergyUserWatchRecords.Id, eggEnergyUserWatchRecords, "residue_watch_ad_num", "next_watch_ad_date")
- if err2 != nil {
- return err2
- }
- }
-
- session := engine.NewSession()
- defer func() {
- session.Close()
- if err := recover(); err != nil {
- _ = zhios_order_relate_logx.Error(err)
- }
- }()
- session.Begin()
-
- //给相应的用户加上"个人"活跃积分
- err = rule.DealUserVirtualCoin(session, md.DealUserVirtualCoinReq{
- Kind: "add",
- Title: enum.UserVirtualAmountFlowTransferType.String(enum.EggEnergyWatchAdRewardPersonalActiveCoin),
- TransferType: int(enum.EggEnergyWatchAdRewardPersonalActiveCoin),
- CoinId: eggEnergyBasicSetting.PersonEggPointsCoinId,
- Uid: uid,
- Amount: rewardValue,
- })
- if err != nil {
- _ = session.Rollback()
- fmt.Println("err:::::2222", err)
- return err
- }
-
- //给相应的用户加上"团队"活跃积分
- for _, vv := range rewardFather {
- //TODO::推入rabbitmq 异步处理
- ch.Publish(md2.EggEnergyExchange, md.DealUserVirtualCoinReq{
- Kind: "add",
- Title: enum.UserVirtualAmountFlowTransferType.String(enum.EggEnergyWatchAdRewardTeamActiveCoin),
- TransferType: int(enum.EggEnergyWatchAdRewardTeamActiveCoin),
- CoinId: eggEnergyBasicSetting.TeamEggPointsCoinId,
- Uid: vv.Uid,
- Amount: vv.RewardValue,
- }, md2.EggEnergyRoutKeyForSettlementPublicGiveActivityCoin)
- }
- err = session.Commit()
- if err != nil {
- _ = session.Rollback()
- return errors.New("事务提交失败")
- }
-
- redisKey := fmt.Sprintf(md2.UserNextWatchAdDate, uid)
- var watchAdDate string
- if eggEnergyUserWatchRecords.ResidueWatchAdNum == egg_system_rules.StrToInt(videoRewardSystem.RewardTotalNum) {
- if eggEnergyUserWatchRecords.NextWatchAdDate.Before(time.Now()) {
- watchAdDate = ""
- } else {
- watchAdDate = eggEnergyUserWatchRecords.NextWatchAdDate.Format("2006-01-02 15:04:05")
- }
- } else {
- watchAdDate = time.Now().Add(time.Duration(egg_system_rules.StrToInt64(videoRewardSystem.IntervalMinutes)) * time.Second).Format("2006-01-02 15:04:05")
- }
- cache.SetEx(redisKey, watchAdDate, 60*60*24) //TODO::默认缓存1小时
- }
- return
- }
-
- func ActivityCoinToAlipayRealName(engine *xorm.Engine, uid int64, amount string) (err error) {
- amountValue, _ := decimal.NewFromString(amount)
-
- //1、查找 `egg_energy_basic_setting` 基础设置
- eggEnergyBasicSettingDb := implement.NewEggEnergyBasicSettingDb(engine)
- eggEnergyBasicSetting, err := eggEnergyBasicSettingDb.EggEnergyBasicSettingGetOneByParams(map[string]interface{}{
- "key": "is_open",
- "value": 1,
- })
- if err != nil {
- return
- }
- if eggEnergyBasicSetting == nil {
- err = errors.New("蛋蛋能量设置未开启!")
- return
- }
-
- var coin model.VirtualCoin
- _, err = engine.Where("id = ?", eggEnergyBasicSetting.PersonEggPointsCoinId).Get(&coin)
- if err != nil {
- return
- }
- personActivePointsCoinExchangeRatioValue, _ := decimal.NewFromString(coin.ExchangeRatio)
-
- //2、判断个人蛋蛋积分是否足够
- var personUserVirtualAmount model.UserVirtualAmount
- _, err = engine.Where("coin_id = ?", eggEnergyBasicSetting.PersonEggPointsCoinId).And("uid =?", uid).Get(&personUserVirtualAmount)
- if err != nil {
- fmt.Println("err:::::1111", err)
- return
- }
- personUserVirtualAmountValue, _ := decimal.NewFromString(personUserVirtualAmount.Amount)
- needVirtualAmountValue := amountValue.Mul(personActivePointsCoinExchangeRatioValue)
- needVirtualAmount, _ := amountValue.Mul(personActivePointsCoinExchangeRatioValue).Float64()
- if personUserVirtualAmountValue.LessThan(needVirtualAmountValue) {
- err = errors.New("当前蛋蛋积分不足!")
- return
- }
-
- //3、扣除对应个人蛋蛋积分
- session := engine.NewSession()
- defer func() {
- session.Close()
- if err := recover(); err != nil {
- _ = zhios_order_relate_logx.Error(err)
- }
- }()
- session.Begin()
-
- //给相应的用户加上"个人"活跃积分
- err = rule.DealUserVirtualCoin(session, md.DealUserVirtualCoinReq{
- Kind: "sub",
- Title: enum.UserVirtualAmountFlowTransferType.String(enum.EggPointCoinToAliPayRealName),
- TransferType: int(enum.EggPointCoinToAliPayRealName),
- CoinId: eggEnergyBasicSetting.PersonEggPointsCoinId,
- Uid: uid,
- Amount: needVirtualAmount,
- })
- if err != nil {
- _ = session.Rollback()
- fmt.Println("err:::::2222", err)
- return err
- }
-
- err = session.Commit()
- if err != nil {
- _ = session.Rollback()
- return errors.New("事务提交失败")
- }
-
- return
- }
-
- func CheckActivityCoinToAlipayRealName(engine *xorm.Engine, uid int64, amount string) (err error, isCan bool) {
- amountValue, _ := decimal.NewFromString(amount)
-
- //1、查找 `egg_energy_basic_setting` 基础设置
- eggEnergyBasicSettingDb := implement.NewEggEnergyBasicSettingDb(engine)
- eggEnergyBasicSetting, err := eggEnergyBasicSettingDb.EggEnergyBasicSettingGetOneByParams(map[string]interface{}{
- "key": "is_open",
- "value": 1,
- })
- if err != nil {
- return
- }
- if eggEnergyBasicSetting == nil {
- err = errors.New("蛋蛋能量设置未开启!")
- return
- }
-
- var coin model.VirtualCoin
- _, err = engine.Where("id = ?", eggEnergyBasicSetting.PersonEggPointsCoinId).Get(&coin)
- if err != nil {
- return
- }
- personActivePointsCoinExchangeRatioValue, _ := decimal.NewFromString(coin.ExchangeRatio)
-
- //2、判断个人蛋蛋积分是否足够
- var personUserVirtualAmount model.UserVirtualAmount
- _, err = engine.Where("coin_id = ?", eggEnergyBasicSetting.PersonEggPointsCoinId).And("uid =?", uid).Get(&personUserVirtualAmount)
- if err != nil {
- fmt.Println("err:::::1111", err)
- return
- }
- personUserVirtualAmountValue, _ := decimal.NewFromString(personUserVirtualAmount.Amount)
- needVirtualAmountValue := amountValue.Mul(personActivePointsCoinExchangeRatioValue)
- if personUserVirtualAmountValue.GreaterThan(needVirtualAmountValue) {
- isCan = true
- }
- return
- }
-
- // CalcUserContinuousDailyActivityDays 计算用户连续活跃天数
- func CalcUserContinuousDailyActivityDays(engine *xorm.Engine, uid int, startDate string, endDate string) (err error, days int, isContinuousDailyActivity bool) {
- startAt, err := time.ParseInLocation("2006-01-02", startDate, time.Local) //起始时间
- endAt, err := time.ParseInLocation("2006-01-02", endDate, time.Local) //起始时间
- var list []model.EggEnergyUserActivity
- err = engine.Where("date >= ?", startAt.Format("2006-01-02")).
- And("date < ?", endAt.Format("2006-01-02")).
- And("uid =?", uid).Find(&list)
- if err != nil {
- fmt.Println("err:::::1111", err)
- return
- }
- days = len(list)
- diffDays := egg_system_rules.GetDiffDays(endAt, startAt) //相差天数
- if days == diffDays {
- isContinuousDailyActivity = true
- }
- return
- }
|