business_edb.go 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  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/data"
  7. "eta/eta_hub/utils"
  8. "fmt"
  9. "github.com/rdlucklib/rdluck_tools/paging"
  10. "strings"
  11. )
  12. // Push
  13. // @Title 指标数据
  14. // @Description 指标数据
  15. // @Success 200 {object} data.BaseFromBusinessIndexResp
  16. // @router /push [post]
  17. func (c *EdbController) Push() {
  18. br := new(models.BaseResponse).Init()
  19. defer func() {
  20. c.Data["json"] = br
  21. c.ServeJSON()
  22. }()
  23. body := c.Ctx.Input.RequestBody
  24. var req data_manage.PushBusinessIndexReq
  25. err := json.Unmarshal(body, &req)
  26. if err != nil {
  27. br.Msg = "参数解析异常!"
  28. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  29. return
  30. }
  31. //if req.IndexCode == `` {
  32. // br.Msg = "指标编码不能为空"
  33. // return
  34. //}
  35. if req.IndexName == `` {
  36. br.Msg = "指标名称不能为空"
  37. return
  38. }
  39. if req.Unit == `` {
  40. br.Msg = "指标单位不能为空"
  41. return
  42. }
  43. if req.Frequency == `` {
  44. br.Msg = "指标频度不能为空"
  45. return
  46. }
  47. if req.SourceName == `` {
  48. br.Msg = "数据来源名称不能为空"
  49. return
  50. }
  51. // 兼容频度缺少度的字段
  52. if !strings.Contains(req.Frequency, "度") {
  53. req.Frequency = req.Frequency + "度"
  54. }
  55. if !utils.VerifyFrequency(req.Frequency) {
  56. br.Msg = "指标频度不合法:" + req.Frequency
  57. return
  58. }
  59. reqJson, err := json.Marshal(req)
  60. if err != nil {
  61. br.Msg = "参数解析异常!"
  62. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  63. return
  64. }
  65. respItem, err := data.PushEdb(string(reqJson))
  66. if err != nil {
  67. br.Msg = "处理失败"
  68. br.ErrMsg = "处理失败,Err:" + err.Error()
  69. return
  70. }
  71. if respItem.Ret != 200 {
  72. br.Msg = respItem.Msg
  73. br.ErrMsg = respItem.ErrMsg
  74. return
  75. }
  76. br.Data = respItem.Data
  77. br.Ret = 200
  78. br.Msg = "处理成功"
  79. }
  80. // BusinessEdbList
  81. // @Title 获取自有数据列表
  82. // @Description 获取自有数据列表
  83. // @Success 200 {object} data_manage.BaseFromBusinessIndexResp
  84. // @router /business/edb/list [get]
  85. func (c *EdbController) BusinessEdbList() {
  86. br := new(models.BaseResponse).Init()
  87. defer func() {
  88. c.Data["json"] = br
  89. c.ServeJSON()
  90. }()
  91. pageSize, _ := c.GetInt("PageSize")
  92. currentIndex, _ := c.GetInt("CurrentIndex")
  93. var startSize int
  94. if pageSize <= 0 {
  95. pageSize = utils.PageSize20
  96. }
  97. if currentIndex <= 0 {
  98. currentIndex = 1
  99. }
  100. startSize = utils.StartIndex(currentIndex, pageSize)
  101. //通过指标ID、指标名称、渠道、单位、频度查询匹配自有数据中已有的指标;
  102. indexCode := c.GetString("IndexCode")
  103. indexName := c.GetString("IndexName")
  104. sysSource := c.GetString("SysSource")
  105. //if indexName == `` && indexCode == `` {
  106. // br.Msg = "IndexCode与IndexName不能同时为空"
  107. // br.ErrMsg = "IndexCode与IndexName不能同时为空"
  108. // return
  109. //}
  110. cond := ``
  111. pars := make([]interface{}, 0)
  112. var orderRule string
  113. var fieldArr []string
  114. if sysSource == "ht_mini_crm" {
  115. fieldArr = []string{"index_code", "index_name", "frequency", "unit", "source_name", "start_date", "end_date", "create_time"}
  116. KeyWord := c.GetString("KeyWord")
  117. if KeyWord != "" {
  118. cond = `And (index_name like ? or index_code like ?)`
  119. pars = utils.GetLikeKeywordPars(pars, KeyWord, 2)
  120. }
  121. sourceName := c.GetString("SourceName")
  122. SortColumn := c.GetString("SortColumn")
  123. if SortColumn == "" {
  124. SortColumn = "create_time"
  125. }
  126. SortOrder := c.GetString("SortOrder")
  127. if SortOrder == "" {
  128. SortOrder = "desc"
  129. }
  130. if sourceName != "" {
  131. cond += ` AND source_name = ?`
  132. pars = append(pars, sourceName)
  133. } else {
  134. cond += ` AND source_name like ?`
  135. pars = append(pars, "一期-%")
  136. }
  137. frequency := c.GetString("Frequency")
  138. if frequency != `` {
  139. cond += ` AND frequency = ?`
  140. pars = append(pars, frequency)
  141. }
  142. orderRule = fmt.Sprintf("%s %s", SortColumn, SortOrder)
  143. } else {
  144. orderRule = "base_from_business_index_id DESC"
  145. fieldArr = []string{"index_code", "index_name", "frequency", "unit", "source_name"}
  146. if indexCode != `` {
  147. cond += ` AND index_code = ?`
  148. pars = append(pars, indexCode)
  149. }
  150. if indexName != `` {
  151. cond += ` AND index_name like ?`
  152. pars = utils.GetLikeKeywordPars(pars, indexName, 1)
  153. }
  154. sourceName := c.GetString("SourceName")
  155. if sourceName != `` {
  156. cond += ` AND source_name = ?`
  157. pars = append(pars, sourceName)
  158. }
  159. unit := c.GetString("Unit")
  160. if unit != `` {
  161. cond += ` AND unit = ?`
  162. pars = append(pars, unit)
  163. }
  164. frequency := c.GetString("Frequency")
  165. if frequency != `` {
  166. cond += ` AND frequency = ?`
  167. pars = append(pars, frequency)
  168. }
  169. }
  170. edbOb := new(data_manage.BaseFromBusinessIndex)
  171. total, edbList, e := edbOb.GetItemsByCondition(cond, pars, fieldArr, orderRule, startSize, pageSize)
  172. if e != nil {
  173. br.Msg = "获取失败"
  174. br.ErrMsg = "EdbList GetItemsByCondition err: " + e.Error()
  175. return
  176. }
  177. page := paging.GetPaging(currentIndex, pageSize, total)
  178. resp := data_manage.BaseFromBusinessIndexResp{
  179. Paging: page,
  180. List: edbList,
  181. }
  182. br.Data = resp
  183. br.Ret = 200
  184. br.Msg = "获取成功"
  185. }
  186. // BusinessSourceList
  187. // @Title 获取来源列表
  188. // @Description 获取来源列表
  189. // @Success 200 {object} data_manage.BaseFromBusinessIndexResp
  190. // @router /business/edb/source/list [get]
  191. func (c *EdbController) BusinessSourceList() {
  192. br := new(models.BaseResponse).Init()
  193. defer func() {
  194. c.Data["json"] = br
  195. c.ServeJSON()
  196. }()
  197. obj := new(data_manage.EdbBusinessSource)
  198. list, err := obj.GetAllList()
  199. if err != nil && err.Error() != utils.ErrNoRow() {
  200. br.Msg = "获取失败"
  201. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  202. return
  203. }
  204. br.Ret = 200
  205. br.Msg = "获取成功"
  206. br.Data = list
  207. }
  208. // DataList
  209. // @Title 获取指标数据列表
  210. // @Description 获取指标数据列表接口
  211. // @Param PageSize query int true "每页数据条数"
  212. // @Param CurrentIndex query int true "当前页页码,从1开始"
  213. // @Param IndexCode query string true "频度"
  214. // @Success 200 {object} models.DataListResp
  215. // @router /business/edb/data/list [get]
  216. func (c *EdbController) DataList() {
  217. br := new(models.BaseResponse).Init()
  218. defer func() {
  219. c.Data["json"] = br
  220. c.ServeJSON()
  221. }()
  222. req := new(data_manage.BusinessDataDataListReq)
  223. if e := c.ParseForm(req); e != nil {
  224. br.Msg = "获取失败"
  225. br.ErrMsg = "参数解析失败, Err: " + e.Error()
  226. return
  227. }
  228. pageSize := req.PageSize
  229. currentIndex := req.CurrentIndex
  230. var startSize int
  231. if pageSize <= 0 {
  232. pageSize = utils.PageSize20
  233. }
  234. if currentIndex <= 0 {
  235. currentIndex = 1
  236. }
  237. startSize = utils.StartIndex(currentIndex, pageSize)
  238. if req.IndexCode == "" {
  239. br.Msg = "指标编码为空"
  240. br.ErrMsg = "指标编码为空"
  241. return
  242. }
  243. // 获取分页数据
  244. dataCount, dataList, err := data.GetPageBaseBusinessIndexData(req.IndexCode, startSize, pageSize)
  245. if err != nil && err.Error() != utils.ErrNoRow() {
  246. br.Msg = "获取指标信息失败"
  247. br.ErrMsg = "获取指标数据总数失败,Err:" + err.Error()
  248. return
  249. }
  250. page := paging.GetPaging(currentIndex, pageSize, dataCount)
  251. resp := data_manage.BusinessIndexDataListResp{
  252. List: dataList,
  253. Paging: page,
  254. }
  255. br.Ret = 200
  256. br.Msg = "获取成功"
  257. br.Data = resp
  258. }
  259. // BusinessEdbDel
  260. // @Title 删除指标数据
  261. // @Description 删除指标数据
  262. // @Success 200 {object} data_manage.EdbInfoItem
  263. // @router /business/edb/del [post]
  264. func (c *EdbController) BusinessEdbDel() {
  265. br := new(models.BaseResponse).Init()
  266. defer func() {
  267. c.Data["json"] = br
  268. c.ServeJSON()
  269. }()
  270. body := c.Ctx.Input.RequestBody
  271. var req data_manage.DelBusinessIndexReq
  272. err := json.Unmarshal(body, &req)
  273. if err != nil {
  274. br.Msg = "参数解析异常!"
  275. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  276. return
  277. }
  278. if len(req.IndexCodeList) < 0 {
  279. br.Msg = "指标编码不允许为空"
  280. return
  281. }
  282. reqJson, err := json.Marshal(req)
  283. if err != nil {
  284. br.Msg = "参数解析异常!"
  285. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  286. return
  287. }
  288. respItem, err := data.DelBusinessIndex(string(reqJson))
  289. if err != nil {
  290. br.Msg = "删除失败"
  291. br.ErrMsg = "删除失败,Err:" + err.Error()
  292. return
  293. }
  294. if respItem.Ret != 200 {
  295. br.Msg = respItem.Msg
  296. br.ErrMsg = respItem.ErrMsg
  297. return
  298. }
  299. br.Data = respItem.Data
  300. br.Ret = 200
  301. br.Msg = "删除成功"
  302. }
  303. // BusinessEdbDataDel
  304. // @Title 删除指标数据
  305. // @Description 删除指标数据
  306. // @Success 200 {object} data_manage.EdbInfoItem
  307. // @router /business/data/del [post]
  308. func (c *EdbController) BusinessEdbDataDel() {
  309. br := new(models.BaseResponse).Init()
  310. defer func() {
  311. c.Data["json"] = br
  312. c.ServeJSON()
  313. }()
  314. body := c.Ctx.Input.RequestBody
  315. var req data_manage.DelBusinessDataReq
  316. err := json.Unmarshal(body, &req)
  317. if err != nil {
  318. br.Msg = "参数解析异常!"
  319. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  320. return
  321. }
  322. if req.IndexCode == `` {
  323. br.Msg = "指标编码不能为空"
  324. return
  325. }
  326. if req.StartDate == `` && req.EndDate == `` {
  327. br.Msg = "开始日期和结束日期不允许同时为空"
  328. return
  329. }
  330. reqJson, err := json.Marshal(req)
  331. if err != nil {
  332. br.Msg = "参数解析异常!"
  333. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  334. return
  335. }
  336. respItem, err := data.DelBusinessIndexData(string(reqJson))
  337. if err != nil {
  338. br.Msg = "删除失败"
  339. br.ErrMsg = "删除失败,Err:" + err.Error()
  340. return
  341. }
  342. if respItem.Ret != 200 {
  343. br.Msg = respItem.Msg
  344. br.ErrMsg = respItem.ErrMsg
  345. return
  346. }
  347. br.Data = respItem.Data
  348. br.Ret = 200
  349. br.Msg = "删除成功"
  350. }