article_history.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package services
  2. import (
  3. "errors"
  4. "fmt"
  5. "hongze/hongze_cygx/models"
  6. "hongze/hongze_cygx/utils"
  7. "strconv"
  8. "time"
  9. )
  10. func GetArticleHistoryByUser(articleIds []int, user *models.WxUserItem) (mapResp map[int]int) {
  11. var err error
  12. defer func() {
  13. if err != nil {
  14. fmt.Println(err)
  15. go utils.SendAlarmMsg("获取用户的阅读数据,信息失败,Err:"+err.Error(), 3)
  16. }
  17. }()
  18. lenIds := len(articleIds)
  19. if lenIds == 0 {
  20. return
  21. }
  22. var condition string
  23. var pars []interface{}
  24. condition = ` AND article_id IN (` + utils.GetOrmInReplace(lenIds) + `) AND user_id = ?`
  25. pars = append(pars, articleIds, user.UserId)
  26. list, err := models.GetCygxArticleHistoryRecordNewpvList(condition, pars)
  27. if err != nil {
  28. return
  29. }
  30. mapResp = make(map[int]int, 0)
  31. for _, v := range list {
  32. mapResp[v.ArticleId]++
  33. }
  34. return
  35. }
  36. // 记录用户文章浏览记录
  37. func ArticleHistory(articleId int, user *models.WxUserItem) (err error) {
  38. defer func() {
  39. if err != nil {
  40. go utils.SendAlarmMsg("记录用户文章浏览记录,失败"+err.Error(), 2)
  41. }
  42. }()
  43. recordRedis := new(ReportViewRecord)
  44. recordRedis.UserId = user.UserId
  45. recordRedis.ReportId = articleId
  46. recordRedis.Mobile = user.Mobile
  47. recordRedis.Email = user.Email
  48. recordRedis.RealName = user.RealName
  49. recordRedis.CompanyName = user.CompanyName
  50. recordRedis.CreateTime = time.Now()
  51. go PushViewRecordNewRedisData(recordRedis, user.CompanyId)
  52. uid := user.UserId
  53. key := "CYGX_ARTICLE_" + strconv.Itoa(articleId) + "_" + strconv.Itoa(uid)
  54. if !utils.Rc.IsExist(key) {
  55. //新增浏览记录
  56. //这个表貌似没怎么用了,暂时保留记录
  57. record := new(models.CygxArticleViewRecord)
  58. record.UserId = uid
  59. record.ArticleId = articleId
  60. record.CreateTime = time.Now()
  61. record.Mobile = user.Mobile
  62. record.Email = user.Email
  63. record.CompanyId = user.CompanyId
  64. record.CompanyName = user.CompanyName
  65. _, e := models.AddCygxArticleViewRecord(record)
  66. if e != nil {
  67. err = errors.New("AddCygxArticleViewRecord, Err: " + e.Error())
  68. return
  69. }
  70. e = models.ModifyReportLastViewTime(uid)
  71. if e != nil {
  72. err = errors.New("ModifyReportLastViewTime, Err: " + e.Error())
  73. return
  74. }
  75. utils.Rc.Put(key, 1, 2*time.Second)
  76. }
  77. return
  78. }
  79. // 记录用户文章浏览记录带时长
  80. func ArticleHistoryStopTime(articleId, stopTime, outType int, user *models.WxUserItem) (err error) {
  81. defer func() {
  82. if err != nil {
  83. go utils.SendAlarmMsg("记录用户文章浏览记录带时长,失败"+err.Error(), 2)
  84. }
  85. }()
  86. if stopTime < 3 {
  87. return
  88. }
  89. uid := user.UserId
  90. key := "CYGX_ARTICLE_PV" + strconv.Itoa(articleId) + "_" + strconv.Itoa(uid) + "_" + strconv.Itoa(user.CompanyId) + "_" + strconv.Itoa(outType)
  91. if !utils.Rc.IsExist(key) {
  92. record := new(models.CygxArticleHistoryRecordNewpv)
  93. record.UserId = uid
  94. record.ArticleId = articleId
  95. record.CreateTime = time.Now().Add(-time.Second * time.Duration(stopTime))
  96. record.ModifyTime = time.Now()
  97. record.Mobile = user.Mobile
  98. record.Email = user.Email
  99. record.CompanyId = user.CompanyId
  100. record.CompanyName = user.CompanyName
  101. record.StopTime = stopTime
  102. record.OutType = outType
  103. record.Source = "WEB"
  104. _, e := models.AddCygxArticleViewRecordNewpv(record)
  105. if e != nil {
  106. err = errors.New("AddCygxArticleViewRecordNewpv, Err: " + e.Error())
  107. return
  108. }
  109. utils.Rc.Put(key, 1, 2*time.Second)
  110. }
  111. go ArticleHistoryUserLabelLogAdd(articleId, uid)
  112. return
  113. }