|
@@ -3,6 +3,7 @@ package services
|
|
|
import (
|
|
|
"context"
|
|
|
"encoding/json"
|
|
|
+ "errors"
|
|
|
"fmt"
|
|
|
"hongze/hongze_cygx/models"
|
|
|
"hongze/hongze_cygx/utils"
|
|
@@ -64,16 +65,31 @@ func GetStocksFromVmp(cont context.Context) (err error) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-func AddSpecialRecord(user *models.WxUserItem, specialId, stopTime int) {
|
|
|
+// 记录用户阅读时长
|
|
|
+func AddSpecialRecord(user *models.WxUserItem, specialId, stopTime int) (err error) {
|
|
|
+ defer func() {
|
|
|
+ if err != nil {
|
|
|
+ go utils.SendAlarmMsg(fmt.Sprint("记录用户阅读时长 失败 AddSpecialRecord Err:"+err.Error(), "userId:", user.UserId, "specialId:", specialId), 2)
|
|
|
+ }
|
|
|
+ }()
|
|
|
var sellerName string
|
|
|
//获取销售信息
|
|
|
- sellerItem, err := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
|
|
|
- if err != nil {
|
|
|
+ sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
|
|
|
return
|
|
|
}
|
|
|
sellerName = sellerItem.RealName
|
|
|
|
|
|
if stopTime >= 3 {
|
|
|
+
|
|
|
+ //判断一个用户是否阅读过 某一篇研选专栏
|
|
|
+ totalRecord, e := models.GetCygxYanxuanSpecialRecordCountByUser(user.UserId, specialId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("GetCygxYanxuanSpecialRecordCountByUser, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
item := new(models.CygxYanxuanSpecialRecord)
|
|
|
item.UserId = user.UserId
|
|
|
item.Mobile = user.Mobile
|
|
@@ -82,34 +98,67 @@ func AddSpecialRecord(user *models.WxUserItem, specialId, stopTime int) {
|
|
|
item.CompanyName = user.CompanyName
|
|
|
item.RealName = user.RealName
|
|
|
item.SellerName = sellerName
|
|
|
- item.CreateTime = time.Now()
|
|
|
+ item.CreateTime = time.Now().Add(-time.Duration(stopTime) * time.Second) // 往前推迟的时间就是他的阅读时间
|
|
|
item.ModifyTime = time.Now()
|
|
|
item.RegisterPlatform = utils.REGISTER_PLATFORM
|
|
|
item.YanxuanSpecialId = specialId
|
|
|
-
|
|
|
- _, err = models.AddCygxYanxuanSpecialRecord(item)
|
|
|
- if err != nil {
|
|
|
+ item.StopTime = stopTime
|
|
|
+ _, e = models.AddCygxYanxuanSpecialRecord(item) // 添加历史记录
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("AddCygxYanxuanSpecialRecord, Err: " + e.Error())
|
|
|
return
|
|
|
}
|
|
|
-
|
|
|
//如果不是弘则研究的人员阅读的,就修改Pv、Uv数量
|
|
|
if user.CompanyId != utils.HZ_COMPANY_ID {
|
|
|
|
|
|
+ //专栏Pv数量进行加一
|
|
|
+ e = models.UpdateYanxuanSpecialPv(specialId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("UpdateYanxuanSpecialPv, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //专栏作者Pv数量进行加一
|
|
|
+ e = models.UpdateCygxYanxuanSpecialAuthorPv(user.UserId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("UpdateCygxYanxuanSpecialAuthorPv, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //如果没有阅读过,那么就给专栏文章的UV、作者的UV进行加一
|
|
|
+ if totalRecord == 0 {
|
|
|
+ e = models.UpdateYanxuanSpecialUv(specialId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("UpdateYanxuanSpecialUv, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //专栏作者Uv数量进行加一
|
|
|
+ e = models.UpdateCygxYanxuanSpecialAuthorUv(user.UserId)
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("UpdateCygxYanxuanSpecialAuthorUv, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- //item := models.CygxYanxuanSpecialRecord{
|
|
|
- // UserId: user.UserId,
|
|
|
- // Mobile: user.Mobile,
|
|
|
- // Email: user.Email,
|
|
|
- // CompanyId: user.CompanyId,
|
|
|
- // CompanyName: user.CompanyName,
|
|
|
- // RealName: user.RealName,
|
|
|
- // SellerName: sellerName,
|
|
|
- // CreateTime: time.Now(),
|
|
|
- // ModifyTime: time.Now(),
|
|
|
- // RegisterPlatform: utils.REGISTER_PLATFORM,
|
|
|
- // YanxuanSpecialId: specialId,
|
|
|
- //}
|
|
|
-
|
|
|
+ itemLog := new(models.CygxYanxuanSpecialRecordLog)
|
|
|
+ itemLog.UserId = user.UserId
|
|
|
+ itemLog.Mobile = user.Mobile
|
|
|
+ itemLog.Email = user.Email
|
|
|
+ itemLog.CompanyId = user.CompanyId
|
|
|
+ itemLog.CompanyName = user.CompanyName
|
|
|
+ itemLog.RealName = user.RealName
|
|
|
+ itemLog.SellerName = sellerName
|
|
|
+ itemLog.CreateTime = time.Now().Add(-time.Duration(stopTime) * time.Second) // 往前推迟的时间就是他的阅读时间
|
|
|
+ itemLog.ModifyTime = time.Now()
|
|
|
+ itemLog.RegisterPlatform = utils.REGISTER_PLATFORM
|
|
|
+ itemLog.YanxuanSpecialId = specialId
|
|
|
+ _, e = models.AddCygxYanxuanSpecialRecordLog(itemLog) // 添加历史记录
|
|
|
+ if e != nil {
|
|
|
+ err = errors.New("AddCygxYanxuanSpecialRecordLog, Err: " + e.Error())
|
|
|
+ return
|
|
|
+ }
|
|
|
+ return
|
|
|
}
|