|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- package consume
-
- import (
- "applet/app/cfg"
- "applet/app/db"
- "applet/app/utils"
- "applet/app/utils/logx"
- "applet/consume/md"
- "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"
- "code.fnuoos.com/EggPlanet/egg_system_rules.git/rule"
- "code.fnuoos.com/go_rely_warehouse/zyos_go_mq.git/rabbit"
- "encoding/json"
- "errors"
- "fmt"
- "github.com/streadway/amqp"
- "sort"
- "time"
- )
-
- func EggCanalUserDownConsume(queue md.MqQueue) {
- fmt.Println(">>>>>>>>>>>>EggCanalUserDownConsume>>>>>>>>>>>>")
- 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(100)
- delivery := ch.Consume(queue.Name, false)
-
- egg_system_rules.Init(cfg.RedisAddr)
- var res amqp.Delivery
- var ok bool
- for {
- res, ok = <-delivery
- if ok == true {
- err = handleEggCanalUserDownConsume(res.Body, ch)
- err = res.Ack(true)
- fmt.Println("err ::: ", err)
- } else {
- panic(errors.New("error getting message"))
- }
- }
- fmt.Println("get msg done")
- }
-
- func handleEggCanalUserDownConsume(msgData []byte, ch *rabbit.Channel) error {
- var msg *md.CommUserId
- err := json.Unmarshal(msgData, &msg)
- if err != nil {
- return err
- }
- engine := db.Db
- NewUserDb := implement.NewUserDb(engine)
- user, _ := NewUserDb.GetUser(utils.StrToInt64(msg.Uid))
- if user == nil {
- return nil
- }
- levelDb := implement.NewUserLevelDb(engine)
- levelAll, _ := levelDb.UserLevelAllByAsc()
- level := 1
- if len(levelAll) == 0 {
- return nil
- }
- level = levelAll[0].Id
- if levelAll[0].Id == user.Level {
- return nil
- }
- sort.Slice(levelAll, func(i, j int) bool {
- return levelAll[i].LevelWeight <= levelAll[j].LevelWeight
- })
- task := make([]map[string]string, 0)
- for _, v := range levelAll {
- task1, err := rule.UserUpgradeTask(engine, int(user.Id), v.Id)
- if err != nil {
- continue
- }
- level = v.Id
- task = task1
- }
- //升级
- oldLevel := user.Level
- user.Level = level
- _, err = engine.Where("id=?", user.Id).Cols("level").Update(user)
- if err != nil {
- return err
- }
- var tmp = model.UserUpgradeLevel{
- Uid: int(user.Id),
- Level: level,
- OldLv: oldLevel,
- CreateTime: time.Now(),
- Task: utils.SerializeStr(task),
- }
- engine.Insert(&tmp)
- return nil
- }
|