edb_info.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "hongze/hongze_edb_lib/logic"
  5. "hongze/hongze_edb_lib/models"
  6. "hongze/hongze_edb_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. }