business_data.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508
  1. package data_manage
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/data_manage"
  7. "eta/eta_api/models/data_manage/request"
  8. "eta/eta_api/models/system"
  9. "eta/eta_api/services/data"
  10. etaTrialService "eta/eta_api/services/eta_trial"
  11. "eta/eta_api/utils"
  12. "fmt"
  13. "github.com/rdlucklib/rdluck_tools/paging"
  14. "strconv"
  15. "strings"
  16. "time"
  17. )
  18. // EdbBusinessController 外部数据(商家)
  19. type EdbBusinessController struct {
  20. controllers.BaseAuthController
  21. }
  22. // SourceList
  23. // @Title 来源列表
  24. // @Description 来源列表接口
  25. // @Success 200 {object} []*data_manageEdbBusinessSource
  26. // @router /business_data/source/list [get]
  27. func (c *EdbBusinessController) SourceList() {
  28. br := new(models.BaseResponse).Init()
  29. defer func() {
  30. c.Data["json"] = br
  31. c.ServeJSON()
  32. }()
  33. obj := data_manage.EdbBusinessSource{}
  34. list, err := obj.GetAllList()
  35. if err != nil && err.Error() != utils.ErrNoRow() {
  36. br.Msg = "获取失败"
  37. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  38. return
  39. }
  40. br.Ret = 200
  41. br.Success = true
  42. br.Msg = "获取成功"
  43. br.Data = list
  44. }
  45. // List
  46. // @Title 获取指标列表
  47. // @Description 获取指标列表接口
  48. // @Param PageSize query int true "每页数据条数"
  49. // @Param CurrentIndex query int true "当前页页码,从1开始"
  50. // @Param Frequency query string true "频度"
  51. // @Param Source query int true "来源"
  52. // @Param KeyWord query string true "编码/名称关键词"
  53. // @Success 200 {object} models.DataListResp
  54. // @router /business_data/index/list [get]
  55. func (c *EdbBusinessController) List() {
  56. br := new(models.BaseResponse).Init()
  57. defer func() {
  58. c.Data["json"] = br
  59. c.ServeJSON()
  60. }()
  61. pageSize, _ := c.GetInt("PageSize")
  62. currentIndex, _ := c.GetInt("CurrentIndex")
  63. keyword := c.GetString("KeyWord")
  64. frequency := c.GetString("Frequency")
  65. source, _ := c.GetInt("Source") //分类
  66. var startSize int
  67. if pageSize <= 0 {
  68. pageSize = utils.PageSize20
  69. }
  70. if currentIndex <= 0 {
  71. currentIndex = 1
  72. }
  73. startSize = utils.StartIndex(currentIndex, pageSize)
  74. var condition string
  75. var pars []interface{}
  76. if keyword != "" {
  77. keywordSlice := strings.Split(keyword, " ")
  78. if len(keywordSlice) > 0 {
  79. tmpConditionSlice := make([]string, 0)
  80. tmpConditionSlice = append(tmpConditionSlice, ` a.index_name like ? or a.index_code like ? `)
  81. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  82. for _, v := range keywordSlice {
  83. if v == ` ` || v == `` {
  84. continue
  85. }
  86. tmpConditionSlice = append(tmpConditionSlice, ` a.index_name like ? or a.index_code like ? `)
  87. pars = utils.GetLikeKeywordPars(pars, v, 2)
  88. }
  89. condition += ` AND (` + strings.Join(tmpConditionSlice, " or ") + `)`
  90. } else {
  91. condition += ` a.index_name like ? or a.index_code like ? `
  92. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  93. }
  94. }
  95. if frequency != "" {
  96. condition += ` AND a.frequency = ? `
  97. pars = append(pars, frequency)
  98. }
  99. if source > 0 {
  100. condition += ` AND a.source = ? `
  101. pars = append(pars, source)
  102. }
  103. obj := data_manage.BaseFromBusinessIndex{}
  104. total, err := obj.GetListCount(condition, pars)
  105. if err != nil {
  106. br.Msg = "获取失败"
  107. br.ErrMsg = "获取失败,Err:" + err.Error()
  108. return
  109. }
  110. list, err := obj.GetPageItemsByCondition(condition, pars, startSize, pageSize)
  111. if err != nil {
  112. br.Msg = "获取失败"
  113. br.ErrMsg = "获取失败,Err:" + err.Error()
  114. return
  115. }
  116. if len(list) <= 0 {
  117. list = make([]*data_manage.BaseFromBusinessIndexItem, 0)
  118. }
  119. page := paging.GetPaging(currentIndex, pageSize, total)
  120. resp := data_manage.BusinessIndexListResp{
  121. List: list,
  122. Paging: page,
  123. }
  124. br.Ret = 200
  125. br.Success = true
  126. br.Msg = "获取成功"
  127. br.Data = resp
  128. }
  129. // AddCheck
  130. // @Title 新增校验
  131. // @Description 新增校验
  132. // @Param request body data_manage.BloombergSourceBatchAddCheckReq true "type json string"
  133. // @Success 200 string "操作成功"
  134. // @router /business_data/add_check [post]
  135. func (c *EdbBusinessController) AddCheck() {
  136. br := new(models.BaseResponse).Init()
  137. defer func() {
  138. if br.ErrMsg == "" {
  139. br.IsSendEmail = false
  140. }
  141. c.Data["json"] = br
  142. c.ServeJSON()
  143. }()
  144. sysUser := c.SysUser
  145. if sysUser == nil {
  146. br.Msg = "请登录"
  147. br.ErrMsg = "请登录,SysUser Is Empty"
  148. br.Ret = 408
  149. return
  150. }
  151. var req *request.BusinessDataBatchAddCheckReq
  152. if e := json.Unmarshal(c.Ctx.Input.RequestBody, &req); e != nil {
  153. br.Msg = "参数解析异常!"
  154. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  155. return
  156. }
  157. codeMax := 100
  158. codeLen := len(req.IndexCodes)
  159. // 获取指标库已有指标
  160. existsEdb, e := data_manage.GetEdbCodesBySource(utils.DATA_SOURCE_BUSINESS)
  161. if e != nil {
  162. br.Msg = "获取失败"
  163. br.ErrMsg = "获取Bloomberg已添加的指标失败, Err: " + e.Error()
  164. return
  165. }
  166. existMap := make(map[string]*data_manage.EdbInfo)
  167. for _, v := range existsEdb {
  168. existMap[v.EdbCode] = v
  169. }
  170. // 非全选-不需要频率等筛选条件
  171. bloombergOb := new(data_manage.BaseFromBloombergIndex)
  172. obj := data_manage.BaseFromBusinessIndex{}
  173. if !req.ListAll {
  174. if codeLen == 0 {
  175. br.Msg = "请选择指标"
  176. return
  177. }
  178. if codeLen > codeMax {
  179. br.Msg = fmt.Sprintf("最多只能选择%d个指标", codeMax)
  180. return
  181. }
  182. // 查询选中的指标
  183. cond := fmt.Sprintf(` AND %s IN (%s)`, data_manage.BaseFromBusinessIndexCols.IndexCode, utils.GetOrmInReplace(codeLen))
  184. pars := make([]interface{}, 0)
  185. pars = append(pars, req.IndexCodes)
  186. list, e := obj.GeItemsByCondition(cond, pars, 0)
  187. if e != nil {
  188. br.Msg = "获取失败"
  189. br.ErrMsg = "获取Bloomberg原始指标列表失败, Err: " + e.Error()
  190. return
  191. }
  192. resp := make([]*data_manage.BaseFromBloombergIndexItem, 0)
  193. for _, v := range list {
  194. t := data_manage.FormatBaseFromBloombergIndex2Item(v)
  195. ed := existMap[v.IndexCode]
  196. if ed != nil {
  197. t.EdbExist = 1
  198. t.EdbInfoId = ed.EdbInfoId
  199. t.EdbUniqueCode = ed.UniqueCode
  200. t.EdbClassifyId = ed.ClassifyId
  201. }
  202. resp = append(resp, t)
  203. }
  204. br.Data = resp
  205. br.Msg = "校验成功"
  206. br.Ret = 200
  207. br.Success = true
  208. return
  209. }
  210. // 全选-需要频率等筛选条件
  211. cond := ``
  212. pars := make([]interface{}, 0)
  213. // 筛选项
  214. req.Keywords = strings.TrimSpace(req.Keywords)
  215. if req.Keywords != "" {
  216. cond += fmt.Sprintf(` AND (%s LIKE ? OR %s LIKE ?)`, data_manage.BaseFromBloombergIndexCols.IndexCode, data_manage.BaseFromBloombergIndexCols.IndexName)
  217. kw := fmt.Sprint("%", req.Keywords, "%")
  218. pars = append(pars, kw, kw)
  219. }
  220. if req.Frequency != "" {
  221. cond += fmt.Sprintf(` AND %s = ?`, data_manage.BaseFromBloombergIndexCols.Frequency)
  222. pars = append(pars, req.Frequency)
  223. }
  224. // 排除对应指标
  225. if codeLen > 0 {
  226. cond += fmt.Sprintf(` AND %s NOT IN (%s)`, data_manage.BaseFromBloombergIndexCols.IndexCode, utils.GetOrmInReplace(codeLen))
  227. pars = append(pars, req.IndexCodes)
  228. }
  229. // 查询max+1个指标
  230. list, e := bloombergOb.GetItemsByCondition(cond, pars, []string{}, orderRule, codeMax+1)
  231. if e != nil {
  232. br.Msg = "获取失败"
  233. br.ErrMsg = "获取Bloomberg原始指标列表失败, Err: " + e.Error()
  234. return
  235. }
  236. if len(list) > codeMax {
  237. br.Msg = fmt.Sprintf("最多只能选择%d个指标", codeMax)
  238. return
  239. }
  240. resp := make([]*data_manage.BaseFromBloombergIndexItem, 0)
  241. for _, v := range list {
  242. t := data_manage.FormatBaseFromBloombergIndex2Item(v)
  243. ed := existMap[v.IndexCode]
  244. if ed != nil {
  245. t.EdbExist = 1
  246. t.EdbInfoId = ed.EdbInfoId
  247. t.EdbUniqueCode = ed.UniqueCode
  248. t.EdbClassifyId = ed.ClassifyId
  249. }
  250. resp = append(resp, t)
  251. }
  252. br.Data = resp
  253. br.Msg = "校验成功"
  254. br.Ret = 200
  255. br.Success = true
  256. }
  257. // BatchAdd
  258. // @Title 批量新增
  259. // @Description 批量新增
  260. // @Param request body data_manage.AddEdbInfoReq true "type json string"
  261. // @Success 200 string "操作成功"
  262. // @router /business_data/batch_add [post]
  263. func (c *EdbBusinessController) BatchAdd() {
  264. br := new(models.BaseResponse).Init()
  265. defer func() {
  266. if br.ErrMsg == "" {
  267. br.IsSendEmail = false
  268. }
  269. c.Data["json"] = br
  270. c.ServeJSON()
  271. }()
  272. sysUser := c.SysUser
  273. if sysUser == nil {
  274. br.Msg = "请登录"
  275. br.ErrMsg = "请登录,SysUser Is Empty"
  276. br.Ret = 408
  277. return
  278. }
  279. deleteCache := true
  280. cacheKey := "CACHE_EDB_INFO_BATCH_ADD_BUSINESS_" + strconv.Itoa(sysUser.AdminId)
  281. defer func() {
  282. if deleteCache {
  283. _ = utils.Rc.Delete(cacheKey)
  284. }
  285. }()
  286. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  287. deleteCache = false
  288. br.Msg = "系统处理中,请稍后重试!"
  289. br.ErrMsg = "系统处理中,请稍后重试!" + sysUser.RealName + ";data:" + string(c.Ctx.Input.RequestBody)
  290. return
  291. }
  292. var req []*data_manage.AddEdbInfoReq
  293. if e := json.Unmarshal(c.Ctx.Input.RequestBody, &req); e != nil {
  294. br.Msg = "参数解析异常!"
  295. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  296. return
  297. }
  298. if len(req) == 0 {
  299. br.Msg = "请选择指标"
  300. return
  301. }
  302. if len(req) > 30 {
  303. br.Msg = "批量添加指标数量不得超过30个"
  304. return
  305. }
  306. indexNames := make([]string, 0)
  307. for _, v := range req {
  308. v.EdbCode = strings.TrimSpace(v.EdbCode)
  309. if v.EdbCode == "" {
  310. br.Msg = "指标ID不可为空"
  311. return
  312. }
  313. v.EdbName = strings.TrimSpace(v.EdbName)
  314. if v.EdbName == "" {
  315. br.Msg = "请输入指标名称"
  316. return
  317. }
  318. indexNames = append(indexNames, v.EdbName)
  319. v.Frequency = strings.TrimSpace(v.Frequency)
  320. if v.Frequency == "" {
  321. br.Msg = "请选择频度"
  322. return
  323. }
  324. v.Unit = strings.TrimSpace(v.Unit)
  325. if v.Unit == "" {
  326. br.Msg = "请输入单位"
  327. return
  328. }
  329. if v.ClassifyId <= 0 {
  330. br.Msg = "请选择分类"
  331. return
  332. }
  333. }
  334. // 限定同一时间最多批量新增30个指标
  335. for _, v := range req {
  336. var r data.BloombergIndexSource2EdbReq
  337. r.EdbCode = v.EdbCode
  338. r.EdbName = v.EdbName
  339. r.Frequency = v.Frequency
  340. r.Unit = v.Unit
  341. r.ClassifyId = v.ClassifyId
  342. r.AdminId = sysUser.AdminId
  343. r.AdminRealName = sysUser.RealName
  344. edbInfo, e, errMsg, skip := data.BloombergIndexSource2Edb(r)
  345. if e != nil {
  346. br.Msg = "操作失败"
  347. if errMsg != "" {
  348. br.Msg = errMsg
  349. }
  350. br.ErrMsg = e.Error()
  351. return
  352. }
  353. if skip {
  354. continue
  355. }
  356. // 试用平台更新用户累计新增指标数
  357. if utils.BusinessCode == utils.BusinessCodeSandbox {
  358. go func() {
  359. adminItem, e := system.GetSysAdminById(sysUser.AdminId)
  360. if e != nil {
  361. tips := fmt.Sprintf("试用平台更新用户累计新增指标数-获取用户失败, Err: " + e.Error())
  362. utils.FileLog.Info(tips)
  363. return
  364. }
  365. if adminItem.DepartmentName != "ETA试用客户" {
  366. return
  367. }
  368. var ur etaTrialService.EtaTrialUserReq
  369. ur.Mobile = adminItem.Mobile
  370. _, _ = etaTrialService.UpdateUserIndexNum(ur)
  371. }()
  372. }
  373. // 新增操作日志
  374. {
  375. edbLog := new(data_manage.EdbInfoLog)
  376. edbLog.EdbInfoId = edbInfo.EdbInfoId
  377. edbLog.SourceName = edbInfo.SourceName
  378. edbLog.Source = edbInfo.Source
  379. edbLog.EdbCode = edbInfo.EdbCode
  380. edbLog.EdbName = edbInfo.EdbName
  381. edbLog.ClassifyId = edbInfo.ClassifyId
  382. edbLog.SysUserId = sysUser.AdminId
  383. edbLog.SysUserRealName = sysUser.RealName
  384. edbLog.CreateTime = time.Now()
  385. edbLog.Content = string(c.Ctx.Input.RequestBody)
  386. edbLog.Status = "新增指标"
  387. edbLog.Method = c.Ctx.Input.URI()
  388. go data_manage.AddEdbInfoLog(edbLog)
  389. }
  390. }
  391. br.Msg = "操作成功"
  392. br.Ret = 200
  393. br.Success = true
  394. br.IsAddLog = true
  395. }
  396. // NameCheck
  397. // @Title 重名校验
  398. // @Description 批量新增
  399. // @Param request body data_manage.AddEdbInfoReq true "type json string"
  400. // @Success 200 string "操作成功"
  401. // @router /business_data/name_check [post]
  402. func (c *EdbBusinessController) NameCheck() {
  403. br := new(models.BaseResponse).Init()
  404. defer func() {
  405. if br.ErrMsg == "" {
  406. br.IsSendEmail = false
  407. }
  408. c.Data["json"] = br
  409. c.ServeJSON()
  410. }()
  411. sysUser := c.SysUser
  412. if sysUser == nil {
  413. br.Msg = "请登录"
  414. br.ErrMsg = "请登录,SysUser Is Empty"
  415. br.Ret = 408
  416. return
  417. }
  418. var req []*data_manage.AddEdbInfoReq
  419. if e := json.Unmarshal(c.Ctx.Input.RequestBody, &req); e != nil {
  420. br.Msg = "参数解析异常!"
  421. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  422. return
  423. }
  424. if len(req) == 0 {
  425. br.Msg = "请选择指标"
  426. return
  427. }
  428. type NameCheckResult struct {
  429. EdbCode string
  430. EdbName string
  431. Exist bool
  432. }
  433. indexNames := make([]string, 0)
  434. resp := make([]*NameCheckResult, 0)
  435. for _, v := range req {
  436. v.EdbCode = strings.TrimSpace(v.EdbCode)
  437. if v.EdbCode == "" {
  438. br.Msg = "指标ID不可为空"
  439. return
  440. }
  441. v.EdbName = strings.TrimSpace(v.EdbName)
  442. if v.EdbName == "" {
  443. br.Msg = "请输入指标名称"
  444. return
  445. }
  446. indexNames = append(indexNames, v.EdbName)
  447. resp = append(resp, &NameCheckResult{
  448. EdbCode: v.EdbCode,
  449. EdbName: v.EdbName,
  450. })
  451. }
  452. // 重名校验
  453. edbList, e := data_manage.GetEdbInfoByNameArr(indexNames)
  454. if e != nil {
  455. br.Msg = "操作失败"
  456. br.ErrMsg = "获取重名指标失败, Err: " + e.Error()
  457. return
  458. }
  459. nameExists := make(map[string]bool)
  460. for _, v := range edbList {
  461. nameExists[v.EdbName] = true
  462. }
  463. if len(nameExists) > 0 {
  464. for _, v := range resp {
  465. v.Exist = nameExists[v.EdbName]
  466. }
  467. }
  468. br.Data = resp
  469. br.Msg = "操作成功"
  470. br.Ret = 200
  471. br.Success = true
  472. }