base_from_pb.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_index_lib/logic"
  5. "eta/eta_index_lib/models"
  6. "eta/eta_index_lib/services"
  7. "eta/eta_index_lib/utils"
  8. "fmt"
  9. "strconv"
  10. "time"
  11. )
  12. // 彭博
  13. type PbController struct {
  14. BaseAuthController
  15. }
  16. // @Title 新增彭博指标接口
  17. // @Description 新增彭博指标接口
  18. // @Success 200 {object} models.AddEdbInfoReq
  19. // @router /add [post]
  20. func (this *PbController) Add() {
  21. br := new(models.BaseResponse).Init()
  22. var cacheKey string
  23. defer func() {
  24. utils.Rc.Delete(cacheKey)
  25. this.Data["json"] = br
  26. this.ServeJSON()
  27. }()
  28. source := utils.DATA_SOURCE_PB
  29. var req models.AddEdbInfoReq
  30. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  31. if err != nil {
  32. br.Msg = "参数解析异常!"
  33. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  34. return
  35. }
  36. if req.EdbCode == "" {
  37. br.Msg = "请输入指标编码!"
  38. br.ErrMsg = "请输入指标编码,指标编码为空"
  39. return
  40. }
  41. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  42. if !utils.Rc.IsExist(cacheKey) {
  43. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  44. dataItem, err := services.GetEdbDataFromPb(req.EdbCode, utils.BASE_START_DATE_UnSpace, utils.GetPbNowEndDate(), "")
  45. // 日志记录
  46. num := 0
  47. if dataItem != nil {
  48. num = len(dataItem.Date)
  49. }
  50. models.AddEdbRefreshApiRecordByRefresh(&models.EdbInfo{EdbCode: req.EdbCode, Source: source}, utils.BASE_START_DATE_UnSpace, num, err)
  51. if err != nil {
  52. br.Msg = "获取指标信息失败!"
  53. br.ErrMsg = "获取指标信息失败 GetEdbDataFromPb,Err:" + err.Error()
  54. return
  55. }
  56. err = models.AddEdbDataFromPb(req.EdbCode, dataItem)
  57. if err != nil {
  58. br.Msg = "获取指标信息失败!"
  59. br.ErrMsg = "获取指标信息失败 AddEdbDataFromPb,Err:" + err.Error()
  60. return
  61. }
  62. br.Ret = 200
  63. br.Success = true
  64. br.Msg = "获取成功"
  65. } else {
  66. br.Ret = 501
  67. br.Success = true
  68. br.Msg = "系统处理中,请稍后重试"
  69. }
  70. }
  71. // @Title 刷新彭博指标接口
  72. // @Description 刷新彭博指标接口
  73. // @Success 200 {object} models.RefreshEdbInfoReq
  74. // @router /refresh [post]
  75. func (this *PbController) Refresh() {
  76. br := new(models.BaseResponse).Init()
  77. var cacheKey string
  78. defer func() {
  79. utils.Rc.Delete(cacheKey)
  80. this.Data["json"] = br
  81. this.ServeJSON()
  82. }()
  83. source := utils.DATA_SOURCE_PB
  84. var req models.RefreshEdbInfoReq
  85. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  86. if err != nil {
  87. br.Msg = "参数解析异常!"
  88. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  89. return
  90. }
  91. if req.EdbCode == "" {
  92. br.Msg = "请输入指标编码!"
  93. br.ErrMsg = "请输入指标编码,指标编码为空"
  94. return
  95. }
  96. if req.EdbInfoId <= 0 {
  97. br.Msg = "请输入指标ID!"
  98. br.ErrMsg = "请输入指标ID"
  99. return
  100. }
  101. // 获取指标详情
  102. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  103. if err != nil {
  104. br.Msg = "指标不存在!"
  105. br.ErrMsg = "指标不存在"
  106. return
  107. }
  108. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  109. if utils.Rc.IsExist(cacheKey) {
  110. br.Ret = 501
  111. br.Success = true
  112. br.Msg = "系统处理中,请稍后重试"
  113. return
  114. }
  115. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  116. //开始日期格式化
  117. startDateTime, err := time.ParseInLocation(utils.FormatDate, req.StartDate, time.Local)
  118. if err != nil {
  119. br.Msg = "开始日期格式化异常!"
  120. br.ErrMsg = fmt.Sprintf("开始日期格式化异常,请求日期:%s,Err:%s", req.StartDate, err.Error())
  121. return
  122. }
  123. // 当前日期格式化
  124. endDateStr := utils.GetPbNowEndDate()
  125. endDateTime, err := time.ParseInLocation(utils.FormatDateUnSpace, endDateStr, time.Local)
  126. if err != nil {
  127. br.Msg = "结束日期格式化异常!"
  128. br.ErrMsg = fmt.Sprintf("结束日期格式化异常,请求日期:%s,Err:%s", req.StartDate, err.Error())
  129. return
  130. }
  131. if startDateTime.After(endDateTime) {
  132. br.Msg = `指标刷新的开始日期早于当前日期!`
  133. return
  134. }
  135. dataItem, err := services.GetEdbDataFromPb(req.EdbCode, startDateTime.Format(utils.FormatDateUnSpace), endDateTime.Format(utils.FormatDateUnSpace), edbInfo.TerminalCode)
  136. // 日志记录
  137. num := 0
  138. if dataItem != nil {
  139. num = len(dataItem.Date)
  140. }
  141. models.AddEdbRefreshApiRecordByRefresh(edbInfo, startDateTime.Format(utils.FormatDateUnSpace), num, err)
  142. if err != nil {
  143. br.Msg = "获取指标信息失败!"
  144. br.ErrMsg = "获取指标信息失败 GetEdbDataFromPb,Err:" + err.Error()
  145. return
  146. }
  147. err = models.RefreshEdbDataFromPb(req.EdbInfoId, req.EdbCode, req.StartDate, dataItem)
  148. if err != nil && err.Error() != utils.ErrNoRow() {
  149. br.Msg = "刷新指标信息失败!"
  150. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromPb,Err:" + err.Error()
  151. return
  152. }
  153. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  154. if err != nil {
  155. br.Msg = errMsg
  156. br.ErrMsg = err.Error()
  157. return
  158. }
  159. // 更新ES
  160. go logic.UpdateEs(edbInfo.EdbInfoId)
  161. br.Ret = 200
  162. br.Success = true
  163. br.Msg = "获取成功"
  164. }