smm_api.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. package data_manage
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/models/data_manage"
  5. "eta/eta_api/utils"
  6. "fmt"
  7. "github.com/rdlucklib/rdluck_tools/paging"
  8. "strings"
  9. )
  10. // SmmIndexList
  11. // @Title 有色api数据指标列表
  12. // @Description 有色api数据指标列表
  13. // @Success 200 {object} data_manage.SmmClassify
  14. // @router /smm/api/list [get]
  15. func (this *EdbInfoController) SmmApiList() {
  16. br := new(models.BaseResponse).Init()
  17. defer func() {
  18. this.Data["json"] = br
  19. this.ServeJSON()
  20. }()
  21. sysUser := this.SysUser
  22. if sysUser == nil {
  23. br.Msg = "请登录"
  24. br.ErrMsg = "请登录,SysUser Is Empty"
  25. br.Ret = 408
  26. return
  27. }
  28. types := this.GetString("Types")
  29. frequency := this.GetString("Frequency")
  30. dataState := this.GetString("DataState")
  31. keyword := this.GetString("Keyword")
  32. indexCodes := this.GetString("IndexCodes")
  33. sortType := this.GetString("SortType", "desc")
  34. sortParam := this.GetString("SortParam")
  35. pageSize, _ := this.GetInt("PageSize")
  36. currentIndex, _ := this.GetInt("CurrentIndex")
  37. var startSize int
  38. if pageSize <= 0 {
  39. pageSize = utils.PageSize20
  40. }
  41. if currentIndex <= 0 {
  42. currentIndex = 1
  43. }
  44. startSize = utils.StartIndex(currentIndex, pageSize)
  45. var condition string
  46. var pars []interface{}
  47. if types != "" {
  48. typeArr := strings.Split(types,",")
  49. for i, v := range typeArr {
  50. typeStr := "type_"
  51. typeStr += fmt.Sprintf("%d", i+1)
  52. condition += " AND "+typeStr+" =? "
  53. pars = append(pars, v)
  54. }
  55. }
  56. if frequency != "" {
  57. condition += " AND frequency = ? "
  58. pars = append(pars, frequency)
  59. }
  60. if dataState != "" {
  61. if dataState == "normal" {
  62. condition += " AND (data_state = 'normal' OR data_state = '') "
  63. pars = append(pars)
  64. } else {
  65. condition += " AND data_state = ? "
  66. pars = append(pars, dataState)
  67. }
  68. }
  69. if keyword != "" {
  70. condition += " AND (index_name LIKE ? OR index_code LIKE ?) "
  71. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  72. }
  73. if indexCodes != "" {
  74. indexCodeArr := strings.Split(indexCodes,",")
  75. indexCodeStr := ""
  76. for _, v := range indexCodeArr {
  77. indexCodeStr += "'" + v + "',"
  78. }
  79. indexCodeStr = strings.TrimRight(indexCodeStr, ",")
  80. condition += " AND index_code IN (" + indexCodeStr + ") "
  81. }
  82. sortStr := ``
  83. if sortParam != `` {
  84. sortStr = fmt.Sprintf("%s %s,modify_time desc ", utils.PascalToSnake(sortParam), sortType)
  85. } else {
  86. sortStr = " modify_time desc "
  87. }
  88. total, err := data_manage.GetSmmIndexDataListCount(condition, pars)
  89. if err!= nil {
  90. br.Msg = "获取指标总数失败"
  91. br.ErrMsg = "获取指标总数失败,Err:" + err.Error()
  92. return
  93. }
  94. indexList, err := data_manage.GetSmmIndexDataList(condition, sortStr, pars, startSize, pageSize)
  95. if err != nil {
  96. br.Msg = "获取指标列表失败"
  97. br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
  98. return
  99. }
  100. for _, v := range indexList {
  101. v.TypeAll = v.Type1 + "/" + v.Type2 + "/" + v.Type3
  102. }
  103. page := paging.GetPaging(currentIndex, pageSize, total)
  104. var ret data_manage.BaseFromSmmIndexListResp
  105. ret.List = indexList
  106. ret.Paging = page
  107. br.Ret = 200
  108. br.Success = true
  109. br.Msg = "获取成功"
  110. br.Data = ret
  111. }
  112. // SmmApiTypeList
  113. // @Title 有色api数据分类列表
  114. // @Description 有色api数据分类列表
  115. // @Success 200 {object} data_manage.SmmClassify
  116. // @router /smm/api/type/list [get]
  117. func (this *EdbInfoController) SmmApiTypeList() {
  118. br := new(models.BaseResponse).Init()
  119. defer func() {
  120. this.Data["json"] = br
  121. this.ServeJSON()
  122. }()
  123. sysUser := this.SysUser
  124. if sysUser == nil {
  125. br.Msg = "请登录"
  126. br.ErrMsg = "请登录,SysUser Is Empty"
  127. br.Ret = 408
  128. return
  129. }
  130. typeList, err := data_manage.GetBaseFromSmmIndexTypeList()
  131. if err != nil {
  132. br.Msg = "获取指标列表失败"
  133. br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
  134. return
  135. }
  136. resp := make([]data_manage.TypeListRespItem, 0)
  137. typeMap := make(map[string]map[string][]string)
  138. //type2Map := make(map[string][]string)
  139. //type2Map := make(map[string]data_manage.TypeListRespItem)
  140. // 初始化
  141. for _, v := range typeList {
  142. if v.Type1 != ""{
  143. if _, ok := typeMap[v.Type1];!ok {
  144. typeMap[v.Type1] = make(map[string][]string)
  145. } else {
  146. if _, ok := typeMap[v.Type1][v.Type2];!ok {
  147. typeMap[v.Type1][v.Type2] = make([]string, 0)
  148. }
  149. }
  150. }
  151. }
  152. for _, v := range typeList {
  153. if v.Type1 != ""{
  154. typeMap[v.Type1][v.Type2] = append(typeMap[v.Type1][v.Type2], v.Type3)
  155. }
  156. }
  157. for type1, type2Map := range typeMap {
  158. var item data_manage.TypeListRespItem
  159. item.Type = type1
  160. for type2, type3List := range type2Map {
  161. var child data_manage.TypeListRespItem
  162. child.Type = type2
  163. for _, type3 := range type3List {
  164. child.Child = append(child.Child, data_manage.TypeListRespItem{type3,nil})
  165. }
  166. item.Child = append(item.Child, child)
  167. }
  168. resp = append(resp, item)
  169. }
  170. br.Ret = 200
  171. br.Success = true
  172. br.Msg = "获取成功"
  173. br.Data = resp
  174. }