123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- package services
- import (
- "errors"
- "fmt"
- "hongze/hongze_web_mfyx/models"
- "hongze/hongze_web_mfyx/utils"
- "strconv"
- "time"
- )
- // 记录用户文章浏览记录
- func ArticleHistory(articleId int, user *models.WxUserItem) (err error) {
- defer func() {
- if err != nil {
- go utils.SendAlarmMsg("记录用户文章浏览记录,失败"+err.Error(), 2)
- }
- }()
- uid := user.UserId
- key := "CYGX_ARTICLE_" + strconv.Itoa(articleId) + "_" + strconv.Itoa(uid)
- if !utils.Rc.IsExist(key) {
- //新增浏览记录
- //这个表貌似没怎么用了,暂时保留记录
- record := new(models.CygxArticleViewRecord)
- record.UserId = uid
- record.ArticleId = articleId
- record.CreateTime = time.Now()
- record.Mobile = user.Mobile
- record.Email = user.Email
- record.CompanyId = user.CompanyId
- record.CompanyName = user.CompanyName
- _, e := models.AddCygxArticleViewRecord(record)
- if e != nil {
- err = errors.New("AddCygxArticleViewRecord, Err: " + e.Error())
- return
- }
- e = models.ModifyReportLastViewTime(uid)
- if e != nil {
- err = errors.New("ModifyReportLastViewTime, Err: " + e.Error())
- return
- }
- utils.Rc.Put(key, 1, 2*time.Second)
- }
- return
- }
- // 记录用户文章浏览记录带时长
- func ArticleHistoryStopTime(articleId, stopTime, outType int, user *models.WxUserItem) (err error) {
- defer func() {
- if err != nil {
- go utils.SendAlarmMsg("记录用户文章浏览记录带时长,失败"+err.Error(), 2)
- }
- }()
- if stopTime < 3 {
- return
- }
- uid := user.UserId
- key := "CYGX_ARTICLE_PV" + strconv.Itoa(articleId) + "_" + strconv.Itoa(uid) + "_" + strconv.Itoa(user.CompanyId) + "_" + strconv.Itoa(outType)
- if !utils.Rc.IsExist(key) {
- record := new(models.CygxArticleHistoryRecordNewpv)
- record.UserId = uid
- record.ArticleId = articleId
- record.CreateTime = time.Now().Add(-time.Second * time.Duration(stopTime))
- record.ModifyTime = time.Now()
- record.Mobile = user.Mobile
- record.Email = user.Email
- record.CompanyId = user.CompanyId
- record.CompanyName = user.CompanyName
- record.StopTime = stopTime
- record.OutType = outType
- record.RegisterPlatform = utils.REGISTER_PLATFORM
- record.Source = "WEB"
- newId, e := models.AddCygxArticleViewRecordNewpv(record)
- if e != nil {
- err = errors.New("AddCygxArticleViewRecordNewpv, Err: " + e.Error())
- return
- }
- recordRedis := new(ReportViewRecord)
- recordRedis.UserId = user.UserId
- recordRedis.ReportId = articleId
- recordRedis.Mobile = user.Mobile
- recordRedis.Email = user.Email
- recordRedis.RealName = user.RealName
- recordRedis.CompanyName = user.CompanyName
- recordRedis.StopTime = stopTime
- recordRedis.OutId = int(newId)
- recordRedis.CreateTime = record.CreateTime
- go PushViewRecordNewRedisData(recordRedis, user.CompanyId)
- go ArticleWxUserRaiLabelRedisAdd(articleId, user.UserId, record.CreateTime)
- utils.Rc.Put(key, 1, 2*time.Second)
- }
- go ArticleHistoryUserLabelLogAdd(articleId, uid)
- return
- }
- // GetArticleHistoryByArticleId 获取文章阅读 pv map
- func GetArticleHistoryByArticleId(articleIds []int) (mapResp map[int]int) {
- var err error
- defer func() {
- if err != nil {
- fmt.Println(err)
- go utils.SendAlarmMsg("获取用户的阅读数据,信息失败,GetArticleHistoryByArticleId Err:"+err.Error(), 3)
- }
- }()
- lenIds := len(articleIds)
- if lenIds == 0 {
- return
- }
- var condition string
- var pars []interface{}
- condition = ` AND article_id IN (` + utils.GetOrmInReplace(lenIds) + `) `
- pars = append(pars, articleIds)
- listCy, e := models.GetCygxArticleHistoryRecordNewpvListPvCy(condition, pars)
- if e != nil {
- err = errors.New("GetCygxArticleHistoryRecordNewpvListPvCy, Err: " + e.Error())
- return
- }
- mapResp = make(map[int]int, 0)
- for _, v := range listCy {
- mapResp[v.ArticleId] = v.Pv
- }
- listCl, e := models.GetCygxArticleHistoryRecordNewpvListPvCl(condition, pars)
- if e != nil {
- err = errors.New("GetCygxArticleHistoryRecordNewpvListPvCy, Err: " + e.Error())
- return
- }
- for _, v := range listCl {
- mapResp[v.ArticleId] += v.Pv
- }
- return
- }
|