main.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. package main
  2. import (
  3. _ "eta/eta_mini_ht_api/common/component"
  4. logger "eta/eta_mini_ht_api/common/component/log"
  5. "eta/eta_mini_ht_api/common/contants"
  6. "eta/eta_mini_ht_api/common/exception"
  7. "eta/eta_mini_ht_api/domian/report"
  8. "eta/eta_mini_ht_api/models/eta"
  9. "eta/eta_mini_ht_api/models/ht"
  10. _ "eta/eta_mini_ht_api/routers"
  11. _ "eta/eta_mini_ht_api/task"
  12. "github.com/beego/beego/v2/server/web"
  13. "sync"
  14. "time"
  15. )
  16. func main() {
  17. if web.BConfig.RunMode == "dev" {
  18. web.BConfig.WebConfig.DirectoryIndex = true
  19. web.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
  20. }
  21. //web.ErrorHandler("*", exception.ControllerAdvice())
  22. web.BConfig.RecoverFunc = exception.PanicAdvice
  23. go func() {
  24. //内存数据预热预加载
  25. logger.Info("开始预加载数据")
  26. //初始化研报库
  27. initReport()
  28. }()
  29. logger.Info("初始化成功")
  30. web.Run()
  31. }
  32. func initReport() {
  33. var wg sync.WaitGroup
  34. wg.Add(2)
  35. logger.Info("开始初始化研报库")
  36. go func() {
  37. defer wg.Done()
  38. for {
  39. id, err := report.GetETALatestReportId()
  40. var etaReportList []eta.ETAReport
  41. etaReportList, err = eta.GetETAReports(id)
  42. if err != nil {
  43. logger.Error("获取ETA研报列表失败:%v", err)
  44. }
  45. if len(etaReportList) > 0 {
  46. err = report.InitETAReportList(etaReportList)
  47. if err != nil {
  48. logger.Error("同步ETA研报列表失败:%v", err)
  49. }
  50. } else {
  51. logger.Info(contants.TaskFormat, "同步ETA研报库结束")
  52. break
  53. }
  54. }
  55. }()
  56. go func() {
  57. defer wg.Done()
  58. for {
  59. id, err := report.GetHTLatestReportId()
  60. var htReportList []ht.HTReport
  61. htReportList, err = ht.GetHTReports(id)
  62. if err != nil {
  63. logger.Error("获取ETA研报列表失败:%v", err)
  64. }
  65. if len(htReportList) > 0 {
  66. for i := 0; i < len(htReportList); i++ {
  67. timestamp := int64(htReportList[i].PublishTime)
  68. t := time.UnixMilli(timestamp)
  69. htReportList[i].PublishedTime = t.Format(time.DateTime)
  70. plateId := htReportList[i].PlateId
  71. plate, err := ht.GetPermissionNameById(plateId)
  72. if err != nil || plate.ParentId == 0 {
  73. htReportList[i].PermissionName = htReportList[i].PlateName
  74. } else {
  75. PermissionName, err := getPermissionNameById(plate.ParentId)
  76. if err != nil {
  77. logger.Error("获取ETA研报列表失败:%v", err)
  78. htReportList[i].PermissionName = ""
  79. } else {
  80. htReportList[i].PermissionName = PermissionName
  81. }
  82. }
  83. }
  84. var stop bool
  85. stop, err = report.InitHTReportList(htReportList)
  86. if err != nil {
  87. logger.Error("同步ETA研报列表失败:%v", err)
  88. break
  89. }
  90. if stop {
  91. logger.Info(contants.TaskFormat, "同步HT研报库结束")
  92. break
  93. }
  94. } else {
  95. logger.Info(contants.TaskFormat, "同步HT研报库结束")
  96. break
  97. }
  98. }
  99. }()
  100. wg.Wait()
  101. logger.Info("初始化研报库完成")
  102. }
  103. func getPermissionNameById(id int) (name string, err error) {
  104. plate, err := ht.GetPermissionNameById(id)
  105. if err != nil {
  106. return
  107. }
  108. if plate.ParentId != 0 {
  109. return getPermissionNameById(plate.ParentId)
  110. } else {
  111. return plate.PlateName, nil
  112. }
  113. }