task.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package services
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_api/cache"
  6. "hongze/hongze_api/models"
  7. "hongze/hongze_api/services/alarm_msg"
  8. "hongze/hongze_api/services/go_redis"
  9. "hongze/hongze_api/utils"
  10. "time"
  11. )
  12. func Task() {
  13. fmt.Println("start")
  14. //InitSetUnionId()
  15. //FixUnionId()
  16. fmt.Println("end")
  17. go AutoUpdateUserView()
  18. }
  19. // AutoUpdateUserView 自动添加阅读记录
  20. func AutoUpdateUserView() {
  21. defer func() {
  22. if err := recover(); err != nil {
  23. fmt.Println("[AutoUpdateUserView]", err)
  24. }
  25. }()
  26. for {
  27. go_redis.BRPop2Func(utils.CACHE_KEY_USER_VIEW, func(b []byte) {
  28. var userViewRedisData cache.UserViewRedisData
  29. if err := json.Unmarshal(b, &userViewRedisData); err != nil {
  30. //fmt.Println(utils.APPNAME + " " + utils.RunMode + " 失败提醒:" + fmt.Sprint("AutoUpdateUserView ERR:", err, ";response data:", string(b)))
  31. go alarm_msg.SendAlarmMsg(utils.APPNAME+" "+utils.RunMode+" 失败提醒:"+fmt.Sprint("AutoUpdateUserView ERR:", err, ";response data:", string(b)), 2)
  32. //}
  33. //if _, err := models.AddLogs(&log); err != nil {
  34. // fmt.Println("AddLogs:", err.Error(), log)
  35. } else {
  36. // 客户的阅读时间
  37. err = models.UpdateCompanyProductViewData(userViewRedisData.CompanyId, userViewRedisData.ProductId, userViewRedisData.ViewTime)
  38. if err != nil {
  39. //fmt.Println(utils.APPNAME + " " + utils.RunMode + " 失败提醒:" + fmt.Sprint("AutoUpdateUserView Update UpdateCompanyProductViewData ERR:", err, ";response data:", string(b)))
  40. go alarm_msg.SendAlarmMsg(utils.APPNAME+" "+utils.RunMode+" 失败提醒:"+fmt.Sprint("AutoUpdateUserView Update UpdateCompanyProductViewData ERR:", err, ";response data:", string(b)), 2)
  41. }
  42. // 添加报告阅读汇总记录
  43. {
  44. source := userViewRedisData.Source
  45. if source == 0 {
  46. if userViewRedisData.ProductId == 2 {
  47. source = 4
  48. } else {
  49. source = 1
  50. }
  51. }
  52. item := &models.UserReportViewRecord{
  53. Id: 1,
  54. Source: source,
  55. UserId: userViewRedisData.UserId,
  56. ReportId: userViewRedisData.ReportId,
  57. ReportChapterId: userViewRedisData.ReportChapterId,
  58. Mobile: userViewRedisData.Mobile,
  59. Email: userViewRedisData.Email,
  60. RealName: userViewRedisData.RealName,
  61. CompanyName: userViewRedisData.CompanyName,
  62. StopTime: userViewRedisData.StopTime,
  63. OutId: fmt.Sprint(userViewRedisData.OutId),
  64. CreateTime: userViewRedisData.ViewTime,
  65. }
  66. viewTime, tmpErr := time.ParseInLocation(utils.FormatDateTime, userViewRedisData.ViewTime, time.Local)
  67. if tmpErr != nil {
  68. //fmt.Println(utils.APPNAME+" "+utils.RunMode+" 失败提醒", fmt.Sprint("AutoUpdateUserView ADD UserReportViewRecord ERR:", tmpErr, ";response data:", string(b)))
  69. go utils.SendEmail(utils.APPNAME+" "+utils.RunMode+" 失败提醒", fmt.Sprint("AutoUpdateUserView ADD UserReportViewRecord ERR:", tmpErr, ";response data:", string(b)), utils.EmailSendToUsers)
  70. } else {
  71. err = item.Insert(viewTime.Year(), item)
  72. if err != nil {
  73. //fmt.Println(utils.APPNAME+" "+utils.RunMode+" 失败提醒", fmt.Sprint("AutoUpdateUserView ADD UserReportViewRecord ERR:", err, ";response data:", string(b)))
  74. go utils.SendEmail(utils.APPNAME+" "+utils.RunMode+" 失败提醒", fmt.Sprint("AutoUpdateUserView ADD UserReportViewRecord ERR:", err, ";response data:", string(b)), utils.EmailSendToUsers)
  75. }
  76. }
  77. }
  78. // 联系人的阅读时间
  79. err = models.UpdateWxUserViewData(userViewRedisData.UserId, userViewRedisData.ProductId, userViewRedisData.ViewTime)
  80. if err != nil {
  81. //fmt.Println(utils.APPNAME + " " + utils.RunMode + " 失败提醒:" + fmt.Sprint("AutoUpdateUserView Update UpdateWxUserViewData ERR:", err, ";response data:", string(b)))
  82. go alarm_msg.SendAlarmMsg(utils.APPNAME+" "+utils.RunMode+" 失败提醒:"+fmt.Sprint("AutoUpdateUserView Update UpdateWxUserViewData ERR:", err, ";response data:", string(b)), 2)
  83. }
  84. }
  85. })
  86. }
  87. }