base_from_ly.go 3.7 KB

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