cygx_activity_video_history.go 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  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. // 添加活动的视频播放记录
  11. //func AddActivityVideoHistory(user *models.WxUserItem, activityId int) (err error) {
  12. // activityInfo, errInfo := models.GetCygxActivityVideoByActivityId(activityId)
  13. // if activityInfo == nil {
  14. // return
  15. // }
  16. // if errInfo != nil {
  17. // return
  18. // }
  19. // var sellerName string
  20. // sellerName, err = models.GetCompanySellerName(user.CompanyId)
  21. // if err != nil {
  22. // return
  23. // }
  24. // item := models.CygxActivityVideoHistory{
  25. // ActivityId: activityInfo.ActivityId,
  26. // VideoId: activityInfo.VideoId,
  27. // UserId: user.UserId,
  28. // CreateTime: time.Now(),
  29. // Mobile: user.Mobile,
  30. // Email: user.Email,
  31. // CompanyId: user.CompanyId,
  32. // CompanyName: user.CompanyName,
  33. // RealName: user.RealName,
  34. // SellerName: sellerName,
  35. // ModifyTime: time.Now(),
  36. // }
  37. // err = models.AddCygxActivityVideoHistory(&item)
  38. // if err != nil {
  39. // return
  40. // }
  41. // err = models.UpdateActivityVideoCounts(activityInfo.ActivityId)
  42. // if err != nil {
  43. // return
  44. // }
  45. // go ActivityVideoUserRmind(user, activityId, 1)
  46. // return
  47. //}
  48. // 添加活动视频的播放记录
  49. func AddActivityVideoHistory(user *models.WxUserItem, activityId, playSeconds int) {
  50. // 十分钟之内的合并
  51. key := utils.CYGX_VIDEO_HISTORY_KEY + utils.CYGX_OBJ_ACTIVITYVIDEO + strconv.Itoa(activityId) + "_" + strconv.Itoa(user.UserId)
  52. if utils.Rc.IsExist(key) {
  53. return
  54. }
  55. utils.Rc.Put(key, 1, 10*time.Minute)
  56. var err error
  57. defer func() {
  58. if err != nil {
  59. go utils.SendAlarmMsg(fmt.Sprint("添加活动视频的播放记录失败 AddActivityVideoHistory Err:", err.Error(), "活动ID:", activityId, "UserId:", user.UserId), 2)
  60. }
  61. }()
  62. activityVideoInfo, e := models.GetCygxActivityVideoByActivityId(activityId)
  63. if e != nil {
  64. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  65. return
  66. }
  67. item := new(models.CygxActivityVideoHistory)
  68. item.UserId = user.UserId
  69. item.RealName = user.RealName
  70. item.ActivityId = activityId
  71. item.VideoId = activityVideoInfo.VideoId
  72. item.PlaySeconds = strconv.Itoa(playSeconds)
  73. item.Mobile = user.Mobile
  74. item.Email = user.Email
  75. item.CompanyId = user.CompanyId
  76. item.CompanyName = user.CompanyName
  77. item.CreateTime = time.Now()
  78. item.ModifyTime = time.Now()
  79. item.RegisterPlatform = utils.REGISTER_PLATFORM
  80. sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  81. if e != nil && e.Error() != utils.ErrNoRow() {
  82. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  83. return
  84. }
  85. if sellerItem != nil {
  86. item.SellerName = sellerItem.RealName
  87. }
  88. //添加记录
  89. e = models.AddCygxActivityVideoHistory(item)
  90. if e != nil {
  91. err = errors.New("AddCygxActivityVideoHistory, Err: " + e.Error())
  92. return
  93. }
  94. //播放记录加1
  95. e = models.UpdateActivityVideoCounts(activityId)
  96. if e != nil {
  97. err = errors.New("UpdateActivityVideoCounts, Err: " + e.Error())
  98. return
  99. }
  100. //设置消息提醒
  101. go ActivityVideoUserRmind(user, activityId, 1)
  102. go ActivityVivoWxUserRaiLabelRedisAdd(activityId, user.UserId, item.CreateTime) // 添加用户播放活动音视频标签到Redis
  103. //if !utils.Rc.IsExist(key) {
  104. // //添加记录
  105. // e = models.AddCygxActivityVideoHistory(item)
  106. // if e != nil {
  107. // err = errors.New("AddCygxActivityVideoHistory, Err: " + e.Error())
  108. // return
  109. // }
  110. // //播放记录加1
  111. // e = models.UpdateActivityVideoCounts(activityId)
  112. // if e != nil {
  113. // err = errors.New("UpdateActivityVideoCounts, Err: " + e.Error())
  114. // return
  115. // }
  116. // //设置消息提醒
  117. // go ActivityVideoUserRmind(user, activityId, 1)
  118. //
  119. // utils.Rc.Put(key, 1, 10*time.Minute)
  120. //} else {
  121. // lastItem, e := models.GetLastCygxActivityVideoHistory(activityId, user.UserId)
  122. // if e != nil {
  123. // err = errors.New("GetLastCygxActivityVideoHistory, Err: " + e.Error())
  124. // return
  125. // }
  126. // //更新播放时长
  127. // e = models.UpdateLastCygxActivityVideoHistory(strconv.Itoa(playSeconds), lastItem.Id)
  128. // if e != nil {
  129. // err = errors.New("UpdateLastCygxActivityVideoHistory, Err: " + e.Error())
  130. // return
  131. // }
  132. //}
  133. ////小程序端的回传两次,第一次没有播放时长,第二次有播放时长
  134. //if playSeconds != 0 {
  135. // lastItem, e := models.GetLastCygxActivityVideoHistory(activityId, user.UserId)
  136. // if e != nil {
  137. // err = errors.New("GetLastCygxActivityVideoHistory, Err: " + e.Error())
  138. // return
  139. // }
  140. // //更新播放时长
  141. // e = models.UpdateLastCygxActivityVideoHistory(strconv.Itoa(playSeconds), lastItem.Id)
  142. // if e != nil {
  143. // err = errors.New("UpdateLastCygxActivityVideoHistory, Err: " + e.Error())
  144. // return
  145. // }
  146. //
  147. // utils.Rc.Put(key, 1, 10*time.Minute)
  148. //} else {
  149. // //添加记录
  150. // e = models.AddCygxActivityVideoHistory(item)
  151. // if e != nil {
  152. // err = errors.New("AddCygxActivityVideoHistory, Err: " + e.Error())
  153. // return
  154. // }
  155. // //播放记录加1
  156. // e = models.UpdateActivityVideoCounts(activityId)
  157. // if e != nil {
  158. // err = errors.New("UpdateActivityVideoCounts, Err: " + e.Error())
  159. // return
  160. // }
  161. // //设置消息提醒
  162. // go ActivityVideoUserRmind(user, activityId, 1)
  163. //}
  164. return
  165. }
  166. // 记录用户活动音频播放记录
  167. func AddActivityVoiceHistory(user *models.WxUserItem, activityId, playSeconds int) {
  168. if playSeconds == 0 {
  169. return
  170. }
  171. key := utils.CYGX_VIDEO_HISTORY_KEY + utils.CYGX_OBJ_ACTIVITYVOICE + strconv.Itoa(activityId) + "_" + strconv.Itoa(user.UserId)
  172. var err error
  173. defer func() {
  174. if err != nil {
  175. go utils.SendAlarmMsg(fmt.Sprint("记录用户活动音频播放记录失败 AddActivityVoiceHistory Err:", err.Error(), "活动ID:", activityId, "UserId:", user.UserId), 2)
  176. }
  177. }()
  178. item := new(models.CygxActivityVoiceHistory)
  179. item.UserId = user.UserId
  180. item.RealName = user.RealName
  181. item.ActivityId = activityId
  182. item.PlaySeconds = strconv.Itoa(playSeconds)
  183. item.Mobile = user.Mobile
  184. item.Email = user.Email
  185. item.CompanyId = user.CompanyId
  186. item.CompanyName = user.CompanyName
  187. item.CreateTime = time.Now()
  188. item.ModifyTime = time.Now()
  189. item.RegisterPlatform = utils.REGISTER_PLATFORM
  190. sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  191. if e != nil && e.Error() != utils.ErrNoRow() {
  192. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  193. return
  194. }
  195. if sellerItem != nil {
  196. item.SellerName = sellerItem.RealName
  197. }
  198. if !utils.Rc.IsExist(key) {
  199. //添加记录
  200. e = models.AddCygxActivityVoiceHistory(item)
  201. if e != nil {
  202. err = errors.New("AddCygxActivityVoiceHistory, Err: " + e.Error())
  203. return
  204. }
  205. //播放记录加1
  206. e = models.UpdateCygxActivityVoiceCounts(activityId)
  207. if e != nil {
  208. err = errors.New("UpdateCygxActivityVoiceCounts, Err: " + e.Error())
  209. return
  210. }
  211. utils.Rc.Put(key, 1, 10*time.Minute)
  212. //设置消息提醒
  213. go ActivityVideoUserRmind(user, activityId, 2)
  214. } else {
  215. lastItem, e := models.GetLastCygxActivityVoiceHistory(activityId, user.UserId)
  216. if e != nil {
  217. err = errors.New("GetLastCygxActivityVoiceHistory, Err: " + e.Error())
  218. return
  219. }
  220. e = models.UpdateLastCygxActivityVoiceHistory(strconv.Itoa(playSeconds), lastItem.Id)
  221. if e != nil {
  222. err = errors.New("UpdateLastCygxActivityVoiceHistory, Err: " + e.Error())
  223. return
  224. }
  225. }
  226. go ActivityVivoWxUserRaiLabelRedisAdd(activityId, user.UserId, item.CreateTime) // 添加用户播放活动音视频标签到Redis
  227. //小程序端的回传两次,第一次没有播放时长,第二次有播放时长
  228. //if playSeconds != 0 {
  229. // lastItem, e := models.GetLastCygxActivityVoiceHistory(activityId, user.UserId)
  230. // if e != nil {
  231. // err = errors.New("GetLastCygxActivityVoiceHistory, Err: " + e.Error())
  232. // return
  233. // }
  234. // e = models.UpdateLastCygxActivityVoiceHistory(strconv.Itoa(playSeconds), lastItem.Id)
  235. // if e != nil {
  236. // err = errors.New("UpdateLastCygxActivityVoiceHistory, Err: " + e.Error())
  237. // return
  238. // }
  239. // utils.Rc.Put(key, 1, 10*time.Second)
  240. //} else {
  241. // //添加记录
  242. // e = models.AddCygxActivityVoiceHistory(item)
  243. // if e != nil {
  244. // err = errors.New("AddCygxActivityVoiceHistory, Err: " + e.Error())
  245. // return
  246. // }
  247. // //播放记录加1
  248. // e = models.UpdateCygxActivityVoiceCounts(activityId)
  249. // if e != nil {
  250. // err = errors.New("UpdateCygxActivityVoiceCounts, Err: " + e.Error())
  251. // return
  252. // }
  253. // //设置消息提醒
  254. // go ActivityVideoUserRmind(user, activityId, 2)
  255. //}
  256. return
  257. }