cygx_yanxuan_special_company.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. package services
  2. import (
  3. "context"
  4. "encoding/json"
  5. "errors"
  6. "fmt"
  7. "hongze/hongze_cygx/models"
  8. "hongze/hongze_cygx/utils"
  9. "io/ioutil"
  10. "net/http"
  11. "time"
  12. )
  13. func GetStocksFromVmp(cont context.Context) (err error) {
  14. defer func() {
  15. if err != nil {
  16. fmt.Println("err:", err)
  17. go utils.SendAlarmMsg("更新上市公司表失败"+err.Error(), 2)
  18. }
  19. }()
  20. err = models.DelYanxuanSpecialCompany()
  21. if err != nil {
  22. fmt.Println("获取上市公司信息失败 Err:%s", err.Error())
  23. return
  24. }
  25. getUrl := "https://vmp.hzinsights.com/v2api/articles/stock"
  26. result, err := http.Get(getUrl)
  27. if err != nil {
  28. return
  29. }
  30. defer result.Body.Close()
  31. body, err := ioutil.ReadAll(result.Body)
  32. if err != nil {
  33. fmt.Println("err:" + err.Error())
  34. return
  35. }
  36. fmt.Println(body)
  37. var resp models.VmpStocks
  38. err = json.Unmarshal(body, &resp)
  39. if err != nil {
  40. fmt.Println("获取上市公司信息失败 Err:%s", err.Error())
  41. return
  42. }
  43. items := make([]*models.CygxYanxuanSpecialCompany, 0)
  44. for i, _ := range resp.Data {
  45. items = append(items, &resp.Data[i])
  46. if len(items) > 5000 {
  47. err = models.AddCygxYanxuanSpecialCompanyMulti(items)
  48. if err != nil {
  49. fmt.Println("AddCygxYanxuanSpecialCompanyMulti Err:%s", err.Error())
  50. return
  51. }
  52. items = []*models.CygxYanxuanSpecialCompany{}
  53. }
  54. }
  55. err = models.AddCygxYanxuanSpecialCompanyMulti(items)
  56. if err != nil {
  57. fmt.Println("AddCygxYanxuanSpecialCompanyMulti Err:%s", err.Error())
  58. return
  59. }
  60. return
  61. }
  62. // 记录用户阅读时长
  63. func AddSpecialRecord(user *models.WxUserItem, specialId, stopTime int) (err error) {
  64. defer func() {
  65. if err != nil {
  66. go utils.SendAlarmMsg(fmt.Sprint("记录用户阅读时长 失败 AddSpecialRecord Err:"+err.Error(), "userId:", user.UserId, "specialId:", specialId), 2)
  67. }
  68. }()
  69. var sellerName string
  70. //获取销售信息
  71. sellerItem, e := models.GetSellerByCompanyIdCheckFicc(user.CompanyId, 2)
  72. if e != nil {
  73. err = errors.New("GetSellerByCompanyIdCheckFicc, Err: " + e.Error())
  74. return
  75. }
  76. sellerName = sellerItem.RealName
  77. if stopTime >= 3 {
  78. //判断一个用户是否阅读过 某一篇研选专栏
  79. totalRecord, e := models.GetCygxYanxuanSpecialRecordCountByUser(user.UserId, specialId)
  80. if e != nil {
  81. err = errors.New("GetCygxYanxuanSpecialRecordCountByUser, Err: " + e.Error())
  82. return
  83. }
  84. item := new(models.CygxYanxuanSpecialRecord)
  85. item.UserId = user.UserId
  86. item.Mobile = user.Mobile
  87. item.Email = user.Email
  88. item.CompanyId = user.CompanyId
  89. item.CompanyName = user.CompanyName
  90. item.RealName = user.RealName
  91. item.SellerName = sellerName
  92. item.CreateTime = time.Now().Add(-time.Duration(stopTime) * time.Second) // 往前推迟的时间就是他的阅读时间
  93. item.ModifyTime = time.Now()
  94. item.RegisterPlatform = utils.REGISTER_PLATFORM
  95. item.YanxuanSpecialId = specialId
  96. item.StopTime = stopTime
  97. _, e = models.AddCygxYanxuanSpecialRecord(item) // 添加历史记录
  98. if e != nil {
  99. err = errors.New("AddCygxYanxuanSpecialRecord, Err: " + e.Error())
  100. return
  101. }
  102. //如果不是弘则研究的人员阅读的,就修改Pv、Uv数量
  103. if user.CompanyId != utils.HZ_COMPANY_ID {
  104. //专栏Pv数量进行加一
  105. e = models.UpdateYanxuanSpecialPv(specialId)
  106. if e != nil {
  107. err = errors.New("UpdateYanxuanSpecialPv, Err: " + e.Error())
  108. return
  109. }
  110. //专栏作者Pv数量进行加一
  111. e = models.UpdateCygxYanxuanSpecialAuthorPv(user.UserId)
  112. if e != nil {
  113. err = errors.New("UpdateCygxYanxuanSpecialAuthorPv, Err: " + e.Error())
  114. return
  115. }
  116. //如果没有阅读过,那么就给专栏文章的UV、作者的UV进行加一
  117. if totalRecord == 0 {
  118. e = models.UpdateYanxuanSpecialUv(specialId)
  119. if e != nil {
  120. err = errors.New("UpdateYanxuanSpecialUv, Err: " + e.Error())
  121. return
  122. }
  123. //专栏作者Uv数量进行加一
  124. e = models.UpdateCygxYanxuanSpecialAuthorUv(user.UserId)
  125. if e != nil {
  126. err = errors.New("UpdateCygxYanxuanSpecialAuthorUv, Err: " + e.Error())
  127. return
  128. }
  129. }
  130. }
  131. }
  132. itemLog := new(models.CygxYanxuanSpecialRecordLog)
  133. itemLog.UserId = user.UserId
  134. itemLog.Mobile = user.Mobile
  135. itemLog.Email = user.Email
  136. itemLog.CompanyId = user.CompanyId
  137. itemLog.CompanyName = user.CompanyName
  138. itemLog.RealName = user.RealName
  139. itemLog.SellerName = sellerName
  140. itemLog.CreateTime = time.Now().Add(-time.Duration(stopTime) * time.Second) // 往前推迟的时间就是他的阅读时间
  141. itemLog.ModifyTime = time.Now()
  142. itemLog.RegisterPlatform = utils.REGISTER_PLATFORM
  143. itemLog.YanxuanSpecialId = specialId
  144. itemLog.StopTime = stopTime
  145. _, e = models.AddCygxYanxuanSpecialRecordLog(itemLog) // 添加历史记录
  146. if e != nil {
  147. err = errors.New("AddCygxYanxuanSpecialRecordLog, Err: " + e.Error())
  148. return
  149. }
  150. return
  151. }