keyword.go 3.9 KB

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