statemethodlogic.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package logic
  2. import (
  3. "app.yhyue.com/moapp/jyInfo/rpc/model"
  4. "app.yhyue.com/moapp/jyInfo/rpc/util"
  5. "context"
  6. "log"
  7. "time"
  8. "app.yhyue.com/moapp/jyInfo/rpc/common/commoninfo"
  9. "app.yhyue.com/moapp/jyInfo/rpc/common/internal/svc"
  10. mc "app.yhyue.com/moapp/jybase/common"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type StateMethodLogic struct {
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. logx.Logger
  17. }
  18. func NewStateMethodLogic(ctx context.Context, svcCtx *svc.ServiceContext) *StateMethodLogic {
  19. return &StateMethodLogic{
  20. ctx: ctx,
  21. svcCtx: svcCtx,
  22. Logger: logx.WithContext(ctx),
  23. }
  24. }
  25. //数据组 rpc回调 修改信息发布状态
  26. func (l *StateMethodLogic) StateMethod(in *commoninfo.StateRequest) (*commoninfo.StateResponse, error) {
  27. var (
  28. resp commoninfo.StateResponse
  29. )
  30. log.Println("信息发布回调StateMethod", in)
  31. query := make(map[string]interface{})
  32. query["id"] = in.Id
  33. upData := make(map[string]interface{})
  34. upData["published"] = 2
  35. upData["publish_id"] = in.PublishId
  36. upData["publish_time"] = time.Now().Format("2006-01-02 15:04:05")
  37. data := model.Mysql.FindOne("information", query, "", "")
  38. if data == nil || len(*data) < 1 {
  39. log.Println("nsq回调发布状态,获取信息失败", in.Id)
  40. resp.ErrCode = -1
  41. resp.ErrMsg = "nsq回调发布状态,获取信息失败"
  42. return &resp, nil
  43. }
  44. //处理对于发布删除冲突问题,在回调发布后查看是否已删除,如已删除在回调删除nsq 未删除继续正常发布流程
  45. if mc.IntAll((*data)["is_de"]) == -1 {
  46. nsq, err := util.NewNsqInfo(model.NsqConfig.Ip, model.NsqConfig.Topic, mc.InterfaceToStr((*data)["id"]), "3", mc.InterfaceToStr((*data)["type"]), false, upData)
  47. if err != nil || nsq.NsqPushInfo() != nil {
  48. log.Println("信息已删除,同步删除信息失败", model.NsqConfig, upData)
  49. resp.ErrCode = -1
  50. resp.ErrMsg = "信息已删除,同步删除信息失败"
  51. }
  52. return &resp, nil
  53. }
  54. if !model.Mysql.Update("information", query, upData) {
  55. log.Println("nsq回调发布状态,更新信息状态失败", query, upData)
  56. resp.ErrCode = -1
  57. resp.ErrMsg = "nsq回调发布状态,更新信息状态失败"
  58. } else {
  59. //信息审核通过后 留资信息
  60. go PublishSales(in.PublishId, *data)
  61. }
  62. return &resp, nil
  63. }
  64. //PublishSales 信息审核通过后 留资信息
  65. func PublishSales(id string, data map[string]interface{}) {
  66. //选择了“我需要”,则信息审核通过后,生成1条留资信息
  67. if mc.IntAll(data["recommended_service"]) == 1 {
  68. _d := map[string]interface{}{
  69. "userid": data["user_id"],
  70. "source": "info_supplier_recom",
  71. "company": data["ent_name"],
  72. "name": data["contact_person"],
  73. "phone": data["contact_phone"],
  74. "publish_id": id,
  75. "createtime": time.Now().Unix(),
  76. }
  77. model.Mgo.Save("saleLeads", _d)
  78. }
  79. }