keyword.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package services
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_mfyx/models"
  6. "hongze/hongze_mfyx/utils"
  7. "time"
  8. )
  9. // AddSearchKeyWord 记录用户搜索关键词
  10. func AddSearchKeyWord(user *models.WxUserItem, keyWord string, source int) (err error) {
  11. defer func() {
  12. if err != nil {
  13. go utils.SendAlarmMsg(" 记录用户搜索关键词失败"+err.Error(), 2)
  14. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "记录用户搜索关键词失败 ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  15. }
  16. }()
  17. keyWordItem := new(models.CygxSearchKeyWord)
  18. keyWordItem.UserId = user.UserId
  19. keyWordItem.KeyWord = keyWord
  20. keyWordItem.CreateTime = time.Now()
  21. keyWordItem.Mobile = user.Mobile
  22. keyWordItem.Email = user.Email
  23. keyWordItem.CompanyId = user.CompanyId
  24. keyWordItem.CompanyName = user.CompanyName
  25. keyWordItem.RealName = user.RealName
  26. keyWordItem.RegisterPlatform = utils.REGISTER_PLATFORM
  27. _, err = models.AddSearchKeyWord(keyWordItem)
  28. go AddUserSearchLog(user, keyWord, source)
  29. go SearchKeywordUserRmind(user, keyWord)
  30. go SearchKeywordUserRmindCategoryMsg(user, keyWord)
  31. ////一分钟之内的相同搜索词不重复记录
  32. //setNX := utils.Rc.SetNX(cacheKey, keyWord, time.Minute*1)
  33. //if !setNX {
  34. // go utils.SendAlarmMsg("记录用户搜索关键词失败,设置Redis Key 过期时间失败:key"+cacheKey, 3)
  35. //}
  36. return
  37. }
  38. // AddUserSearchLog 记录用户搜索关键词的日志
  39. func AddUserSearchLog(user *models.WxUserItem, keyWord string, source int) (err error) {
  40. defer func() {
  41. if err != nil {
  42. fmt.Println(err)
  43. go utils.SendAlarmMsg(" 记录用户搜索关键词的日志"+err.Error(), 2)
  44. go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "修改活动状态至进行中失败 ErrMsg:"+err.Error(), utils.EmailSendToUsers)
  45. }
  46. }()
  47. item := new(models.CygxSearchKeyWordLog)
  48. item.UserId = user.UserId
  49. item.KeyWord = keyWord
  50. item.CreateTime = time.Now()
  51. item.Mobile = user.Mobile
  52. item.Email = user.Email
  53. item.CompanyId = user.CompanyId
  54. item.CompanyName = user.CompanyName
  55. item.RealName = user.RealName
  56. item.Source = source
  57. _, err = models.AddSearchKeyWordLog(item)
  58. return
  59. }
  60. // 用户搜索操作操作行为,模板消息推送
  61. func SearchKeywordUserRmind(user *models.WxUserItem, keyWord string) (err error) {
  62. defer func() {
  63. if err != nil {
  64. fmt.Println(err)
  65. go utils.SendAlarmMsg(fmt.Sprint("用户搜索操作操作行为,模板消息推送失败"+err.Error(), "UserId:", user.UserId, "keyWord:", keyWord), 2)
  66. }
  67. }()
  68. countUser, e := models.GetUserRemind(user.UserId)
  69. if e != nil {
  70. err = errors.New("GetUserRemind, Err: " + e.Error())
  71. return
  72. }
  73. if countUser == 0 {
  74. return
  75. }
  76. var first string
  77. var keyword1 string
  78. var keyword2 string
  79. var keyword3 string
  80. var keyword4 string
  81. var remark string
  82. //获取销售手机号
  83. sellerItemQy, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  84. if e != nil && e.Error() != utils.ErrNoRow() {
  85. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  86. return
  87. }
  88. if sellerItemQy != nil {
  89. openIdList, e := models.GetWxOpenIdByMobileList(sellerItemQy.Mobile)
  90. if e != nil {
  91. err = errors.New("GetSellerByAdminId, Err: " + e.Error())
  92. return
  93. }
  94. if len(openIdList) == 0 {
  95. return
  96. }
  97. first = fmt.Sprint("互动:搜索,", user.RealName, "--", user.CompanyName)
  98. keyword1 = "搜索关键词:" + keyWord
  99. keyword2 = first
  100. openIdArr := make([]string, 0)
  101. for _, v := range openIdList {
  102. openIdArr = append(openIdArr, v.OpenId)
  103. }
  104. redirectUrl := ""
  105. sendInfo := new(SendWxTemplate)
  106. sendInfo.First = first
  107. sendInfo.Keyword1 = keyword1
  108. sendInfo.Keyword2 = keyword2
  109. sendInfo.Keyword3 = keyword3
  110. sendInfo.Keyword4 = keyword4
  111. sendInfo.Remark = remark
  112. sendInfo.TemplateId = utils.WxMsgTemplateIdArticleUserRemind
  113. sendInfo.RedirectUrl = redirectUrl
  114. sendInfo.RedirectTarget = 3
  115. sendInfo.Resource = "0"
  116. sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_ARTICLE_ADD
  117. sendInfo.OpenIdArr = openIdArr
  118. err = PublicSendTemplateMsg(sendInfo)
  119. if err != nil {
  120. return
  121. }
  122. }
  123. return
  124. }