123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- package service
- import (
- "context"
- "encoding/json"
- model "go-common/app/job/main/reply/model/reply"
- "go-common/library/log"
- xtime "go-common/library/time"
- )
- func (s *Service) actionUp(c context.Context, msg *consumerMsg) {
- var d struct {
- Op string `json:"op"`
- Action uint32 `json:"action"`
- Oid int64 `json:"oid"`
- Tp int64 `json:"tp"`
- RpID int64 `json:"rpid"`
- MTime xtime.Time `json:"mtime"`
- }
- if err := json.Unmarshal([]byte(msg.Data), &d); err != nil {
- log.Error("json.Unmarshal() error(%v)", err)
- return
- }
- if d.Oid == 0 || d.RpID == 0 {
- log.Error("The structure of action(%s) from rpCh was wrong", msg.Data)
- return
- }
- rp, err := s.getReplyCache(c, d.Oid, d.RpID)
- if err != nil {
- log.Error("s.getReply failed , oid(%d), RpID(%d) err(%v)", d.Oid, d.RpID, err)
- return
- }
- if rp == nil {
- log.Error("reply is nil oid(%d) RpID(%d)", d.Oid, d.RpID)
- return
- }
- var state int8
- switch {
- case d.Op == "show":
- if rp.State != model.ReplyStateHidden {
- log.Warn("reply state(%d) is not hidden", rp.State)
- return
- }
- state = model.ReplyStateNormal
- case d.Op == "hide":
- if rp.State != model.ReplyStateNormal && rp.State != model.ReplyStateGarbage && rp.State != model.ReplyStateFiltered && rp.State != model.ReplyStateFolded {
- log.Warn("reply state(%d) is not normal", rp.State)
- return
- }
- state = model.ReplyStateHidden
- case d.Op == "top_add":
- if err := s.topAdd(c, rp, d.MTime, d.Action, model.SubAttrUpperTop); err != nil {
- log.Error("s.topAdd(oid %d) err(%v)", d.Oid, err)
- }
- return
- }
- if rows, err := s.dao.Reply.UpState(c, d.Oid, d.RpID, state, d.MTime.Time()); err != nil || rows < 1 {
- log.Error("dao.Reply.Update(%d, %d, %d), error(%v) and rows==0", d.Oid, d.RpID, state, err)
- } else {
- // if rp, err := s.dao.Mc.GetReply(nil, d.RpID); err == nil && rp != nil {
- rp.State = state
- if err = s.dao.Mc.AddReply(c, rp); err != nil {
- log.Error("s.dao.Mc.AddReply(%d, %d, %d), error(%v) and rows==0", d.Oid, d.RpID, state, err)
- }
- // }
- }
- // callSearchUp(rp.Oid, rp.RpID, rp.Type, false)
- }
|