base_from_predict.go 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_edb_lib/logic"
  6. "hongze/hongze_edb_lib/models"
  7. "hongze/hongze_edb_lib/utils"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. // PredictController 预测指标
  13. type PredictController struct {
  14. BaseAuthController
  15. }
  16. // Save
  17. // @Title 新增/编辑预测指标运算接口
  18. // @Description 新增预测指标运算接口
  19. // @Success 200 {object} models.EdbInfoCalculateSaveReq
  20. // @router /save [post]
  21. func (this *PredictController) Save() {
  22. br := new(models.BaseResponse).Init()
  23. defer func() {
  24. this.Data["json"] = br
  25. this.ServeJSON()
  26. }()
  27. var req models.AddPredictEdbInfoReq
  28. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  29. if err != nil {
  30. br.Msg = "参数解析异常!"
  31. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  32. return
  33. }
  34. if req.EdbInfoId <= 0 {
  35. addPredict(br, req)
  36. } else {
  37. editPredict(br, req)
  38. }
  39. }
  40. // AddPredictCalculate 添加预测指标运算
  41. func addPredict(br *models.BaseResponse, req models.AddPredictEdbInfoReq) {
  42. //加入缓存机制,避免创建同一个名称的指标 start
  43. redisKey := fmt.Sprint("predict_edb_info:calculate:batch:save:", utils.DATA_SOURCE_PREDICT, ":", req.EdbName)
  44. isExist := utils.Rc.IsExist(redisKey)
  45. if isExist {
  46. br.Msg = "指标正在处理,请勿重复提交"
  47. return
  48. } else {
  49. //设置3分钟缓存
  50. utils.Rc.SetNX(redisKey, 1, time.Second*300)
  51. defer func() {
  52. _ = utils.Rc.Delete(redisKey)
  53. }()
  54. }
  55. // 添加指标
  56. edbInfo, err, errMsg := logic.AddPredictEdbInfo(req.SourceEdbInfoId, req.ClassifyId, req.EdbName, req.RuleList, req.AdminId, req.AdminName)
  57. if err != nil {
  58. br.Msg = errMsg
  59. br.ErrMsg = err.Error()
  60. return
  61. }
  62. resp := models.AddEdbInfoResp{
  63. EdbInfoId: edbInfo.EdbInfoId,
  64. UniqueCode: edbInfo.UniqueCode,
  65. }
  66. br.Ret = 200
  67. br.Success = true
  68. br.Msg = "保存成功"
  69. br.Data = resp
  70. br.IsAddLog = true
  71. }
  72. // editPredictCalculate 编辑预测指标运算
  73. func editPredict(br *models.BaseResponse, req models.AddPredictEdbInfoReq) {
  74. req.EdbName = strings.Trim(req.EdbName, " ")
  75. //加入缓存机制,避免创建同一个名称的指标 start
  76. redisKey := fmt.Sprint("predict_edb_info:calculate:batch:save:", utils.DATA_SOURCE_PREDICT, ":", req.EdbName)
  77. isExist := utils.Rc.IsExist(redisKey)
  78. if isExist {
  79. br.Msg = "指标正在处理,请勿重复提交"
  80. return
  81. } else {
  82. //设置3分钟缓存
  83. utils.Rc.SetNX(redisKey, 1, time.Second*300)
  84. defer func() {
  85. _ = utils.Rc.Delete(redisKey)
  86. }()
  87. }
  88. // 编辑指标
  89. edbInfo, err, errMsg := logic.EditPredictEdbInfo(req.EdbInfoId, req.ClassifyId, req.EdbName, req.RuleList)
  90. if err != nil {
  91. br.Msg = errMsg
  92. br.ErrMsg = err.Error()
  93. return
  94. }
  95. resp := models.AddEdbInfoResp{
  96. EdbInfoId: edbInfo.EdbInfoId,
  97. UniqueCode: edbInfo.UniqueCode,
  98. }
  99. br.Ret = 200
  100. br.Success = true
  101. br.Msg = "保存成功"
  102. br.Data = resp
  103. br.IsAddLog = true
  104. }
  105. // Refresh
  106. // @Title 刷新计算指标接口
  107. // @Description 刷新计算指标接口
  108. // @Success 200 {object} models.RefreshEdbInfoReq
  109. // @router /refresh [post]
  110. func (this *PredictController) Refresh() {
  111. br := new(models.BaseResponse).Init()
  112. var cacheKey string
  113. defer func() {
  114. this.Data["json"] = br
  115. this.ServeJSON()
  116. }()
  117. var req models.RefreshEdbInfoReq
  118. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  119. if err != nil {
  120. br.Msg = "参数解析异常!"
  121. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  122. return
  123. }
  124. if req.EdbCode == "" {
  125. br.Msg = "请输入指标编码!"
  126. br.ErrMsg = "请输入指标编码,指标编码为空"
  127. return
  128. }
  129. if req.EdbInfoId <= 0 {
  130. br.Msg = "请输入指标ID!"
  131. br.ErrMsg = "请输入指标ID"
  132. return
  133. }
  134. edbInfo, err := models.GetEdbInfoById(req.EdbInfoId)
  135. if err != nil {
  136. br.Msg = "指标不存在!"
  137. br.ErrMsg = "指标不存在"
  138. return
  139. }
  140. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(edbInfo.Source) + "_" + req.EdbCode
  141. if utils.Rc.IsExist(cacheKey) {
  142. br.Ret = 501
  143. br.Success = true
  144. br.Msg = "系统处理中,请稍后重试"
  145. br.IsSendEmail = false
  146. }
  147. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  148. defer func() {
  149. _ = utils.Rc.Delete(cacheKey)
  150. }()
  151. startDate := req.StartDate
  152. var errMsg string
  153. edbInfoId := edbInfo.EdbInfoId
  154. source := edbInfo.Source
  155. var latestDateStr string // 最近实际数据的日期
  156. var latestValue float64 // 最近实际数据的值
  157. switch source {
  158. case utils.DATA_SOURCE_PREDICT_CALCULATE:
  159. //startDate = edbInfo.StartDate
  160. //sTime, err := time.Parse(utils.FormatDate, edbInfo.EndDate)
  161. //if err != nil {
  162. // return
  163. //}
  164. //startDate = sTime.Format(utils.FormatDate)
  165. startDate = ""
  166. var edbInfoIdBytes []string
  167. calculateMap, err := models.GetEdbInfoCalculateDetailList(edbInfo.EdbInfoId)
  168. if err != nil {
  169. errMsg = "GetEdbInfoCalculateDetail Err:" + err.Error()
  170. break
  171. }
  172. var formulaStr string
  173. edbInfoList := make([]*models.EdbInfo, 0)
  174. for _, v := range calculateMap {
  175. formulaStr += v.FromTag + ","
  176. edbInfoIdBytes = append(edbInfoIdBytes, v.FromTag)
  177. edbInfo, _ := models.GetEdbInfoById(v.FromEdbInfoId)
  178. edbInfoList = append(edbInfoList, edbInfo)
  179. }
  180. latestDateStr, latestValue, err = models.RefreshAllPredictCalculate(edbInfoList, edbInfo.EdbInfoId, source, edbInfo.EdbCode, edbInfo.CalculateFormula, startDate, edbInfoIdBytes)
  181. if err != nil && err.Error() != utils.ErrNoRow() {
  182. errMsg = "RefreshCalculate Err:" + err.Error()
  183. break
  184. }
  185. case utils.DATA_SOURCE_PREDICT_CALCULATE_TBZ: //刷新同比值
  186. calculateTbz, err := models.GetEdbInfoCalculateMappingDetail(edbInfoId)
  187. if err != nil {
  188. errMsg = "GetEdbInfoCalculateTbzDetail Err:" + err.Error()
  189. break
  190. }
  191. fromEdbInfo, err := models.GetEdbInfoById(calculateTbz.FromEdbInfoId)
  192. if err != nil {
  193. errMsg = "GetEdbInfoById Err:" + err.Error()
  194. break
  195. }
  196. startDate = edbInfo.StartDate
  197. latestDateStr, latestValue, err = models.RefreshAllPredictCalculateTbz(edbInfoId, source, fromEdbInfo, calculateTbz.EdbCode, startDate)
  198. if err != nil && err.Error() != utils.ErrNoRow() {
  199. errMsg = "RefreshAllCalculateTbz Err:" + err.Error()
  200. break
  201. }
  202. case utils.DATA_SOURCE_PREDICT_CALCULATE_TCZ: //同差值
  203. calculateTcz, err := models.GetEdbInfoCalculateMappingDetail(edbInfoId)
  204. if err != nil {
  205. errMsg = "GetEdbInfoCalculateTczDetail Err:" + err.Error()
  206. break
  207. }
  208. fromEdbInfo, err := models.GetEdbInfoById(calculateTcz.FromEdbInfoId)
  209. if err != nil {
  210. errMsg = "GetEdbInfoById Err:" + err.Error()
  211. break
  212. }
  213. startDate = edbInfo.StartDate
  214. latestDateStr, latestValue, err = models.RefreshAllPredictCalculateTcz(edbInfoId, source, fromEdbInfo, calculateTcz.EdbCode, startDate)
  215. if err != nil && err.Error() != utils.ErrNoRow() {
  216. errMsg = "RefreshCalculateTcz Err:" + err.Error()
  217. break
  218. }
  219. default:
  220. br.Msg = "来源异常,请联系相关开发!"
  221. br.ErrMsg = "来源异常,请联系相关开发"
  222. return
  223. }
  224. if errMsg != `` {
  225. br.Msg = "刷新指标失败!"
  226. br.ErrMsg = "刷新指标失败,err:" + errMsg
  227. return
  228. }
  229. // 更新指标最大最小值
  230. err, errMsg = models.UnifiedModifyPredictEdbInfoMaxAndMinInfo(edbInfo, latestDateStr, latestValue)
  231. if err != nil {
  232. br.Msg = errMsg
  233. br.ErrMsg = err.Error()
  234. return
  235. }
  236. br.Ret = 200
  237. br.Success = true
  238. br.Msg = "获取成功"
  239. }