|
- package consume
-
- import (
- "applet/app/db"
- "applet/app/db/model"
- "applet/app/utils"
- "applet/app/utils/logx"
- "applet/consume/md"
- "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit"
- "encoding/json"
- "errors"
- "fmt"
- "github.com/streadway/amqp"
- "time"
- "xorm.io/xorm"
- )
-
- func ZhiosAcquisitionCondition(queue md.MqQueue) {
- fmt.Println(">>>>>>>>>>>>>>>>>>>>>>>>")
- ch, err := rabbit.Cfg.Pool.GetChannel()
- if err != nil {
- logx.Error(err)
- return
- }
- defer ch.Release()
- //1、将自己绑定到交换机上
- ch.Bind(queue.Name, queue.ExchangeName, queue.RoutKey)
- //2、取出数据进行消费
- ch.Qos(300)
- delivery := ch.Consume(queue.Name, false)
-
- var res amqp.Delivery
- var ok bool
- for {
- res, ok = <-delivery
- if ok == true {
- //fmt.Println(string(res.Body))
- fmt.Println(">>>>>>>>>>>>>>>>ZhiosAcquisitionCondition<<<<<<<<<<<<<<<<<<<<<<<<<")
- err = handleZhiosAcquisition(res.Body)
- //_ = res.Reject(false)
- fmt.Println(err)
- if err == nil {
- //_ = res.Ack(true)
- } else {
- var canalMsg *md.ZhiosAcquisition
- var tmpString string
- err := json.Unmarshal(res.Body, &tmpString)
- if err == nil {
- fmt.Println(tmpString)
- err = json.Unmarshal([]byte(tmpString), &canalMsg)
- if err == nil {
- ch.Publish(queue.ExchangeName, utils.SerializeStr(canalMsg), queue.RoutKey)
- }
- }
-
- }
- } else {
- panic(errors.New("error getting message"))
- }
- }
- fmt.Println("get msg done")
- }
- func handleZhiosAcquisition(msg []byte) error {
- //1、解析canal采集至mq中queue的数据结构体
- var canalMsg *md.ZhiosAcquisition
- fmt.Println(string(msg))
- var tmpString string
- err := json.Unmarshal(msg, &tmpString)
- if err != nil {
- fmt.Println(err.Error())
- return err
- }
- fmt.Println(tmpString)
- err = json.Unmarshal([]byte(tmpString), &canalMsg)
- if err != nil {
- return err
- }
- mid := canalMsg.Mid
- eg := db.DBs[mid]
- if eg == nil {
- return nil
- }
- if canalMsg.Uid == "" {
- return nil
- }
- userInfo, _ := db.UserFindByID(eg, canalMsg.Uid)
- if userInfo == nil {
- return nil
- }
- userProfile, _ := db.UserProfileFindByID(eg, canalMsg.Uid)
- cfg := db.GetAcquisitionCfg(eg, canalMsg.Id, userInfo.CreateAt)
- if cfg == nil {
- return nil
- }
- nextUserProfile, _ := db.UserProfileFindByID(eg, userProfile.ParentUid)
- var user = &md.User{Info: userInfo, Profile: userProfile}
-
- bools, str := checkAllCompleteTmp(eg, user, cfg)
- isFull := 0
- fullTime := 0
- toRewardTime := 0
- if bools {
- isFull = 1
- fullTime = int(time.Now().Unix())
- toRewardTime = int(time.Now().Unix()) + utils.StrToInt(cfg.RewardAccountDay)*86400
- }
- //写入奖励记录
-
- //新的设置 读第一个新注册的奖励
- lv := 0
- if len(cfg.RewardRule.LvRewardList) > 0 {
- isEnd := 0
- for k, v := range cfg.RewardRule.LvRewardList {
- if isEnd == 1 {
- continue
- }
- if utils.StrToInt(v.Id) == user.Info.Level {
- isEnd = 1
- }
- lv = utils.StrToInt(v.Id)
- InvitedReward := v.InvitedReward
- if cfg.RewardRule.RewardType == "1" {
- InvitedReward = Rands(v.InvitedReward, v.InvitedRewardMax)
- }
- //直推
- DirectSuccess := v.DirectSuccess
- if cfg.RewardRule.RewardType == "1" {
- DirectSuccess = Rands(v.DirectSuccess, v.DirectSuccessMax)
- }
- //间推
- IndirectSuccess := v.IndirectSuccess
- if cfg.RewardRule.RewardType == "1" {
- IndirectSuccess = Rands(v.IndirectSuccess, v.IndirectSuccessMax)
- }
- InvitedSource := 0
- DirectSource := 1
- IndirectSource := 2
- InvitedSourceStr := "注册奖励"
- DirectSourceStr := "直推好友"
- IndirectSourceStr := "间推好友"
- if k > 0 {
- InvitedSource = 3
- DirectSource = 4
- IndirectSource = 5
- InvitedSourceStr = "升级" + v.Name + "奖励"
- DirectSourceStr = "直推好友升级" + v.Name + "奖励"
- IndirectSourceStr = "间推好友升级" + v.Name + "奖励"
- }
- if utils.StrToFloat64(InvitedReward) > 0 {
- ownRewardLog, ownhas, _ := db.GetNewAcquisitionRewardLogWhere(eg, userProfile.Uid, user.Profile.Uid, lv)
- if !ownhas {
- ownRewardLog = &model.NewAcquisitionRewardLog{
- Uid: user.Profile.Uid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: InvitedSource,
- SourceText: InvitedSourceStr,
- Money: InvitedReward,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
-
- db.InsertNewRewardLog(eg, ownRewardLog)
- }
- if ownRewardLog.GivenAt == 0 {
-
- ownRewardLog.CompleteCon = str
- ownRewardLog.IsFull = isFull
- if ownRewardLog.FullTime == 0 {
- ownRewardLog.FullTime = fullTime
- }
- if ownRewardLog.ToRewardTime == 0 {
- ownRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", ownRewardLog.Id).Update(ownRewardLog)
- }
- }
- if utils.StrToFloat64(DirectSuccess) > 0 {
- if userProfile.ParentUid > 0 {
- //写入奖励记录
- extendRewardLog, extendHas, _ := db.GetNewAcquisitionRewardLogWhere(eg, userProfile.ParentUid, userProfile.Uid, lv)
- if !extendHas {
- extendRewardLog = &model.NewAcquisitionRewardLog{
- Uid: user.Profile.ParentUid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: DirectSource,
- SourceText: DirectSourceStr,
- Money: DirectSuccess,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
- db.InsertNewRewardLog(eg, extendRewardLog)
- }
- if extendRewardLog.GivenAt == 0 {
-
- extendRewardLog.CompleteCon = str
- extendRewardLog.IsFull = isFull
- if extendRewardLog.FullTime == 0 {
- extendRewardLog.FullTime = fullTime
- }
- if extendRewardLog.ToRewardTime == 0 {
- extendRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", extendRewardLog.Id).Update(extendRewardLog)
- }
- }
- }
- if utils.StrToFloat64(IndirectSuccess) > 0 {
- if nextUserProfile != nil && nextUserProfile.ParentUid > 0 {
- IndirectRewardLog, IndirectHas, _ := db.GetNewAcquisitionRewardLogWhere(eg, nextUserProfile.ParentUid, userProfile.Uid, lv)
- if !IndirectHas {
- IndirectRewardLog = &model.NewAcquisitionRewardLog{
- Uid: nextUserProfile.ParentUid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: IndirectSource,
- SourceText: IndirectSourceStr,
- Money: IndirectSuccess,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
- db.InsertNewRewardLog(eg, IndirectRewardLog)
- }
- if IndirectRewardLog.GivenAt == 0 {
- IndirectRewardLog.CompleteCon = str
- IndirectRewardLog.IsFull = isFull
- if IndirectRewardLog.FullTime == 0 {
- IndirectRewardLog.FullTime = fullTime
- }
- if IndirectRewardLog.ToRewardTime == 0 {
- IndirectRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", IndirectRewardLog.Id).Update(IndirectRewardLog)
- }
- }
- }
- }
- } else {
- InvitedReward := cfg.RewardRule.InvitedReward
- if cfg.RewardRule.RewardType == "1" {
- InvitedReward = Rands(cfg.RewardRule.InvitedReward, cfg.RewardRule.InvitedRewardMax)
- }
- //直推
- DirectSuccess := cfg.RewardRule.DirectSuccess
- if cfg.RewardRule.RewardType == "1" {
- DirectSuccess = Rands(cfg.RewardRule.DirectSuccess, cfg.RewardRule.DirectSuccessMax)
- }
- //间推
- IndirectSuccess := cfg.RewardRule.IndirectSuccess
- if cfg.RewardRule.RewardType == "1" {
- IndirectSuccess = Rands(cfg.RewardRule.IndirectSuccess, cfg.RewardRule.IndirectSuccessMax)
- }
- if utils.StrToFloat64(InvitedReward) > 0 {
- ownRewardLog, ownhas, _ := db.GetNewAcquisitionRewardLog(eg, &model.NewAcquisitionRewardLog{
- Uid: user.Profile.Uid,
- ToUid: user.Profile.Uid,
- })
- if !ownhas {
- ownRewardLog = &model.NewAcquisitionRewardLog{
- Uid: user.Profile.Uid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: 0,
- SourceText: "注册奖励",
- Money: InvitedReward,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
-
- db.InsertNewRewardLog(eg, ownRewardLog)
- }
- if ownRewardLog.GivenAt == 0 {
- ownRewardLog.CompleteCon = str
- ownRewardLog.IsFull = isFull
- if ownRewardLog.FullTime == 0 {
- ownRewardLog.FullTime = fullTime
- }
- if ownRewardLog.ToRewardTime == 0 {
- ownRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", ownRewardLog.Id).Update(ownRewardLog)
- }
- }
- if utils.StrToFloat64(DirectSuccess) > 0 {
- if userProfile.ParentUid > 0 {
- //写入奖励记录
- extendRewardLog, extendHas, _ := db.GetNewAcquisitionRewardLog(eg, &model.NewAcquisitionRewardLog{
- Uid: userProfile.ParentUid,
- ToUid: userProfile.Uid,
- })
- if !extendHas {
- extendRewardLog = &model.NewAcquisitionRewardLog{
- Uid: user.Profile.ParentUid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: 1,
- SourceText: "直推好友",
- Money: DirectSuccess,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
- db.InsertNewRewardLog(eg, extendRewardLog)
- }
- if extendRewardLog.GivenAt == 0 {
- extendRewardLog.CompleteCon = str
- extendRewardLog.IsFull = isFull
- if extendRewardLog.FullTime == 0 {
- extendRewardLog.FullTime = fullTime
- }
- if extendRewardLog.ToRewardTime == 0 {
- extendRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", extendRewardLog.Id).Update(extendRewardLog)
- }
- }
- }
- if utils.StrToFloat64(IndirectSuccess) > 0 {
- if nextUserProfile != nil && nextUserProfile.ParentUid > 0 {
- IndirectRewardLog, IndirectHas, _ := db.GetNewAcquisitionRewardLog(eg, &model.NewAcquisitionRewardLog{
- Uid: nextUserProfile.ParentUid,
- ToUid: userProfile.Uid,
- })
- if !IndirectHas {
- IndirectRewardLog = &model.NewAcquisitionRewardLog{
- Uid: nextUserProfile.ParentUid,
- ToUid: user.Profile.Uid,
- Title: user.Info.Nickname,
- Source: 2,
- SourceText: "间推好友",
- Money: IndirectSuccess,
- CreatedAt: int(time.Now().Unix()),
- State: 0,
- CoinId: utils.StrToInt(cfg.RewardRule.RewardCoinId),
- RewardType: utils.StrToInt(cfg.RewardRule.RewardType),
- InviteTime: int(userInfo.CreateAt.Unix()),
- Lv: lv,
- }
- db.InsertNewRewardLog(eg, IndirectRewardLog)
- }
- if IndirectRewardLog.GivenAt == 0 {
- IndirectRewardLog.CompleteCon = str
- IndirectRewardLog.IsFull = isFull
- if IndirectRewardLog.FullTime == 0 {
- IndirectRewardLog.FullTime = fullTime
- }
- if IndirectRewardLog.ToRewardTime == 0 {
- IndirectRewardLog.ToRewardTime = toRewardTime
- }
- eg.Where("id=?", IndirectRewardLog.Id).Update(IndirectRewardLog)
- }
- }
- }
- }
-
- return nil
- }
- func Rands(minVal, maxVal string) string {
- min := int(utils.StrToFloat64(minVal) * 100)
- max := int(utils.StrToFloat64(maxVal) * 100)
- return utils.Float64ToStrByPrec(float64(utils.RandIntRand(min, max))/100, 3)
- }
-
- //判断是否符合条件
- func checkAllCompleteTmp(eg *xorm.Engine, user *md.User, acqCfg *md.AcquisitionCfg) (bool, string) {
- res := true
- str := ""
- if acqCfg.SuccessConditions.Register.Open == "1" {
- res = res && AcqRegisterTmp(user, acqCfg)
- if res {
- str += ",Register"
- }
- }
- if acqCfg.SuccessConditions.TaobaoAuthorization.Open == "1" {
- res = res && AcqTaoBaoAuthTmp(user, acqCfg)
- if res {
- str += ",TaobaoAuthorization"
- }
- }
- if acqCfg.SuccessConditions.FirstOrder.Open == "1" {
- res = res && AcqFirstOrder(eg, user, acqCfg)
- if res {
- str += ",FirstOrder"
- }
- }
- if acqCfg.SuccessConditions.SelfOrder.Open == "1" {
- res = res && AcqSelfOrder(eg, user, acqCfg)
- if res {
- str += ",SelfOrder"
- }
- }
- if acqCfg.SuccessConditions.OrderPay.Open == "1" {
- res = res && AcqOrderPay(eg, user, acqCfg)
- if res {
- str += ",OrderPay"
- }
- }
- if len(str) > 0 {
- str = str[1:]
- }
- return res, str
- }
- func AcqRegisterTmp(user *md.User, acqCfg *md.AcquisitionCfg) bool {
- var startTime = utils.TimeStdParseUnix(acqCfg.StartTime)
- var endTime = utils.TimeStdParseUnix(acqCfg.EndTime)
- if startTime == 0 || endTime == 0 {
- return false
- }
- //时间不在活动范围之内返回false
- if user.Info.CreateAt.Unix() < startTime {
- return false
- }
- if user.Info.CreateAt.Unix() > endTime {
- return false
- }
- return true
- }
-
- func AcqTaoBaoAuthTmp(user *md.User, acqCfg *md.AcquisitionCfg) bool {
- if user.Profile.AccTaobaoAuthTime > 0 {
- return true
- }
- return false
- }
-
- func AcqFirstOrder(eg *xorm.Engine, user *md.User, acqCfg *md.AcquisitionCfg) bool {
- endTime := int(user.Info.CreateAt.Unix()) + utils.StrToInt(acqCfg.SuccessConditions.FirstOrder.Day)*86400
- return commAmount(eg, utils.IntToStr(user.Info.Uid), endTime, 0, acqCfg)
- }
- func AcqSelfOrder(eg *xorm.Engine, user *md.User, acqCfg *md.AcquisitionCfg) bool {
- return commAmount(eg, utils.IntToStr(user.Info.Uid), 0, 2, acqCfg)
- }
- func AcqOrderPay(eg *xorm.Engine, user *md.User, acqCfg *md.AcquisitionCfg) bool {
- return commAmount(eg, utils.IntToStr(user.Info.Uid), 0, 1, acqCfg)
- }
- func sqlSelect(eg *xorm.Engine, uid string, endTime, types int, acqCfg *md.AcquisitionCfg, arr []string) int {
- sql := `SELECT COUNT(*) as count FROM %s ol
- LEFT JOIN %s olr on olr.oid=%s and olr.uid=%s
- WHERE ol.uid=? %s %s
- `
- str := ""
- if endTime > 0 {
- str += " AND olr.create_at<=" + utils.IntToStr(endTime)
- }
- if types == 2 {
- str += " AND olr.amount>=" + acqCfg.SuccessConditions.SelfOrder.Money
- }
- if types == 1 {
- str += " AND %s>=" + acqCfg.SuccessConditions.OrderPay.Money
- str = fmt.Sprintf(str, arr[0])
- }
- sqlOrd := fmt.Sprintf(sql, arr[1], arr[2], arr[3], arr[4], str, arr[5])
- ordResult, err := db.QueryNativeString(eg, sqlOrd, uid)
- fmt.Println(sqlOrd)
- fmt.Println(err)
- count := 0
- for _, v := range ordResult {
- count = utils.StrToInt(v["count"])
- }
- return count
- }
- func commAmount(eg *xorm.Engine, uid string, endTime, types int, acqCfg *md.AcquisitionCfg) bool {
- state := "0,1,2,3,5"
- psoState := "'订单付款','订单结算'"
- mallState := "1,2,3"
- o2oState := "1,2,3,4"
- b2cState := "1,2,3,4"
- if acqCfg.SuccessConditions.FirstOrder.Status == "1" {
- state = "1,2,3,5"
- mallState = "2,3"
- o2oState = "2,3,4"
- b2cState = "2,3,4"
- }
- if acqCfg.SuccessConditions.FirstOrder.Status == "2" {
- state = "2,3,5"
- mallState = "2,3"
- o2oState = "2,3,4"
- b2cState = "2,3,4"
- }
- if acqCfg.SuccessConditions.FirstOrder.Status == "3" {
- state = "3,5"
- mallState = "3"
- o2oState = "3,4"
- b2cState = "3,4"
- psoState = "'订单结算'"
- }
-
- arr := []string{"ol.paid_price", "ord_list", "ord_list_relate", "ol.ord_id", "ol.uid", " and ol.state in(" + state + ")"}
- count := sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.paid_price", "privilege_card_ord", "ord_list_relate", "ol.ord_id", "ol.uid", " and ol.state=1"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.commission", "duoyou_ord_list", "ord_list_relate", "ol.oid", "ol.uid", " and ol.id>0"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.amount", "recharge_order", "ord_list_relate", "ol.oid", "ol.uid", " and ol.status<>'已退款'"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.amount", "playlet_sale_order", "ord_list_relate", "ol.custom_oid", "ol.uid", " and ol.status in(" + psoState + ")"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
-
- arr = []string{"ol.cost_price", "mall_ord", "mall_ord_list_relate", "ol.ord_id", "ol.uid", " and ol.state in(" + mallState + ")"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
-
- arr = []string{"ol.cost_price", "o2o_ord", "o2o_ord_list_relate", "ol.ord_id", "ol.uid", " and ol.state in(" + o2oState + ")"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.actual_pay_amount", "o2o_pay_to_merchant", "o2o_ord_list_relate", "ol.pay_id", "ol.uid", " and ol.state >=1"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- arr = []string{"ol.cost_price", "b2c_ord", "b2c_ord_list_relate", "ol.ord_id", "ol.uid", " and ol.state in(" + b2cState + ")"}
- count += sqlSelect(eg, uid, endTime, types, acqCfg, arr)
- if count > 0 {
- return true
- }
- return false
- }
|