edb_info.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  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/utils"
  7. "strconv"
  8. "time"
  9. )
  10. // 指标
  11. type EdbInfoController struct {
  12. BaseAuthController
  13. }
  14. // @Title 新增指标接口
  15. // @Description 新增指标接口
  16. // @Success 200 {object} models.AddEdbInfoParams
  17. // @router /add [post]
  18. func (this *EdbInfoController) Add() {
  19. br := new(models.BaseResponse).Init()
  20. var cacheKey string
  21. defer func() {
  22. utils.Rc.Delete(cacheKey)
  23. this.Data["json"] = br
  24. this.ServeJSON()
  25. }()
  26. var req models.AddEdbInfoParams
  27. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  28. if err != nil {
  29. br.Msg = "参数解析异常!"
  30. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  31. return
  32. }
  33. if req.EdbCode == "" {
  34. br.Msg = "请输入指标编码!"
  35. br.ErrMsg = "请输入指标编码,指标编码为空"
  36. return
  37. }
  38. deleteCache := true
  39. cacheKey = "CACHE_EDB_INFO_ADD_" + req.EdbCode
  40. defer func() {
  41. if deleteCache {
  42. utils.Rc.Delete(cacheKey)
  43. }
  44. }()
  45. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  46. deleteCache = false
  47. br.Msg = "系统处理中,请稍后重试!"
  48. br.ErrMsg = "系统处理中,请稍后重试!"
  49. return
  50. }
  51. if req.ClassifyId <= 0 {
  52. br.Msg = "请输入指标分类!"
  53. br.ErrMsg = "请输入指标分类"
  54. return
  55. }
  56. if req.Source <= 0 {
  57. br.Msg = "请输入指标来源!"
  58. br.ErrMsg = "请输入指标来源"
  59. return
  60. }
  61. if req.EdbName == "" {
  62. br.Msg = "请输入指标名称!"
  63. br.ErrMsg = "请输入指标名称"
  64. return
  65. }
  66. if req.Frequency == "" {
  67. br.Msg = "请输入指标频度!"
  68. br.ErrMsg = "请输入指标频度"
  69. return
  70. }
  71. if req.Unit == "" {
  72. br.Msg = "请输入指标单位!"
  73. br.ErrMsg = "请输入指标单位"
  74. return
  75. }
  76. var isAdd bool
  77. item, err := models.GetEdbInfoByEdbCode(req.Source, req.EdbCode)
  78. if err != nil {
  79. if err.Error() == utils.ErrNoRow() {
  80. isAdd = true
  81. } else {
  82. br.Msg = "判断指标是否存在失败!"
  83. br.ErrMsg = "判断指标是否存在失败"
  84. return
  85. }
  86. }
  87. if item != nil && item.EdbInfoId <= 0 {
  88. isAdd = true
  89. }
  90. var windUrl string
  91. if isAdd {
  92. if req.Source == utils.DATA_SOURCE_WIND {
  93. windUrl, err = GetServerUrl(req.EdbCode)
  94. if err != nil {
  95. br.Msg = "判断失败!"
  96. br.ErrMsg = "判断失败,Err:" + err.Error()
  97. return
  98. }
  99. }
  100. }
  101. admnId, _ := strconv.Atoi(utils.InitAdminId)
  102. edbInfo, err := models.EdbInfoAdd(&req, windUrl, admnId, utils.InitAdminName)
  103. if err != nil {
  104. br.Msg = "新增指标失败!"
  105. br.ErrMsg = "新增指标失败,Err:" + err.Error()
  106. return
  107. }
  108. // 更新ES
  109. go logic.UpdateEs(edbInfo.EdbInfoId)
  110. br.Ret = 200
  111. br.Msg = "新增成功"
  112. br.Data = edbInfo
  113. }
  114. // @Title 获取基础指标详情
  115. // @Description 获取基础指标详情
  116. // @Param request body models.EdbInfoDetailReq true "type json string"
  117. // @Success 200 {object} models.EdbInfo
  118. // @router /detail [post]
  119. func (this *EdbInfoController) EdbIndexDetail() {
  120. br := new(models.BaseResponse).Init()
  121. defer func() {
  122. this.Data["json"] = br
  123. this.ServeJSON()
  124. }()
  125. var req models.EdbInfoDetailReq
  126. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  127. if err != nil {
  128. br.Msg = "参数解析异常!"
  129. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  130. return
  131. }
  132. if req.EdbCode == "" {
  133. br.Msg = "请输入指标编码!"
  134. return
  135. }
  136. detail, err := models.GetEdbInfoOnlyByEdbCode(req.EdbCode)
  137. if err != nil {
  138. if err.Error() == utils.ErrNoRow() {
  139. br.Msg = "指标数据不存在!"
  140. br.ErrMsg = "指标数据不存在,Err:" + err.Error()
  141. br.ErrCode = "400"
  142. return
  143. }
  144. br.Msg = "获取数据失败!"
  145. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  146. return
  147. }
  148. br.Ret = 200
  149. br.Success = true
  150. br.Msg = "获取成功"
  151. br.Data = detail
  152. }
  153. // @Title 复制新增来自弘则的指标接口
  154. // @Description 复制新增来自弘则的指标接口
  155. // @Success 200 {object} models.EdbInfo
  156. // @router /copy/from/hz [post]
  157. func (this *EdbInfoController) CopyFromHz() {
  158. br := new(models.BaseResponse).Init()
  159. var cacheKey string
  160. defer func() {
  161. utils.Rc.Delete(cacheKey)
  162. this.Data["json"] = br
  163. this.ServeJSON()
  164. }()
  165. req := new(models.EdbInfo)
  166. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  167. if err != nil {
  168. br.Msg = "参数解析异常!"
  169. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  170. return
  171. }
  172. if req.EdbCode == "" {
  173. br.Msg = "请输入指标编码!"
  174. br.ErrMsg = "请输入指标编码,指标编码为空"
  175. return
  176. }
  177. deleteCache := true
  178. cacheKey = "CACHE_EDB_INFO_COPY_FROM_HZ_" + req.EdbCode
  179. defer func() {
  180. if deleteCache {
  181. utils.Rc.Delete(cacheKey)
  182. }
  183. }()
  184. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  185. deleteCache = false
  186. br.Msg = "系统处理中,请稍后重试!"
  187. br.ErrMsg = "系统处理中,请稍后重试!"
  188. return
  189. }
  190. if req.ClassifyId <= 0 {
  191. br.Msg = "请输入指标分类!"
  192. br.ErrMsg = "请输入指标分类"
  193. return
  194. }
  195. if req.Source <= 0 {
  196. br.Msg = "请输入指标来源!"
  197. br.ErrMsg = "请输入指标来源"
  198. return
  199. }
  200. if req.EdbName == "" {
  201. br.Msg = "请输入指标名称!"
  202. br.ErrMsg = "请输入指标名称"
  203. return
  204. }
  205. if req.Frequency == "" {
  206. br.Msg = "请输入指标频度!"
  207. br.ErrMsg = "请输入指标频度"
  208. return
  209. }
  210. if req.Unit == "" {
  211. br.Msg = "请输入指标单位!"
  212. br.ErrMsg = "请输入指标单位"
  213. return
  214. }
  215. var isAdd bool
  216. item, err := models.GetEdbInfoByEdbCode(req.Source, req.EdbCode)
  217. if err != nil {
  218. if err.Error() == utils.ErrNoRow() {
  219. isAdd = true
  220. } else {
  221. br.Msg = "判断指标是否存在失败!"
  222. br.ErrMsg = "判断指标是否存在失败"
  223. return
  224. }
  225. }
  226. if item != nil && item.EdbInfoId <= 0 {
  227. isAdd = true
  228. }
  229. if isAdd {
  230. req.EdbInfoId = 0
  231. req.StartDate = "1990-01-01"
  232. err = req.Add()
  233. if err != nil {
  234. br.Msg = "新增指标失败!"
  235. br.ErrMsg = "新增指标失败"
  236. return
  237. }
  238. }
  239. edbInfo, err := models.GetEdbInfoOnlyByEdbCode(req.EdbCode)
  240. // 更新ES
  241. go logic.UpdateEs(edbInfo.EdbInfoId)
  242. br.Ret = 200
  243. br.Msg = "新增成功"
  244. br.Data = edbInfo
  245. }