package services import ( "errors" "fmt" "hongze/hongze_mfyx/models" "hongze/hongze_mfyx/utils" "time" ) // 记录用户阅读时长 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) } }() if user.CompanyId <= 1 { return } var sellerName string //获取销售信息 sellerItem, _ := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2) if sellerItem == nil { 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 item.Email = user.Email item.CompanyId = user.CompanyId item.CompanyName = user.CompanyName item.RealName = user.RealName item.SellerName = sellerName item.CreateTime = time.Now().Add(-time.Duration(stopTime) * time.Second) // 往前推迟的时间就是他的阅读时间 item.ModifyTime = time.Now() item.RegisterPlatform = utils.REGISTER_PLATFORM item.YanxuanSpecialId = specialId 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 } } } } 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 itemLog.StopTime = stopTime _, e := models.AddCygxYanxuanSpecialRecordLog(itemLog) // 添加历史记录 if e != nil { err = errors.New("AddCygxYanxuanSpecialRecordLog, Err: " + e.Error()) return } return }