statemethodlogic.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package logic
  2. import (
  3. "context"
  4. "app.yhyue.com/moapp/jyInfo/rpc/model"
  5. "app.yhyue.com/moapp/jyInfo/rpc/util"
  6. "time"
  7. "app.yhyue.com/moapp/jyInfo/rpc/common/internal/svc"
  8. "app.yhyue.com/moapp/jyInfo/rpc/common/type/common"
  9. mc "app.yhyue.com/moapp/jybase/common"
  10. "github.com/zeromicro/go-zero/core/logx"
  11. )
  12. type StateMethodLogic struct {
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. logx.Logger
  16. }
  17. func NewStateMethodLogic(ctx context.Context, svcCtx *svc.ServiceContext) *StateMethodLogic {
  18. return &StateMethodLogic{
  19. ctx: ctx,
  20. svcCtx: svcCtx,
  21. Logger: logx.WithContext(ctx),
  22. }
  23. }
  24. func (l *StateMethodLogic) StateMethod(in *common.StateRequest) (*common.StateResponse, error) {
  25. var (
  26. resp common.StateResponse
  27. )
  28. query := make(map[string]interface{})
  29. query["id"] = in.Id
  30. upData := make(map[string]interface{})
  31. upData["published"] = 2
  32. upData["publish_id"] = in.PublishId
  33. upData["publish_time"] = time.Now().Format("2006-01-02 15:04:05")
  34. data := model.Mysql.FindOne("information", query, "", "")
  35. if data == nil || len(*data) < 1 {
  36. resp.ErrCode = 1
  37. resp.ErrMsg = "nsq回调发布状态,获取信息失败"
  38. return &resp, nil
  39. }
  40. //处理对于发布删除冲突问题,在回调发布后查看是否已删除,如已删除在回调删除nsq 未删除继续正常发布流程
  41. if mc.IntAll((*data)["is_de"]) == -1 {
  42. nsq, err := util.NewNsqInfo(model.NsqConfig.Ip, model.NsqConfig.Topic, mc.InterfaceToStr((*data)["id"]), "3", mc.InterfaceToStr((*data)["type"]), false, upData)
  43. if err != nil || nsq.NsqPushInfo() != nil {
  44. resp.ErrCode = 1
  45. resp.ErrMsg = "信息已删除,同步删除信息失败"
  46. }
  47. return &resp, nil
  48. }
  49. if !model.Mysql.Update("information", query, upData) {
  50. resp.ErrCode = 1
  51. resp.ErrMsg = "nsq回调发布状态,更新信息状态失败"
  52. }
  53. return &resp, nil
  54. }