eia_steo.go 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  1. package data_manage
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/models"
  5. "eta/eta_api/models/data_manage"
  6. "eta/eta_api/models/system"
  7. "eta/eta_api/services/alarm_msg"
  8. "eta/eta_api/services/data"
  9. "eta/eta_api/services/data_stat"
  10. etaTrialService "eta/eta_api/services/eta_trial"
  11. "eta/eta_api/utils"
  12. "fmt"
  13. "os"
  14. "path/filepath"
  15. "strconv"
  16. "strings"
  17. "time"
  18. "github.com/rdlucklib/rdluck_tools/paging"
  19. "github.com/tealeg/xlsx"
  20. )
  21. // EiaSteoClassify
  22. // @Title EiaSteo数据分类
  23. // @Description EiaSteo数据分类接口
  24. // @Success 200 {object} data_manage.LzClassify
  25. // @router /eia_steo/classify [get]
  26. func (this *EdbInfoController) EiaSteoClassify() {
  27. br := new(models.BaseResponse).Init()
  28. defer func() {
  29. this.Data["json"] = br
  30. this.ServeJSON()
  31. }()
  32. sysUser := this.SysUser
  33. if sysUser == nil {
  34. br.Msg = "请登录"
  35. br.ErrMsg = "请登录,SysUser Is Empty"
  36. br.Ret = 408
  37. return
  38. }
  39. classifyList, err := data_manage.GetEiaSteoClassifyList()
  40. if err != nil {
  41. br.Msg = "获取分类失败"
  42. br.ErrMsg = "获取分类失败,Err:" + err.Error()
  43. return
  44. }
  45. childClassifyMap := make(map[int][]*data_manage.BaseFromEiaSteoClassifyView)
  46. rootList := make([]*data_manage.BaseFromEiaSteoClassifyView, 0)
  47. for _, v := range classifyList {
  48. if v.Level == 1 {
  49. rootList = append(rootList, v)
  50. } else {
  51. childClassifyMap[v.ParentId] = append(childClassifyMap[v.ParentId], v)
  52. }
  53. }
  54. for _, v := range rootList {
  55. if existItems, ok := childClassifyMap[v.BaseFromEiaSteoClassifyId]; ok {
  56. v.Child = existItems
  57. }
  58. }
  59. br.Ret = 200
  60. br.Success = true
  61. br.Msg = "获取成功"
  62. br.Data = rootList
  63. }
  64. // EiaSteoData
  65. // @Title 获取EiaSteo数据
  66. // @Description 获取EiaSteo数据接口
  67. // @Param BaseFromEiaSteoClassifyId query int true "指标分类id"
  68. // @Param IndexCode query string true "指标code"
  69. // @Param IsExport query bool false "是否导出excel,默认是false"
  70. // @Param PageSize query int true "每页数据条数"
  71. // @Param CurrentIndex query int true "当前页页码,从1开始"
  72. // @Success 200 {object} data_manage.LzFrequency
  73. // @router /eia_steo/data [get]
  74. func (this *EdbInfoController) EiaSteoData() {
  75. br := new(models.BaseResponse).Init()
  76. defer func() {
  77. this.Data["json"] = br
  78. this.ServeJSON()
  79. }()
  80. sysUser := this.SysUser
  81. if sysUser == nil {
  82. br.Msg = "请登录"
  83. br.ErrMsg = "请登录,SysUser Is Empty"
  84. br.Ret = 408
  85. return
  86. }
  87. pageSize, _ := this.GetInt("PageSize")
  88. currentIndex, _ := this.GetInt("CurrentIndex")
  89. var startSize int
  90. //是否导出报表
  91. isExport, _ := this.GetBool("IsExport")
  92. if isExport {
  93. pageSize = 10000
  94. currentIndex = 1
  95. }
  96. if pageSize <= 0 {
  97. pageSize = utils.PageSize20
  98. }
  99. if currentIndex <= 0 {
  100. currentIndex = 1
  101. }
  102. startSize = utils.StartIndex(currentIndex, pageSize)
  103. var condition string
  104. var pars []interface{}
  105. indexCode := this.GetString("IndexCode")
  106. if indexCode != "" {
  107. condition += ` AND index_code = ? `
  108. pars = append(pars, utils.TrimStr(indexCode))
  109. }
  110. classifyId, _ := this.GetInt("BaseFromEiaSteoClassifyId")
  111. if classifyId > 0 {
  112. classifyList, err := data.GetClassifyALLById(classifyId)
  113. if err != nil {
  114. br.Msg = "获取数据失败"
  115. br.ErrMsg = "获取分类数据失败,Err:" + err.Error()
  116. return
  117. }
  118. var classifyIds []int
  119. for _, v := range classifyList {
  120. classifyIds = append(classifyIds, v.BaseFromEiaSteoClassifyId)
  121. }
  122. condition += ` AND base_from_eia_steo_classify_id IN (` + utils.GetOrmInReplace(len(classifyIds)) + `) `
  123. pars = append(pars, classifyIds)
  124. }
  125. //获取指标
  126. indexList, err := data_manage.GetEiaSteoIndexList(condition, pars)
  127. if err != nil {
  128. br.Msg = "获取数据失败"
  129. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  130. return
  131. }
  132. alarm_msg.SendAlarmMsg("指标数:"+strconv.Itoa(len(indexList)), 1)
  133. resultList := make([]data_manage.EiaSteoIndexListResp, 0)
  134. for _, v := range indexList {
  135. indexName := v.IndexName
  136. if indexName == `` {
  137. indexName = v.IndexNameOriginal
  138. }
  139. product := data_manage.EiaSteoIndexListResp{
  140. BaseFromEiaSteoIndexId: v.BaseFromEiaSteoIndexId,
  141. BaseFromEiaSteoClassifyId: v.BaseFromEiaSteoClassifyId,
  142. IndexCode: v.IndexCode,
  143. IndexName: indexName,
  144. //IndexNameOriginal: v.IndexNameOriginal,
  145. Unit: v.Unit,
  146. Frequency: v.Frequency,
  147. StartDate: v.StartDate.Format(utils.FormatDate),
  148. EndDate: v.EndDate.Format(utils.FormatDate),
  149. ModifyTime: v.ModifyTime.Format(utils.FormatDateTime),
  150. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  151. //Paging: tmpPaging,
  152. //DataList: nil,
  153. }
  154. total, err := data_manage.GetEiaSteoIndexDataCount(v.IndexCode)
  155. page := paging.GetPaging(currentIndex, pageSize, total)
  156. dataList, err := data_manage.GetEiaSteoIndexDataList(v.IndexCode, startSize, pageSize)
  157. if err != nil {
  158. br.Msg = "获取数据失败"
  159. br.ErrMsg = "获取指标数据失败,Err:" + err.Error()
  160. return
  161. }
  162. if dataList == nil {
  163. dataList = make([]*data_manage.BaseFromEiaSteoDataItem, 0)
  164. }
  165. product.DataList = dataList
  166. product.Paging = page
  167. resultList = append(resultList, product)
  168. }
  169. //导出excel
  170. if isExport {
  171. EiaSteoDataExport(this, resultList, br)
  172. return
  173. }
  174. br.Ret = 200
  175. br.Success = true
  176. br.Msg = "获取成功"
  177. br.Data = resultList
  178. }
  179. // EiaSteoSearchList
  180. // @Title EiaSteo模糊搜索
  181. // @Description EiaSteo模糊搜索
  182. // @Param Keyword query string ture "关键字搜索"
  183. // @Success 200 {object} models.BaseResponse
  184. // @router /eia_steo/search_list [get]
  185. func (this *EdbInfoController) EiaSteoSearchList() {
  186. br := new(models.BaseResponse).Init()
  187. defer func() {
  188. this.Data["json"] = br
  189. this.ServeJSON()
  190. }()
  191. sysUser := this.SysUser
  192. if sysUser == nil {
  193. br.Msg = "请重新登录"
  194. return
  195. }
  196. //关键字
  197. keyword := this.GetString("Keyword")
  198. list, err := data_manage.GetEiaSteoItemList(utils.TrimStr(keyword))
  199. if err != nil {
  200. br.ErrMsg = "获取失败,Err:" + err.Error()
  201. br.Msg = "获取失败"
  202. return
  203. }
  204. br.Ret = 200
  205. br.Success = true
  206. br.Msg = "获取成功"
  207. br.Data = list
  208. }
  209. // EiaSteoDataExport 表格导出
  210. func EiaSteoDataExport(this *EdbInfoController, list []data_manage.EiaSteoIndexListResp, br *models.BaseResponse) {
  211. sysUser := this.SysUser
  212. if sysUser == nil {
  213. br.Msg = "请重新登录"
  214. return
  215. }
  216. dir, _ := os.Executable()
  217. exPath := filepath.Dir(dir)
  218. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  219. xlsxFile := xlsx.NewFile()
  220. sheet, err := xlsxFile.AddSheet("数据报表")
  221. //获取指标数据
  222. rowSecName := sheet.AddRow()
  223. celSecName := rowSecName.AddCell()
  224. celSecName.SetValue("指标名称")
  225. rowUnit := sheet.AddRow()
  226. celUnit := rowUnit.AddCell()
  227. celUnit.SetValue("单位")
  228. rowModifyDate := sheet.AddRow()
  229. rowModifyCell := rowModifyDate.AddCell()
  230. rowModifyCell.SetValue("更新时间")
  231. dataMap := make(map[string]map[string]*data_manage.BaseFromEiaSteoDataItem)
  232. var indexCodeList []string
  233. for _, v := range list {
  234. cellSenName := rowSecName.AddCell()
  235. cellSenName.SetValue(v.IndexName)
  236. celUnit := rowUnit.AddCell()
  237. celUnit.SetValue(v.Unit)
  238. rowModifyCell := rowModifyDate.AddCell()
  239. rowModifyCell.SetValue(v.ModifyTime)
  240. indexCodeList = append(indexCodeList, v.IndexCode)
  241. dataMap[v.IndexCode] = make(map[string]*data_manage.BaseFromEiaSteoDataItem)
  242. for _, item := range v.DataList {
  243. dataMap[item.IndexCode][item.DataTime] = item
  244. }
  245. }
  246. dateList, err := data_manage.GetEiaSteoDateList(indexCodeList)
  247. if err != nil {
  248. br.Msg = "获取数据失败"
  249. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  250. return
  251. }
  252. for _, n := range dateList {
  253. dateStr := n.DataTime //当前日期
  254. rowData := sheet.AddRow()
  255. celDate := rowData.AddCell()
  256. celDate.SetValue(dateStr)
  257. for _, m := range list {
  258. celData := rowData.AddCell()
  259. if dataMap[m.IndexCode][dateStr] != nil {
  260. celData.SetValue(dataMap[m.IndexCode][dateStr].Value)
  261. }
  262. }
  263. }
  264. err = xlsxFile.Save(downLoadnFilePath)
  265. if err != nil {
  266. //有指标无数据时先导出一遍空表
  267. sheet, err := xlsxFile.AddSheet("无数据")
  268. if err != nil {
  269. br.Msg = "新增Sheet失败"
  270. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  271. return
  272. }
  273. rowSecName := sheet.AddRow()
  274. celSecName := rowSecName.AddCell()
  275. celSecName.SetValue("")
  276. err = xlsxFile.Save(downLoadnFilePath)
  277. if err != nil {
  278. br.Msg = "保存文件失败"
  279. br.ErrMsg = "保存文件失败"
  280. return
  281. }
  282. }
  283. fileName := `EiaSteo数据`
  284. fileName += time.Now().Format("06.01.02") + `.xlsx` //文件名称
  285. this.Ctx.Output.Download(downLoadnFilePath, fileName)
  286. defer func() {
  287. os.Remove(downLoadnFilePath)
  288. }()
  289. br.Ret = 200
  290. br.Success = true
  291. br.Msg = "success"
  292. }
  293. // EiaSteoBatchSearch
  294. // @Title EiaSteo批量操作查询接口
  295. // @Description EiaSteo批量操作查询接口
  296. // @Param BaseFromEiaSteoClassifyIds query string true "分类id"
  297. // @Param Keyword query string true "名称关键词"
  298. // @Success 200 {object} data_manage.LzFrequency
  299. // @router /eia_steo/batch_search [get]
  300. func (this *EdbInfoController) EiaSteoBatchSearch() {
  301. br := new(models.BaseResponse).Init()
  302. defer func() {
  303. this.Data["json"] = br
  304. this.ServeJSON()
  305. }()
  306. sysUser := this.SysUser
  307. if sysUser == nil {
  308. br.Msg = "请登录"
  309. br.ErrMsg = "请登录,SysUser Is Empty"
  310. br.Ret = 408
  311. return
  312. }
  313. classifyIdStr := this.GetString("BaseFromEiaSteoClassifyIds")
  314. var condition string
  315. var pars []interface{}
  316. classifyIds := strings.Split(classifyIdStr, ",")
  317. if len(classifyIds) > 0 && classifyIds[0] != `` {
  318. condition += " AND base_from_eia_steo_classify_id IN (" + utils.GetOrmInReplace(len(classifyIds)) + " ) "
  319. pars = append(pars, classifyIds)
  320. }
  321. keyword := this.GetString("Keyword")
  322. if keyword != `` {
  323. condition += " AND (index_name like ? OR index_code like ?) "
  324. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  325. }
  326. if classifyIdStr == `` && keyword == `` {
  327. var list = make([]*data_manage.BaseFromEiaSteoIndex, 0)
  328. br.Ret = 200
  329. br.Success = true
  330. br.Msg = "获取成功"
  331. br.Data = list
  332. return
  333. }
  334. list, err := data_manage.GetEiaSteoIndexList(condition, pars)
  335. if err != nil {
  336. br.Msg = "获取失败"
  337. br.ErrMsg = "获取失败,Err:" + err.Error()
  338. return
  339. }
  340. br.Ret = 200
  341. br.Success = true
  342. br.Msg = "获取成功"
  343. br.Data = list
  344. }
  345. // AddCheck
  346. // @Title 新增校验
  347. // @Description 新增校验
  348. // @Param request body request.BusinessDataBatchAddCheckReq true "type json string"
  349. // @Success 200 string "操作成功"
  350. // @router /eia_steo/edb_info/add_check [post]
  351. func (c *EdbInfoController) EiaSteoAddCheck() {
  352. br := new(models.BaseResponse).Init()
  353. defer func() {
  354. if br.ErrMsg == "" {
  355. br.IsSendEmail = false
  356. }
  357. c.Data["json"] = br
  358. c.ServeJSON()
  359. }()
  360. sysUser := c.SysUser
  361. if sysUser == nil {
  362. br.Msg = "请登录"
  363. br.ErrMsg = "请登录,SysUser Is Empty"
  364. br.Ret = 408
  365. return
  366. }
  367. var req data_manage.EiaSteoDataBatchAddCheckReq
  368. if e := json.Unmarshal(c.Ctx.Input.RequestBody, &req); e != nil {
  369. br.Msg = "参数解析异常!"
  370. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  371. return
  372. }
  373. codeMax := 30
  374. codeLen := len(req.IndexCodes)
  375. if codeLen == 0 {
  376. br.Msg = "请选择指标"
  377. return
  378. }
  379. if codeLen > codeMax {
  380. br.Msg = fmt.Sprintf("最多只能选择%d个指标", codeMax)
  381. return
  382. }
  383. // 获取指标库已有指标
  384. existsEdb, e := data_manage.GetEdbCodesBySource(utils.DATA_SOURCE_EIA_STEO)
  385. if e != nil {
  386. br.Msg = "获取失败"
  387. br.ErrMsg = "获取自有数据已添加的指标失败, Err: " + e.Error()
  388. return
  389. }
  390. existMap := make(map[string]*data_manage.EdbInfo)
  391. for _, v := range existsEdb {
  392. existMap[v.EdbCode] = v
  393. }
  394. // 查询选中的指标
  395. cond := fmt.Sprintf(` AND index_code IN (%s) `, utils.GetOrmInReplace(len(req.IndexCodes)))
  396. pars := make([]interface{}, 0)
  397. pars = append(pars, req.IndexCodes)
  398. list, err := data_manage.GetEiaSteoIndexList(cond, pars)
  399. if err != nil {
  400. br.Msg = "获取失败"
  401. br.ErrMsg = "获取eiaSteo原始指标列表失败, Err: " + err.Error()
  402. return
  403. }
  404. resp := make([]*data_manage.BaseFromEiaSteoIndexItem, 0)
  405. for _, v := range list {
  406. if edbInfo, ok := existMap[v.IndexCode]; ok {
  407. resp = append(resp, &data_manage.BaseFromEiaSteoIndexItem{
  408. BaseFromEiaSteoIndexId: v.BaseFromEiaSteoIndexId,
  409. BaseFromEiaSteoClassifyId: v.BaseFromEiaSteoClassifyId,
  410. IndexCode: v.IndexCode,
  411. IndexName: v.IndexName,
  412. EdbInfoId: edbInfo.EdbInfoId,
  413. EdbUniqueCode: edbInfo.UniqueCode,
  414. EdbClassifyId: edbInfo.ClassifyId,
  415. EdbExist: 1,
  416. })
  417. } else {
  418. resp = append(resp, &data_manage.BaseFromEiaSteoIndexItem{
  419. BaseFromEiaSteoIndexId: v.BaseFromEiaSteoIndexId,
  420. BaseFromEiaSteoClassifyId: v.BaseFromEiaSteoClassifyId,
  421. IndexCode: v.IndexCode,
  422. IndexName: v.IndexName,
  423. EdbInfoId: 0,
  424. EdbUniqueCode: "",
  425. EdbClassifyId: 0,
  426. EdbExist: 0,
  427. })
  428. }
  429. }
  430. br.Data = resp
  431. br.Msg = "校验成功"
  432. br.Ret = 200
  433. br.Success = true
  434. }
  435. // EiaSteoNameCheck
  436. // @Title 重名校验
  437. // @Description 批量新增
  438. // @Param request body data_manage.AddEdbInfoReq true "type json string"
  439. // @Success 200 string "操作成功"
  440. // @router /eia_steo/name_check [post]
  441. func (c *EdbInfoController) EiaSteoNameCheck() {
  442. br := new(models.BaseResponse).Init()
  443. defer func() {
  444. if br.ErrMsg == "" {
  445. br.IsSendEmail = false
  446. }
  447. c.Data["json"] = br
  448. c.ServeJSON()
  449. }()
  450. sysUser := c.SysUser
  451. if sysUser == nil {
  452. br.Msg = "请登录"
  453. br.ErrMsg = "请登录,SysUser Is Empty"
  454. br.Ret = 408
  455. return
  456. }
  457. var req []*data_manage.NameCheckEdbInfoReq
  458. if e := json.Unmarshal(c.Ctx.Input.RequestBody, &req); e != nil {
  459. br.Msg = "参数解析异常!"
  460. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  461. return
  462. }
  463. if len(req) == 0 {
  464. br.Msg = "请选择指标"
  465. return
  466. }
  467. codeMax := 30
  468. codeLen := len(req)
  469. if codeLen > codeMax {
  470. br.Msg = fmt.Sprintf("最多只能选择%d个指标", codeMax)
  471. return
  472. }
  473. type NameCheckResult struct {
  474. EdbCode string
  475. EdbName string
  476. Exist bool
  477. }
  478. indexNames := make([]string, 0)
  479. resp := make([]*NameCheckResult, 0)
  480. for _, v := range req {
  481. v.EdbCode = strings.TrimSpace(v.EdbCode)
  482. if v.EdbCode == "" {
  483. br.Msg = "指标ID不可为空"
  484. return
  485. }
  486. v.EdbName = strings.TrimSpace(v.EdbName)
  487. if v.EdbName == "" {
  488. br.Msg = "请输入指标名称"
  489. return
  490. }
  491. indexNames = append(indexNames, v.EdbName)
  492. resp = append(resp, &NameCheckResult{
  493. EdbCode: v.EdbCode,
  494. EdbName: v.EdbName,
  495. })
  496. dataItems, err := data_manage.GetEdbDataAllByEdbCode(v.EdbCode, utils.DATA_SOURCE_EIA_STEO, 0, utils.EDB_DATA_LIMIT)
  497. if err != nil && err.Error() != utils.ErrNoRow() {
  498. br.Msg = "获取失败"
  499. br.ErrMsg = "获取钢联已存在信息失败,Err:" + err.Error()
  500. return
  501. }
  502. if len(dataItems) <= 0 {
  503. respItem, err := data.AddEdbData(utils.DATA_SOURCE_EIA_STEO, v.EdbCode, v.Frequency)
  504. if err != nil {
  505. br.Msg = "获取失败"
  506. br.ErrMsg = "获取失败,Err:" + err.Error()
  507. return
  508. }
  509. if respItem.Ret != 200 {
  510. br.Msg = "未搜索到该指标"
  511. br.ErrMsg = respItem.ErrMsg + ";EdbCode:" + v.EdbCode
  512. return
  513. }
  514. }
  515. }
  516. // 重名校验
  517. edbList, e := data_manage.GetEdbInfoByNameArr(indexNames, utils.EDB_INFO_TYPE)
  518. if e != nil {
  519. br.Msg = "操作失败"
  520. br.ErrMsg = "获取重名指标失败, Err: " + e.Error()
  521. return
  522. }
  523. nameExists := make(map[string]bool)
  524. for _, v := range edbList {
  525. nameExists[v.EdbName] = true
  526. }
  527. if len(nameExists) > 0 {
  528. for _, v := range resp {
  529. v.Exist = nameExists[v.EdbName]
  530. }
  531. }
  532. br.Data = resp
  533. br.Msg = "校验成功"
  534. br.Ret = 200
  535. br.Success = true
  536. }
  537. // EiaSteoBatchAdd
  538. // @Title eiaSteo批量新增
  539. // @Description eiaSteo批量新增
  540. // @Param request body data_manage.AddEdbInfoReq true "type json string"
  541. // @Success 200 string "操作成功"
  542. // @router /eia_steo/batch_add [post]
  543. func (this *EdbInfoController) EiaSteoBatchAdd() {
  544. br := new(models.BaseResponse).Init()
  545. defer func() {
  546. if br.ErrMsg == "" {
  547. br.IsSendEmail = false
  548. }
  549. this.Data["json"] = br
  550. this.ServeJSON()
  551. }()
  552. sysUser := this.SysUser
  553. if sysUser == nil {
  554. br.Msg = "请登录"
  555. br.ErrMsg = "请登录,SysUser Is Empty"
  556. br.Ret = 408
  557. return
  558. }
  559. deleteCache := true
  560. cacheKey := "CACHE_EDB_INFO_BATCH_ADD_EIA_STEO_" + strconv.Itoa(sysUser.AdminId)
  561. defer func() {
  562. if deleteCache {
  563. _ = utils.Rc.Delete(cacheKey)
  564. }
  565. }()
  566. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  567. deleteCache = false
  568. br.Msg = "系统处理中,请稍后重试!"
  569. br.ErrMsg = "系统处理中,请稍后重试!" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  570. return
  571. }
  572. var req []*data_manage.AddEdbInfoReq
  573. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  574. br.Msg = "参数解析异常!"
  575. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  576. return
  577. }
  578. if len(req) == 0 {
  579. br.Msg = "请选择指标"
  580. return
  581. }
  582. if len(req) > 30 {
  583. br.Msg = "批量添加指标数量不得超过30个"
  584. return
  585. }
  586. for _, v := range req {
  587. v.EdbCode = strings.TrimSpace(v.EdbCode)
  588. if v.EdbCode == "" {
  589. br.Msg = "指标ID不可为空"
  590. return
  591. }
  592. v.EdbName = strings.TrimSpace(v.EdbName)
  593. if v.EdbName == "" {
  594. br.Msg = "请输入指标名称"
  595. return
  596. }
  597. v.Frequency = strings.TrimSpace(v.Frequency)
  598. if v.Frequency == "" {
  599. br.Msg = "请选择频度"
  600. return
  601. }
  602. v.Unit = strings.TrimSpace(v.Unit)
  603. if v.Unit == "" {
  604. br.Msg = "请输入单位"
  605. return
  606. }
  607. if v.ClassifyId <= 0 {
  608. br.Msg = "请选择分类"
  609. return
  610. }
  611. }
  612. // 限定同一时间最多批量新增30个指标
  613. for _, v := range req {
  614. var r data.EiaSteoIndexSource2EdbReq
  615. r.EdbCode = v.EdbCode
  616. r.EdbName = v.EdbName
  617. r.Frequency = v.Frequency
  618. r.Unit = v.Unit
  619. r.ClassifyId = v.ClassifyId
  620. r.AdminId = sysUser.AdminId
  621. r.AdminRealName = sysUser.RealName
  622. edbInfo, e, errMsg, skip := data.EiaSteoIndexSource2Edb(r, this.Lang)
  623. if e != nil {
  624. br.Msg = "操作失败"
  625. if errMsg != "" {
  626. br.Msg = errMsg
  627. }
  628. br.ErrMsg = e.Error()
  629. return
  630. }
  631. if skip {
  632. continue
  633. }
  634. // 试用平台更新用户累计新增指标数
  635. if utils.BusinessCode == utils.BusinessCodeSandbox {
  636. go func() {
  637. adminItem, e := system.GetSysAdminById(sysUser.AdminId)
  638. if e != nil {
  639. tips := fmt.Sprintf("试用平台更新用户累计新增指标数-获取用户失败, Err: " + e.Error())
  640. utils.FileLog.Info(tips)
  641. return
  642. }
  643. if adminItem.DepartmentName != "ETA试用客户" {
  644. return
  645. }
  646. var ur etaTrialService.EtaTrialUserReq
  647. ur.Mobile = adminItem.Mobile
  648. _, _ = etaTrialService.UpdateUserIndexNum(ur)
  649. }()
  650. }
  651. // 新增操作日志
  652. {
  653. edbLog := new(data_manage.EdbInfoLog)
  654. edbLog.EdbInfoId = edbInfo.EdbInfoId
  655. edbLog.SourceName = edbInfo.SourceName
  656. edbLog.Source = edbInfo.Source
  657. edbLog.EdbCode = edbInfo.EdbCode
  658. edbLog.EdbName = edbInfo.EdbName
  659. edbLog.ClassifyId = edbInfo.ClassifyId
  660. edbLog.SysUserId = sysUser.AdminId
  661. edbLog.SysUserRealName = sysUser.RealName
  662. edbLog.CreateTime = time.Now()
  663. edbLog.Content = string(this.Ctx.Input.RequestBody)
  664. edbLog.Status = "新增指标"
  665. edbLog.Method = this.Ctx.Input.URI()
  666. go data_manage.AddEdbInfoLog(edbLog)
  667. }
  668. }
  669. br.Msg = "操作成功"
  670. br.Ret = 200
  671. br.Success = true
  672. br.IsAddLog = true
  673. }
  674. // EiaSteoAdd
  675. // @Title 新增eiaSteo指标接口
  676. // @Description 新增eiaSteo指标接口
  677. // @Param request body data_manage.AddEdbInfoReq true "type json string"
  678. // @Success Ret=200 保存成功
  679. // @router /eia_steo/edb_info/add [post]
  680. func (this *EdbInfoController) EiaSteoAdd() {
  681. br := new(models.BaseResponse).Init()
  682. defer func() {
  683. this.Data["json"] = br
  684. this.ServeJSON()
  685. }()
  686. sysUser := this.SysUser
  687. if sysUser == nil {
  688. br.Msg = "请登录"
  689. br.ErrMsg = "请登录,SysUser Is Empty"
  690. br.Ret = 408
  691. return
  692. }
  693. deleteCache := true
  694. cacheKey := "CACHE_EDB_INFO_ADD_" + strconv.Itoa(sysUser.AdminId)
  695. defer func() {
  696. if deleteCache {
  697. utils.Rc.Delete(cacheKey)
  698. }
  699. }()
  700. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  701. deleteCache = false
  702. br.Msg = "系统处理中,请稍后重试!"
  703. br.ErrMsg = "系统处理中,请稍后重试!" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  704. return
  705. }
  706. var req data_manage.AddEdbInfoReq
  707. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  708. if err != nil {
  709. br.Msg = "参数解析异常!"
  710. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  711. return
  712. }
  713. req.EdbName = strings.Trim(req.EdbName, " ")
  714. req.EdbCode = strings.Trim(req.EdbCode, " ")
  715. if req.EdbCode == "" {
  716. br.Msg = "指标ID不能为空"
  717. return
  718. }
  719. if req.EdbName == "" {
  720. br.Msg = "指标名称不能为空"
  721. return
  722. }
  723. if req.Frequency == "" {
  724. br.Msg = "频率不能为空"
  725. return
  726. }
  727. if req.Unit == "" {
  728. br.Msg = "单位不能为空"
  729. return
  730. }
  731. if req.ClassifyId <= 0 {
  732. br.Msg = "请选择分类"
  733. return
  734. }
  735. tmpInfo, err := data_manage.GetBaseFromEiaSteoIndexByCode(req.EdbCode)
  736. if err != nil {
  737. if err.Error() != utils.ErrNoRow() {
  738. br.Msg = "获取失败"
  739. br.ErrMsg = "获取失败,Err:" + err.Error()
  740. return
  741. }
  742. }
  743. var source int
  744. if tmpInfo != nil {
  745. source = utils.DATA_SOURCE_EIA_STEO
  746. } else {
  747. br.Msg = "指标不存在"
  748. return
  749. }
  750. // 指标入库
  751. edbInfo, err, errMsg, isSendEmail := data.EdbInfoAdd(source, utils.DATA_SUB_SOURCE_EDB, req.ClassifyId, req.EdbCode, req.EdbName, req.Frequency, req.Unit, req.StartDate, req.EndDate, sysUser.AdminId, sysUser.RealName, this.Lang)
  752. if err != nil {
  753. br.Msg = "保存失败"
  754. if errMsg != `` {
  755. br.Msg = errMsg
  756. }
  757. br.ErrMsg = err.Error()
  758. br.IsSendEmail = isSendEmail
  759. return
  760. }
  761. // 试用平台更新用户累计新增指标数
  762. adminItem, e := system.GetSysAdminById(sysUser.AdminId)
  763. if e != nil {
  764. br.Msg = "操作失败"
  765. br.ErrMsg = "获取系统用户数据失败,Err:" + e.Error()
  766. return
  767. }
  768. if utils.BusinessCode == utils.BusinessCodeSandbox && adminItem.DepartmentName == "ETA试用客户" {
  769. go func() {
  770. var r etaTrialService.EtaTrialUserReq
  771. r.Mobile = adminItem.Mobile
  772. _, _ = etaTrialService.UpdateUserIndexNum(r)
  773. }()
  774. }
  775. //新增操作日志
  776. {
  777. // 添加钢联指标更新日志
  778. if edbInfo.Source == utils.DATA_SOURCE_MYSTEEL_CHEMICAL {
  779. go data_stat.AddEdbInfoUpdateLog(edbInfo.EdbInfoId, 1, "", sysUser, 2)
  780. }
  781. edbLog := new(data_manage.EdbInfoLog)
  782. edbLog.EdbInfoId = edbInfo.EdbInfoId
  783. edbLog.SourceName = edbInfo.SourceName
  784. edbLog.Source = edbInfo.Source
  785. edbLog.EdbCode = edbInfo.EdbCode
  786. edbLog.EdbName = edbInfo.EdbName
  787. edbLog.ClassifyId = edbInfo.ClassifyId
  788. edbLog.SysUserId = sysUser.AdminId
  789. edbLog.SysUserRealName = sysUser.RealName
  790. edbLog.CreateTime = time.Now()
  791. edbLog.Content = string(this.Ctx.Input.RequestBody)
  792. edbLog.Status = "新增指标"
  793. edbLog.Method = this.Ctx.Input.URI()
  794. go data_manage.AddEdbInfoLog(edbLog)
  795. }
  796. // 更新es
  797. go data.AddOrEditEdbInfoToEs(edbInfo.EdbInfoId)
  798. resp := new(data_manage.AddEdbInfoResp)
  799. resp.EdbInfoId = edbInfo.EdbInfoId
  800. resp.UniqueCode = edbInfo.UniqueCode
  801. resp.ClassifyId = edbInfo.ClassifyId
  802. br.Ret = 200
  803. br.Success = true
  804. br.Msg = "保存成功"
  805. br.Data = resp
  806. br.IsAddLog = true
  807. }