cygx_activity_video_history.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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. var err error
  51. defer func() {
  52. if err != nil {
  53. go utils.SendAlarmMsg(fmt.Sprint("添加活动视频的播放记录失败 AddActivityVideoHistory Err:", err.Error(), "活动ID:", activityId, "UserId:", user.UserId), 2)
  54. }
  55. }()
  56. activityVideoInfo, e := models.GetCygxActivityVideoByActivityId(activityId)
  57. if e != nil {
  58. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  59. return
  60. }
  61. item := new(models.CygxActivityVideoHistory)
  62. item.UserId = user.UserId
  63. item.RealName = user.RealName
  64. item.ActivityId = activityId
  65. item.VideoId = activityVideoInfo.VideoId
  66. item.PlaySeconds = strconv.Itoa(playSeconds)
  67. item.Mobile = user.Mobile
  68. item.Email = user.Email
  69. item.CompanyId = user.CompanyId
  70. item.CompanyName = user.CompanyName
  71. item.CreateTime = time.Now()
  72. item.ModifyTime = time.Now()
  73. item.RegisterPlatform = utils.REGISTER_PLATFORM
  74. sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  75. if e != nil && e.Error() != utils.ErrNoRow() {
  76. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  77. return
  78. }
  79. if sellerItem != nil {
  80. item.SellerName = sellerItem.RealName
  81. }
  82. //小程序端的回传两次,第一次没有播放时长,第二次有播放时长
  83. if playSeconds != 0 {
  84. lastItem, e := models.GetLastCygxActivityVideoHistory(activityId, user.UserId)
  85. if e != nil {
  86. err = errors.New("GetLastCygxActivityVideoHistory, Err: " + e.Error())
  87. return
  88. }
  89. //更新播放时长
  90. e = models.UpdateLastCygxActivityVideoHistory(strconv.Itoa(playSeconds), lastItem.Id)
  91. if e != nil {
  92. err = errors.New("UpdateLastCygxActivityVideoHistory, Err: " + e.Error())
  93. return
  94. }
  95. } else {
  96. //添加记录
  97. e = models.AddCygxActivityVideoHistory(item)
  98. if e != nil {
  99. err = errors.New("AddCygxActivityVideoHistory, Err: " + e.Error())
  100. return
  101. }
  102. //播放记录加1
  103. e = models.UpdateActivityVideoCounts(activityId)
  104. if e != nil {
  105. err = errors.New("UpdateActivityVideoCounts, Err: " + e.Error())
  106. return
  107. }
  108. //设置消息提醒
  109. go ActivityVideoUserRmind(user, activityId, 1)
  110. }
  111. return
  112. }
  113. // 记录用户活动音频播放记录
  114. func AddActivityVoiceHistory(user *models.WxUserItem, activityId, playSeconds int) {
  115. var err error
  116. defer func() {
  117. if err != nil {
  118. go utils.SendAlarmMsg(fmt.Sprint("记录用户活动音频播放记录失败 AddActivityVoiceHistory Err:", err.Error(), "活动ID:", activityId, "UserId:", user.UserId), 2)
  119. }
  120. }()
  121. item := new(models.CygxActivityVoiceHistory)
  122. item.UserId = user.UserId
  123. item.RealName = user.RealName
  124. item.ActivityId = activityId
  125. item.PlaySeconds = strconv.Itoa(playSeconds)
  126. item.Mobile = user.Mobile
  127. item.Email = user.Email
  128. item.CompanyId = user.CompanyId
  129. item.CompanyName = user.CompanyName
  130. item.CreateTime = time.Now()
  131. item.ModifyTime = time.Now()
  132. item.RegisterPlatform = utils.REGISTER_PLATFORM
  133. sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  134. if e != nil && e.Error() != utils.ErrNoRow() {
  135. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  136. return
  137. }
  138. if sellerItem != nil {
  139. item.SellerName = sellerItem.RealName
  140. }
  141. //小程序端的回传两次,第一次没有播放时长,第二次有播放时长
  142. if playSeconds != 0 {
  143. lastItem, e := models.GetLastCygxActivityVoiceHistory(activityId, user.UserId)
  144. if e != nil {
  145. err = errors.New("GetLastCygxActivityVoiceHistory, Err: " + e.Error())
  146. return
  147. }
  148. e = models.UpdateLastCygxActivityVoiceHistory(strconv.Itoa(playSeconds), lastItem.Id)
  149. if e != nil {
  150. err = errors.New("UpdateLastCygxActivityVoiceHistory, Err: " + e.Error())
  151. return
  152. }
  153. } else {
  154. //添加记录
  155. e = models.AddCygxActivityVoiceHistory(item)
  156. if e != nil {
  157. err = errors.New("AddCygxActivityVoiceHistory, Err: " + e.Error())
  158. return
  159. }
  160. //播放记录加1
  161. e = models.UpdateCygxActivityVoiceCounts(activityId)
  162. if e != nil {
  163. err = errors.New("UpdateCygxActivityVoiceCounts, Err: " + e.Error())
  164. return
  165. }
  166. //设置消息提醒
  167. go ActivityVideoUserRmind(user, activityId, 2)
  168. }
  169. return
  170. }