base_from_jiayue.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  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. "strconv"
  9. "time"
  10. )
  11. // JiaYueController 嘉悦物产数据源
  12. type JiaYueController struct {
  13. BaseAuthController
  14. }
  15. // Add
  16. // @Title 嘉悦物产-新增指标接口
  17. // @Description 新增指标接口
  18. // @Success 200 {object} models.AddEdbInfoReq
  19. // @router /add [post]
  20. func (this *JiaYueController) Add() {
  21. br := new(models.BaseResponse).Init()
  22. var cacheKey string
  23. defer func() {
  24. if br.ErrMsg == "" {
  25. br.IsSendEmail = false
  26. }
  27. _ = utils.Rc.Delete(cacheKey)
  28. this.Data["json"] = br
  29. this.ServeJSON()
  30. }()
  31. var req models.AddEdbInfoReq
  32. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  33. br.Msg = "操作失败"
  34. br.ErrMsg = "参数解析异常, err: " + e.Error()
  35. return
  36. }
  37. if req.EdbCode == "" {
  38. br.Msg = "请输入指标编码"
  39. br.ErrMsg = "指标编码为空"
  40. return
  41. }
  42. if req.Source <= 0 {
  43. br.Msg = "请输入指标来源"
  44. br.ErrMsg = "指标来源为空"
  45. return
  46. }
  47. // 加锁
  48. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(req.Source) + "_" + req.EdbCode
  49. if utils.Rc.IsExist(cacheKey) {
  50. br.Ret = 501
  51. br.Success = true
  52. br.Msg = "系统处理中,请稍后重试"
  53. return
  54. }
  55. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  56. defer func() {
  57. _ = utils.Rc.Delete(cacheKey)
  58. }()
  59. // 校验数据源
  60. cond := ` AND edb_source_id = ?`
  61. pars := make([]interface{}, 0)
  62. pars = append(pars, req.Source)
  63. sourceItem, e := models.GetEdbSourceItemByCondition(cond, pars)
  64. if e != nil {
  65. br.Msg = "数据源有误"
  66. br.ErrMsg = "获取数据源失败, Err: " + e.Error()
  67. return
  68. }
  69. // 从桥接服务获取指标和数据
  70. var params models.BridgeJiaYueIndexDataParams
  71. params.IndexCode = req.EdbCode
  72. params.SourceExtend = sourceItem.SourceExtend
  73. params.StartDate = utils.BASE_START_DATE
  74. params.EndDate = utils.BASE_END_DATE
  75. indexData, e := services.GetJiaYueIndexDataFromBridge(params)
  76. if e != nil {
  77. br.Msg = "获取指标失败"
  78. br.ErrMsg = "获取指标数据失败, Err: " + e.Error()
  79. return
  80. }
  81. if indexData.Id <= 0 {
  82. br.Msg = "指标不存在"
  83. br.Success = true
  84. return
  85. }
  86. // 新增指标数据
  87. e = models.AddEdbDataFromJiaYue(sourceItem.TableName, req.EdbCode, indexData.IndexData)
  88. if e != nil {
  89. br.Msg = "操作失败"
  90. br.ErrMsg = "新增指标数据失败, Err: " + e.Error()
  91. return
  92. }
  93. br.Ret = 200
  94. br.Success = true
  95. br.Msg = "操作成功"
  96. }
  97. // Refresh
  98. // @Title 嘉悦物产-刷新指标接口
  99. // @Description 刷新指标接口
  100. // @Success 200 {object} models.RefreshEdbInfoReq
  101. // @router /refresh [post]
  102. func (this *JiaYueController) Refresh() {
  103. br := new(models.BaseResponse).Init()
  104. var cacheKey string
  105. defer func() {
  106. if br.ErrMsg == "" {
  107. br.IsSendEmail = false
  108. }
  109. this.Data["json"] = br
  110. this.ServeJSON()
  111. }()
  112. var req models.RefreshEdbInfoReq
  113. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  114. if err != nil {
  115. br.Msg = "参数解析异常!"
  116. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  117. return
  118. }
  119. if req.EdbCode == "" {
  120. br.Msg = "请输入指标编码!"
  121. br.ErrMsg = "请输入指标编码,指标编码为空"
  122. return
  123. }
  124. if req.EdbInfoId <= 0 {
  125. br.Msg = "请输入指标ID!"
  126. br.ErrMsg = "请输入指标ID"
  127. return
  128. }
  129. if req.Source <= 0 {
  130. br.Msg = "请输入指标来源"
  131. br.ErrMsg = "指标来源为空"
  132. return
  133. }
  134. startDate := req.StartDate
  135. if startDate == "" {
  136. startDate = utils.BASE_START_DATE
  137. }
  138. // 加锁
  139. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(req.Source) + "_" + req.EdbCode
  140. if utils.Rc.IsExist(cacheKey) {
  141. br.Ret = 501
  142. br.Success = true
  143. br.Msg = "系统处理中,请稍后重试"
  144. return
  145. }
  146. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  147. defer func() {
  148. _ = utils.Rc.Delete(cacheKey)
  149. }()
  150. // 校验指标和数据源
  151. edbInfo, e := models.GetEdbInfoById(req.EdbInfoId)
  152. if e != nil {
  153. br.Msg = "指标信息有误"
  154. br.ErrMsg = "查询指标信息失败, Err: " + e.Error()
  155. return
  156. }
  157. cond := ` AND edb_source_id = ?`
  158. pars := make([]interface{}, 0)
  159. pars = append(pars, req.Source)
  160. sourceItem, e := models.GetEdbSourceItemByCondition(cond, pars)
  161. if e != nil {
  162. br.Msg = "数据源有误"
  163. br.ErrMsg = "获取数据源失败, Err: " + e.Error()
  164. return
  165. }
  166. // 从桥接服务获取指标和数据
  167. var params models.BridgeJiaYueIndexDataParams
  168. params.IndexCode = req.EdbCode
  169. params.SourceExtend = sourceItem.SourceExtend
  170. params.StartDate = startDate
  171. params.EndDate = utils.BASE_END_DATE
  172. indexData, e := services.GetJiaYueIndexDataFromBridge(params)
  173. if e != nil {
  174. br.Msg = "获取指标失败"
  175. br.ErrMsg = "获取指标数据失败, Err: " + e.Error()
  176. return
  177. }
  178. if indexData.Id <= 0 {
  179. br.Msg = "指标不存在"
  180. br.Success = true
  181. return
  182. }
  183. // 刷新指标数据
  184. e = models.RefreshEdbDataFromJiaYue(req.Source, req.EdbInfoId, sourceItem.TableName, req.EdbCode, startDate, indexData.IndexData)
  185. if e != nil {
  186. br.Msg = "刷新失败"
  187. br.ErrMsg = "刷新嘉悦指标失败, Err: " + e.Error()
  188. return
  189. }
  190. // 更新指标最大最小值
  191. e, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  192. if e != nil {
  193. br.Msg = errMsg
  194. br.ErrMsg = e.Error()
  195. return
  196. }
  197. // 更新ES
  198. go logic.UpdateEs(edbInfo.EdbInfoId)
  199. br.Ret = 200
  200. br.Success = true
  201. br.Msg = "操作成功"
  202. }