base_from_manual.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "hongze/hongze_edb_lib/models"
  5. "hongze/hongze_edb_lib/utils"
  6. "strconv"
  7. "time"
  8. )
  9. //手工指标
  10. type ManualController struct {
  11. BaseAuthController
  12. }
  13. // @Title 新增手工指标接口
  14. // @Description 新增手工指标接口
  15. // @Success 200 {object} models.AddEdbInfoReq
  16. // @router /add [post]
  17. func (this *ManualController) Add() {
  18. br := new(models.BaseResponse).Init()
  19. var cacheKey string
  20. defer func() {
  21. utils.Rc.Delete(cacheKey)
  22. this.Data["json"] = br
  23. this.ServeJSON()
  24. }()
  25. source := utils.DATA_SOURCE_MANUAL
  26. var req models.AddEdbInfoReq
  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. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  39. if !utils.Rc.IsExist(cacheKey) {
  40. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  41. err = models.AddEdbDataFromManual(req.EdbCode)
  42. if err != nil {
  43. br.Msg = "获取指标信息失败!"
  44. br.ErrMsg = "获取指标信息失败 AddEdbDataFromManual,Err:" + err.Error()
  45. return
  46. }
  47. br.Ret = 200
  48. br.Success = true
  49. br.Msg = "获取成功"
  50. } else {
  51. br.Ret = 501
  52. br.Success = true
  53. br.Msg = "系统处理中,请稍后重试"
  54. }
  55. }
  56. // @Title 刷新手工指标接口
  57. // @Description 刷新手工指标接口
  58. // @Success 200 {object} models.RefreshEdbInfoReq
  59. // @router /refresh [post]
  60. func (this *ManualController) Refresh() {
  61. br := new(models.BaseResponse).Init()
  62. defer func() {
  63. this.Data["json"] = br
  64. this.ServeJSON()
  65. }()
  66. source := utils.DATA_SOURCE_MANUAL
  67. var req models.RefreshEdbInfoReq
  68. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  69. if err != nil {
  70. br.Msg = "参数解析异常!"
  71. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  72. return
  73. }
  74. if req.EdbCode == "" {
  75. br.Msg = "请输入指标编码!"
  76. br.ErrMsg = "请输入指标编码,指标编码为空"
  77. return
  78. }
  79. if req.EdbInfoId <= 0 {
  80. br.Msg = "请输入指标ID!"
  81. br.ErrMsg = "请输入指标ID"
  82. return
  83. }
  84. cacheKey := utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  85. if utils.Rc.IsExist(cacheKey) {
  86. br.Ret = 501
  87. br.Success = true
  88. br.Msg = "系统处理中,请稍后重试"
  89. }
  90. // 设置缓存
  91. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  92. defer func() {
  93. utils.Rc.Delete(cacheKey)
  94. }()
  95. // 获取指标详情
  96. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  97. if err != nil {
  98. br.Msg = "指标不存在!"
  99. br.ErrMsg = "指标不存在"
  100. return
  101. }
  102. req.StartDate = `` // 开始日期也给过滤吧,万一研究员补充了之前的数据呢,还是过滤掉吧
  103. err = models.RefreshEdbDataFromManual(req.EdbInfoId, req.EdbCode, req.StartDate)
  104. if err != nil && err.Error() != utils.ErrNoRow() {
  105. br.Msg = "刷新指标信息失败!"
  106. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromManual,Err:" + err.Error()
  107. return
  108. }
  109. // 更新指标最大最小值
  110. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  111. if err != nil {
  112. br.Msg = errMsg
  113. br.ErrMsg = err.Error()
  114. return
  115. }
  116. br.Ret = 200
  117. br.Success = true
  118. br.Msg = "获取成功"
  119. }