base_from_fenwei.go 6.2 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/services"
  7. "eta/eta_index_lib/utils"
  8. "strconv"
  9. "time"
  10. )
  11. // FenweiController 汾渭煤炭
  12. type FenweiController struct {
  13. BaseAuthController
  14. }
  15. // Add
  16. // @Title 新增汾渭煤炭指标接口
  17. // @Description 新增汾渭煤炭指标接口
  18. // @Success 200 {object} models.AddEdbInfoReq
  19. // @router /add [post]
  20. func (this *FenweiController) Add() {
  21. br := new(models.BaseResponse).Init()
  22. var cacheKey string
  23. defer func() {
  24. if br.ErrMsg == "" {
  25. br.IsSendEmail = false
  26. }
  27. this.Data["json"] = br
  28. this.ServeJSON()
  29. }()
  30. var req models.AddEdbInfoReq
  31. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  32. if err != nil {
  33. br.Msg = "参数解析异常!"
  34. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  35. return
  36. }
  37. if req.EdbCode == "" {
  38. br.Msg = "请输入指标编码!"
  39. br.ErrMsg = "请输入指标编码,指标编码为空"
  40. return
  41. }
  42. ob := new(models.BaseFromFenwei)
  43. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(ob.GetSource()) + "_" + req.EdbCode
  44. if utils.Rc.IsExist(cacheKey) {
  45. br.Ret = 501
  46. br.Success = true
  47. br.Msg = "系统处理中,请稍后重试"
  48. return
  49. }
  50. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  51. defer func() {
  52. _ = utils.Rc.Delete(cacheKey)
  53. }()
  54. if err = ob.Add(req.EdbCode); err != nil {
  55. br.Msg = "获取指标信息失败!"
  56. br.ErrMsg = "获取指标信息失败 AddEdbDataFromFenwei,Err:" + err.Error()
  57. return
  58. }
  59. br.Ret = 200
  60. br.Success = true
  61. br.Msg = "获取成功"
  62. }
  63. // Refresh
  64. // @Title 刷新汾渭煤炭指标接口
  65. // @Description 刷新汾渭煤炭指标接口
  66. // @Success 200 {object} models.RefreshEdbInfoReq
  67. // @router /refresh [post]
  68. func (this *FenweiController) Refresh() {
  69. br := new(models.BaseResponse).Init()
  70. var cacheKey string
  71. defer func() {
  72. if br.ErrMsg == "" {
  73. br.IsSendEmail = false
  74. }
  75. this.Data["json"] = br
  76. this.ServeJSON()
  77. }()
  78. var req models.RefreshEdbInfoReq
  79. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  80. if err != nil {
  81. br.Msg = "参数解析异常!"
  82. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  83. return
  84. }
  85. if req.EdbCode == "" {
  86. br.Msg = "请输入指标编码!"
  87. br.ErrMsg = "请输入指标编码,指标编码为空"
  88. return
  89. }
  90. if req.EdbInfoId < 0 {
  91. br.Msg = "请输入指标ID!"
  92. br.ErrMsg = "请输入指标ID"
  93. return
  94. }
  95. ob := new(models.BaseFromFenwei)
  96. source := ob.GetSource()
  97. // 获取指标详情
  98. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  99. if err != nil {
  100. br.Msg = "指标不存在!"
  101. br.ErrMsg = "指标不存在"
  102. return
  103. }
  104. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  105. if utils.Rc.IsExist(cacheKey) {
  106. br.Ret = 501
  107. br.Success = true
  108. br.Msg = "系统处理中,请稍后重试"
  109. return
  110. }
  111. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  112. defer func() {
  113. _ = utils.Rc.Delete(cacheKey)
  114. }()
  115. if req.EdbInfoId <= 0 {
  116. req.EdbInfoId = edbInfo.EdbInfoId
  117. }
  118. err = ob.Refresh(req.EdbInfoId, req.EdbCode, req.StartDate)
  119. if err != nil && err.Error() != utils.ErrNoRow() {
  120. br.Msg = "刷新指标信息失败!"
  121. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromFenwei,Err:" + err.Error()
  122. return
  123. }
  124. // 更新指标最大最小值
  125. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  126. if err != nil {
  127. br.Msg = errMsg
  128. br.ErrMsg = err.Error()
  129. return
  130. }
  131. // 更新ES
  132. go logic.UpdateEs(edbInfo.EdbInfoId)
  133. br.Ret = 200
  134. br.Success = true
  135. br.Msg = "获取成功"
  136. }
  137. // HandleExcelData
  138. // @Title 处理汾渭煤炭指标的接口
  139. // @Description 处理汾渭煤炭指标的接口
  140. // @Success 200 string "操作成功"
  141. // @router /handle/excel_data [post]
  142. func (this *FenweiController) HandleExcelData() {
  143. br := new(models.BaseResponse).Init()
  144. defer func() {
  145. if br.ErrMsg == "" {
  146. br.IsSendEmail = false
  147. }
  148. this.Data["json"] = br
  149. this.ServeJSON()
  150. }()
  151. var req models.HandleFenweiExcelDataReq
  152. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  153. if err != nil {
  154. br.Msg = "参数解析异常!"
  155. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  156. return
  157. }
  158. // 处理excel表数据
  159. if err = services.HandleFenweiIndex(&req); err != nil {
  160. br.Msg = "处理失败"
  161. br.ErrMsg = "处理失败,Err:" + err.Error()
  162. return
  163. }
  164. br.Ret = 200
  165. br.Success = true
  166. br.Msg = "处理成功"
  167. }
  168. // ClassifyTree
  169. // @Title 汾渭数据分类
  170. // @Description 汾渭数据分类接口
  171. // @Success 200 {object} models.BaseFromFenweiClassifyItem
  172. // @router /classify_tree [post]
  173. func (this *FenweiController) ClassifyTree() {
  174. br := new(models.BaseResponse).Init()
  175. defer func() {
  176. if br.ErrMsg == "" {
  177. br.IsSendEmail = false
  178. }
  179. this.Data["json"] = br
  180. this.ServeJSON()
  181. }()
  182. classifyOb := new(models.BaseFromFenweiClassify)
  183. classifies, e := classifyOb.GetItemsByCondition(``, make([]interface{}, 0), []string{}, "parent_id ASC, sort ASC")
  184. if e != nil {
  185. br.Msg = "获取失败"
  186. br.ErrMsg = "获取汾渭数据分类失败, Err: " + e.Error()
  187. return
  188. }
  189. resp := make([]*models.BaseFromFenweiClassifyItem, 0)
  190. parentMap := make(map[int][]*models.BaseFromFenweiClassifyItem)
  191. for _, v := range classifies {
  192. t := classifyOb.Format2Item(v)
  193. if v.ParentId == 0 {
  194. resp = append(resp, t)
  195. }
  196. if v.ParentId > 0 {
  197. if parentMap[v.ParentId] == nil {
  198. parentMap[v.ParentId] = make([]*models.BaseFromFenweiClassifyItem, 0)
  199. }
  200. parentMap[v.ParentId] = append(parentMap[v.ParentId], t)
  201. }
  202. }
  203. for _, v := range resp {
  204. v.Child = parentMap[v.ClassifyId]
  205. }
  206. br.Data = resp
  207. br.Ret = 200
  208. br.Success = true
  209. br.Msg = "获取成功"
  210. }
  211. // BaseIndexList
  212. // @Title 汾渭指标基础信息列表
  213. // @Description 汾渭指标基础信息列表接口
  214. // @Success 200 {object} models.BaseFromFenweiIndex
  215. // @router /base_index_list [post]
  216. func (this *FenweiController) BaseIndexList() {
  217. br := new(models.BaseResponse).Init()
  218. defer func() {
  219. if br.ErrMsg == "" {
  220. br.IsSendEmail = false
  221. }
  222. this.Data["json"] = br
  223. this.ServeJSON()
  224. }()
  225. ob := new(models.BaseFromFenweiIndex)
  226. list, e := ob.GetItemsByCondition(``, make([]interface{}, 0), []string{}, "")
  227. if e != nil {
  228. br.Msg = "获取失败"
  229. br.ErrMsg = "获取汾渭指标列表失败, Err: " + e.Error()
  230. return
  231. }
  232. br.Data = list
  233. br.Ret = 200
  234. br.Success = true
  235. br.Msg = "获取成功"
  236. }