base_from_ly.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. // @Author gmy 2024/8/13 16:01:00
  2. package controllers
  3. import (
  4. "encoding/json"
  5. "eta/eta_index_lib/logic"
  6. "eta/eta_index_lib/models"
  7. "eta/eta_index_lib/services"
  8. "eta/eta_index_lib/utils"
  9. "strconv"
  10. "time"
  11. )
  12. type BaseFromLyController struct {
  13. BaseAuthController
  14. }
  15. // Add
  16. // @Title 新增粮油商务网指标
  17. // @Description 新增粮油商务网指标
  18. // @router /add [post]
  19. func (this *BaseFromLyController) Add() {
  20. br := new(models.BaseResponse).Init()
  21. var cacheKey string
  22. defer func() {
  23. utils.Rc.Delete(cacheKey)
  24. this.Data["json"] = br
  25. this.ServeJSON()
  26. }()
  27. source := utils.DATA_SOURCE_LY
  28. var req models.AddEdbInfoReq
  29. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  30. if err != nil {
  31. br.Msg = "参数解析异常!"
  32. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  33. return
  34. }
  35. if req.EdbCode == "" {
  36. br.Msg = "请输入指标编码!"
  37. br.ErrMsg = "请输入指标编码,指标编码为空"
  38. return
  39. }
  40. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  41. if !utils.Rc.IsExist(cacheKey) {
  42. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  43. err = models.AddEdbDataFromLy(req.EdbCode)
  44. if err != nil {
  45. br.Msg = "获取指标信息失败!"
  46. br.ErrMsg = "获取指标信息失败 AddEdbDataFromSci99,Err:" + err.Error()
  47. return
  48. }
  49. br.Ret = 200
  50. br.Success = true
  51. br.Msg = "获取成功"
  52. } else {
  53. br.Ret = 501
  54. br.Success = true
  55. br.Msg = "系统处理中,请稍后重试"
  56. }
  57. }
  58. // Refresh
  59. // @Title 刷新粮油商务网指标接口
  60. // @Description 刷新粮油商务网指标接口
  61. // @Success 200 {object} models.RefreshEdbInfoReq
  62. // @router /refresh [post]
  63. func (this *BaseFromLyController) Refresh() {
  64. br := new(models.BaseResponse).Init()
  65. var cacheKey string
  66. defer func() {
  67. if br.ErrMsg == "" {
  68. br.IsSendEmail = false
  69. }
  70. _ = utils.Rc.Delete(cacheKey)
  71. this.Data["json"] = br
  72. this.ServeJSON()
  73. }()
  74. source := utils.DATA_SOURCE_LY
  75. var req models.RefreshEdbInfoReq
  76. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  77. if err != nil {
  78. br.Msg = "参数解析异常!"
  79. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  80. return
  81. }
  82. if req.EdbCode == "" {
  83. br.Msg = "请输入指标编码!"
  84. br.ErrMsg = "请输入指标编码,指标编码为空"
  85. return
  86. }
  87. if req.EdbInfoId <= 0 {
  88. br.Msg = "请输入指标ID!"
  89. br.ErrMsg = "请输入指标ID"
  90. return
  91. }
  92. // 获取指标详情
  93. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  94. if err != nil {
  95. br.Msg = "指标不存在!"
  96. br.ErrMsg = "指标不存在"
  97. return
  98. }
  99. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  100. if utils.Rc.IsExist(cacheKey) {
  101. br.Ret = 501
  102. br.Success = true
  103. br.Msg = "系统处理中,请稍后重试"
  104. return
  105. }
  106. dataUpdateTime := time.Now().Format(utils.FormatDateTime)
  107. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  108. err = models.RefreshEdbDataFromBloomberg(req.EdbInfoId, req.EdbCode, req.StartDate)
  109. if err != nil && err.Error() != utils.ErrNoRow() {
  110. br.Msg = "刷新指标信息失败!"
  111. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromBloomberg,Err:" + err.Error()
  112. return
  113. }
  114. // 更新指标最大最小值
  115. erDataUpdateDate, err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfoDataUpdate(edbInfo, dataUpdateTime)
  116. if err != nil {
  117. br.Msg = errMsg
  118. br.ErrMsg = err.Error()
  119. return
  120. }
  121. // 添加指标刷新成功日志
  122. if erDataUpdateDate != "" {
  123. _ = services.AddEdbInfoUpdateLog(edbInfo.EdbInfoId, 1, "", 1, "", 0, 0)
  124. } else {
  125. _ = services.AddEdbInfoUpdateLog(edbInfo.EdbInfoId, 1, "", 2, "未刷新到数据", 0, 0)
  126. }
  127. // 更新ES
  128. go logic.UpdateEs(edbInfo.EdbInfoId)
  129. br.Ret = 200
  130. br.Success = true
  131. br.Msg = "获取成功"
  132. }