edb.go 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_hub/models"
  5. "eta/eta_hub/models/data_manage"
  6. "eta/eta_hub/services"
  7. "eta/eta_hub/services/data"
  8. "eta/eta_hub/utils"
  9. "time"
  10. "strings"
  11. )
  12. // EdbController 指标
  13. type EdbController struct {
  14. BaseAuthController
  15. }
  16. // SourceList
  17. // @Title 指标来源
  18. // @Description 指标来源
  19. // @Success 200 {object} data_manage.EdbSourceItem
  20. // @router /source/list [get]
  21. func (this *EdbController) SourceList() {
  22. br := new(models.BaseResponse).Init()
  23. defer func() {
  24. this.Data["json"] = br
  25. this.ServeJSON()
  26. }()
  27. sources, e := data_manage.GetEdbSourceItemsByCondition(``, make([]interface{}, 0), []string{}, "")
  28. if e != nil {
  29. br.Msg = "获取失败"
  30. br.ErrMsg = "SourceList GetEdbSourceItemsByCondition err: " + e.Error()
  31. return
  32. }
  33. resp := make([]*data_manage.EdbSourceItem, 0)
  34. for _, v := range sources {
  35. resp = append(resp, data_manage.FormatEdbSource2Item(v))
  36. }
  37. br.Data = resp
  38. br.Ret = 200
  39. br.Msg = "获取成功"
  40. }
  41. // ClassifyList
  42. // @Title 指标分类列表
  43. // @Description 指标分类列表
  44. // @Param ClassifyType query int false "分类类型: 0-普通指标; 1-预测指标"
  45. // @Success 200 {object} data_manage.EdbClassifyItem
  46. // @router /classify/list [get]
  47. func (this *EdbController) ClassifyList() {
  48. br := new(models.BaseResponse).Init()
  49. defer func() {
  50. this.Data["json"] = br
  51. this.ServeJSON()
  52. }()
  53. classifyType, _ := this.GetInt("ClassifyType", 0)
  54. cond := ` AND classify_type = ?`
  55. pars := make([]interface{}, 0)
  56. pars = append(pars, classifyType)
  57. // 获取所有分类
  58. classifyOb := new(data_manage.EdbClassify)
  59. classifies, e := classifyOb.GetItemsByCondition(cond, pars, []string{}, "parent_id ASC, sort ASC")
  60. if e != nil {
  61. br.Msg = "获取失败"
  62. br.ErrMsg = "ClassifyTree GetItemsByCondition err: " + e.Error()
  63. return
  64. }
  65. resp := make([]*data_manage.EdbClassifyItem, 0)
  66. for _, v := range classifies {
  67. resp = append(resp, data_manage.FormatEdbClassify2Item(v))
  68. }
  69. br.Data = resp
  70. br.Ret = 200
  71. br.Msg = "获取成功"
  72. }
  73. // ClassifyTree
  74. // @Title 指标分类树
  75. // @Description 指标分类树
  76. // @Param ClassifyType query int false "分类类型: 0-普通指标; 1-预测指标"
  77. // @Success 200 {object} data_manage.EdbClassifyItem
  78. // @router /classify/tree [get]
  79. func (this *EdbController) ClassifyTree() {
  80. br := new(models.BaseResponse).Init()
  81. defer func() {
  82. this.Data["json"] = br
  83. this.ServeJSON()
  84. }()
  85. classifyType, _ := this.GetInt("ClassifyType", 0)
  86. cond := ` AND classify_type = ?`
  87. pars := make([]interface{}, 0)
  88. pars = append(pars, classifyType)
  89. // 获取所有分类
  90. classifyOb := new(data_manage.EdbClassify)
  91. classifies, e := classifyOb.GetItemsByCondition(cond, pars, []string{}, "sort ASC, parent_id ASC")
  92. if e != nil {
  93. br.Msg = "获取失败"
  94. br.ErrMsg = "EdbClassifyTree GetItemsByCondition err: " + e.Error()
  95. return
  96. }
  97. // 递归生成分类树
  98. classifyTree := services.GetEdbClassifyTreeRecursive(classifies, 0)
  99. br.Data = classifyTree
  100. br.Ret = 200
  101. br.Msg = "获取成功"
  102. }
  103. // List
  104. // @Title 指标列表
  105. // @Description 指标列表
  106. // @Param ClassifyId query int true "指标分类ID"
  107. // @Success 200 {object} data_manage.EdbInfoItem
  108. // @router /list [get]
  109. func (this *EdbController) List() {
  110. br := new(models.BaseResponse).Init()
  111. defer func() {
  112. this.Data["json"] = br
  113. this.ServeJSON()
  114. }()
  115. classifyId, _ := this.GetInt("ClassifyId")
  116. edbOb := new(data_manage.EdbInfo)
  117. cond := ``
  118. pars := make([]interface{}, 0)
  119. if classifyId > 0 {
  120. cond += ` AND classify_id = ?`
  121. pars = append(pars, classifyId)
  122. }
  123. edbList, e := edbOb.GetItemsByCondition(cond, pars, []string{}, "sort ASC, create_time DESC")
  124. if e != nil {
  125. br.Msg = "获取失败"
  126. br.ErrMsg = "EdbList GetItemsByCondition err: " + e.Error()
  127. return
  128. }
  129. resp := make([]*data_manage.EdbInfoItem, 0)
  130. for _, v := range edbList {
  131. resp = append(resp, data_manage.FormatEdbInfo2Item(v))
  132. }
  133. br.Data = resp
  134. br.Ret = 200
  135. br.Msg = "获取成功"
  136. }
  137. // Detail
  138. // @Title 指标详情
  139. // @Description 指标详情
  140. // @Success 200 {object} data_manage.EdbInfoItem
  141. // @router /detail [get]
  142. func (this *EdbController) Detail() {
  143. br := new(models.BaseResponse).Init()
  144. defer func() {
  145. this.Data["json"] = br
  146. this.ServeJSON()
  147. }()
  148. unicode := this.GetString("UniqueCode")
  149. if unicode == "" {
  150. br.Msg = "参数有误"
  151. return
  152. }
  153. edbOb := new(data_manage.EdbInfo)
  154. edb, e := edbOb.GetItemByUniCode(unicode)
  155. if e != nil {
  156. if e.Error() == utils.ErrNoRow() {
  157. br.Msg = "指标不存在"
  158. return
  159. }
  160. br.Msg = "获取失败"
  161. br.ErrMsg = "EdbDetail GetItemByCode err: " + e.Error()
  162. return
  163. }
  164. // 获取指标数据
  165. //dataOb := new(data_manage.EdbData)
  166. //dataList, e := dataOb.GetItemsBySourceAndCode(edb.Source, edb.EdbCode, []string{}, "")
  167. //if e != nil {
  168. // br.Msg = "获取失败"
  169. // br.ErrMsg = "EdbDetail GetItemsBySourceAndCode err: " + e.Error()
  170. // return
  171. //}
  172. //edbData := make([]*data_manage.EdbDataItem, 0)
  173. //for _, v := range dataList {
  174. // edbData = append(edbData, data_manage.FormatEdbData2Item(v))
  175. //}
  176. resp := data_manage.FormatEdbInfo2Item(edb)
  177. br.Data = resp
  178. br.Ret = 200
  179. br.Msg = "获取成功"
  180. }
  181. // EdbData
  182. // @Title 指标数据
  183. // @Description 指标数据
  184. // @Success 200 {object} data_manage.EdbInfoItem
  185. // @router /data [get]
  186. func (this *EdbController) EdbData() {
  187. br := new(models.BaseResponse).Init()
  188. defer func() {
  189. this.Data["json"] = br
  190. this.ServeJSON()
  191. }()
  192. unicode := this.GetString("UniqueCode")
  193. if unicode == "" {
  194. br.Msg = "参数有误"
  195. return
  196. }
  197. startDate := this.GetString("StartDate")
  198. if startDate != "" {
  199. _, e := time.Parse(utils.FormatDate, startDate)
  200. if e != nil {
  201. br.Msg = "开始日期格式有误"
  202. return
  203. }
  204. }
  205. edbOb := new(data_manage.EdbInfo)
  206. edb, e := edbOb.GetItemByUniCode(unicode)
  207. if e != nil {
  208. if e.Error() == utils.ErrNoRow() {
  209. br.Msg = "指标不存在"
  210. return
  211. }
  212. br.Msg = "获取失败"
  213. br.ErrMsg = "EdbDetail GetItemByCode err: " + e.Error()
  214. return
  215. }
  216. // 获取指标数据
  217. dataOb := new(data_manage.EdbData)
  218. dataList, e := dataOb.GetItemsBySourceAndCode(edb.Source, edb.SubSource, edb.EdbCode, startDate, []string{}, "")
  219. if e != nil {
  220. br.Msg = "获取失败"
  221. br.ErrMsg = "EdbData GetItemsBySourceAndCode err: " + e.Error()
  222. return
  223. }
  224. edbData := make([]*data_manage.EdbDataItem, 0)
  225. for _, v := range dataList {
  226. edbData = append(edbData, data_manage.FormatEdbData2Item(v))
  227. }
  228. br.Data = edbData
  229. br.Ret = 200
  230. br.Msg = "获取成功"
  231. }
  232. // TraceEdbInfo
  233. // @Title 指标溯源接口
  234. // @Description 指标溯源接口
  235. // @Param EdbInfoId query int true "指标id"
  236. // @Success 200 {object} data_manage.ChartListResp
  237. // @router /edb_info/trace [get]
  238. func (this *EdbInfoController) TraceEdbInfo() {
  239. br := new(models.BaseResponse).Init()
  240. defer func() {
  241. this.Data["json"] = br
  242. this.ServeJSON()
  243. }()
  244. edbInfoId, _ := this.GetInt("EdbInfoId")
  245. if edbInfoId <= 0 {
  246. br.Msg = "参数错误"
  247. br.ErrMsg = "参数错误"
  248. return
  249. }
  250. resp, err := data.TraceEdbInfoByEdbInfoId(edbInfoId)
  251. if err != nil {
  252. br.Msg = "获取失败"
  253. br.Msg = "获取失败,Err:" + err.Error()
  254. return
  255. }
  256. br.Ret = 200
  257. br.Data = resp
  258. br.Msg = "刷新成功"
  259. }
  260. // Push
  261. // @Title 指标数据
  262. // @Description 指标数据
  263. // @Success 200 {object} data_manage.EdbInfoItem
  264. // @router /push [post]
  265. func (this *EdbController) Push() {
  266. br := new(models.BaseResponse).Init()
  267. defer func() {
  268. this.Data["json"] = br
  269. this.ServeJSON()
  270. }()
  271. body := this.Ctx.Input.RequestBody
  272. var req data_manage.PushBusinessIndexReq
  273. err := json.Unmarshal(body, &req)
  274. if err != nil {
  275. br.Msg = "参数解析异常!"
  276. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  277. return
  278. }
  279. if req.IndexCode == `` {
  280. br.Msg = "指标编码不能为空"
  281. return
  282. }
  283. if req.IndexName == `` {
  284. br.Msg = "指标名称不能为空"
  285. return
  286. }
  287. if req.Unit == `` {
  288. br.Msg = "指标单位不能为空"
  289. return
  290. }
  291. if req.Frequency == `` {
  292. br.Msg = "指标频度不能为空"
  293. return
  294. }
  295. if req.SourceName == `` {
  296. br.Msg = "数据来源名称不能为空"
  297. return
  298. }
  299. // 兼容频度缺少度的字段
  300. if !strings.Contains(req.Frequency, "度") {
  301. req.Frequency = req.Frequency + "度"
  302. }
  303. if !utils.VerifyFrequency(req.Frequency) {
  304. br.Msg = "指标频度不合法:" + req.Frequency
  305. return
  306. }
  307. reqJson, err := json.Marshal(req)
  308. if err != nil {
  309. br.Msg = "参数解析异常!"
  310. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  311. return
  312. }
  313. respItem, err := data.PushEdb(string(reqJson))
  314. if err != nil {
  315. br.Msg = "处理失败"
  316. br.ErrMsg = "处理失败,Err:" + err.Error()
  317. return
  318. }
  319. if respItem.Ret != 200 {
  320. br.Msg = respItem.Msg
  321. br.ErrMsg = respItem.ErrMsg
  322. return
  323. }
  324. //br.Data = edbData
  325. br.Ret = 200
  326. br.Msg = "处理成功"
  327. }