base_from_ly_index_controller.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541
  1. // Package data_manage
  2. // @Author gmy 2024/8/12 14:31:00
  3. package data_manage
  4. import (
  5. "encoding/json"
  6. "eta/eta_api/controllers"
  7. "eta/eta_api/models"
  8. "eta/eta_api/models/data_manage"
  9. "eta/eta_api/models/system"
  10. "eta/eta_api/services/data"
  11. etaTrialService "eta/eta_api/services/eta_trial"
  12. "eta/eta_api/utils"
  13. "fmt"
  14. "github.com/tealeg/xlsx"
  15. "os"
  16. "path/filepath"
  17. "strconv"
  18. "strings"
  19. "time"
  20. )
  21. type BaseFromLyIndexController struct {
  22. controllers.BaseAuthController
  23. }
  24. const (
  25. codeMax = 30 // 指标编码最大数量
  26. dataSource = "粮油商务网"
  27. )
  28. // LyIndexList
  29. // @Title 获取指标列表
  30. // @Description 获取指标列表
  31. // @Param searchParam query string false "搜索参数"
  32. // @Param PageSize query int true "每页数据条数"
  33. // @Param CurrentIndex query int true "当前页页码,从1开始"
  34. // @Success 200 {object} []data_manage.BaseFromLyIndexPage
  35. // @router /ly/index/list [get]
  36. func (this *BaseFromLyIndexController) LyIndexList() {
  37. br := new(models.BaseResponse).Init()
  38. defer func() {
  39. if br.ErrMsg == "" {
  40. br.IsSendEmail = false
  41. }
  42. this.Data["json"] = br
  43. this.ServeJSON()
  44. }()
  45. sysUser := this.SysUser
  46. if sysUser == nil {
  47. br.Msg = "请登录"
  48. br.ErrMsg = "请登录,SysUser Is Empty"
  49. br.Ret = 408
  50. return
  51. }
  52. pageSize, _ := this.GetInt("PageSize")
  53. currentIndex, _ := this.GetInt("CurrentIndex")
  54. searchParam := this.GetString("SearchParam")
  55. classifyId := this.GetString("ClassifyId")
  56. if pageSize <= 0 {
  57. pageSize = utils.PageSize20
  58. }
  59. if currentIndex <= 0 {
  60. currentIndex = 1
  61. }
  62. // 获取指标列表
  63. indexList, err := data.GetIndexPage(classifyId, searchParam, currentIndex, pageSize)
  64. if err != nil {
  65. br.Msg = "获取指标列表失败"
  66. br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
  67. return
  68. }
  69. br.Data = indexList
  70. br.Ret = 200
  71. br.Success = true
  72. br.Msg = "获取成功"
  73. }
  74. // LyIndexDataList
  75. // @Title 获取指标对应的数据列表
  76. // @Description 获取指标对应的数据列表
  77. // @Param indexId query int true "指标ID"
  78. // @Param PageSize query int true "每页数据条数"
  79. // @Param CurrentIndex query int true "当前页页码,从1开始"
  80. // @Success 200 {object} data_manage.BaseFromLyDataPage
  81. // @router /ly/index/data/list [get]
  82. func (this *BaseFromLyIndexController) LyIndexDataList() {
  83. br := new(models.BaseResponse).Init()
  84. defer func() {
  85. if br.ErrMsg == "" {
  86. br.IsSendEmail = false
  87. }
  88. this.Data["json"] = br
  89. this.ServeJSON()
  90. }()
  91. sysUser := this.SysUser
  92. if sysUser == nil {
  93. br.Msg = "请登录"
  94. br.ErrMsg = "请登录,SysUser Is Empty"
  95. br.Ret = 408
  96. return
  97. }
  98. // 获取指标数据列表
  99. indexId, err := this.GetInt("IndexId")
  100. if err != nil {
  101. br.Msg = "获取指标ID失败"
  102. br.ErrMsg = "获取指标ID失败,Err:" + err.Error()
  103. return
  104. }
  105. pageSize, _ := this.GetInt("PageSize")
  106. currentIndex, _ := this.GetInt("CurrentIndex")
  107. if pageSize <= 0 {
  108. pageSize = utils.PageSize20
  109. }
  110. if currentIndex <= 0 {
  111. currentIndex = 1
  112. }
  113. indexDataList, err := data.GetIndexDataPage(indexId, currentIndex, pageSize)
  114. if err != nil {
  115. br.Msg = "获取指标数据列表失败"
  116. br.ErrMsg = "获取指标数据列表失败,Err:" + err.Error()
  117. return
  118. }
  119. br.Data = indexDataList
  120. br.Ret = 200
  121. br.Success = true
  122. br.Msg = "获取成功"
  123. }
  124. // LyIndexAddValidate
  125. // @Title 新增加入到指标库校验
  126. // @Description 新增加入到指标库校验
  127. // @Param req body data_manage.BaseFromLyIndexBatchAddCheckReq true "请求参数"
  128. // @Success 200 {object} []data_manage.IndexCheckData
  129. // @router /ly/index/add/validate [post]
  130. func (this *BaseFromLyIndexController) LyIndexAddValidate() {
  131. br := new(models.BaseResponse).Init()
  132. defer func() {
  133. if br.ErrMsg == "" {
  134. br.IsSendEmail = false
  135. }
  136. this.Data["json"] = br
  137. this.ServeJSON()
  138. }()
  139. sysUser := this.SysUser
  140. if sysUser == nil {
  141. br.Msg = "请登录"
  142. br.ErrMsg = "请登录,SysUser Is Empty"
  143. br.Ret = 408
  144. return
  145. }
  146. var req *data_manage.BaseFromLyIndexBatchAddCheckReq
  147. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  148. br.Msg = "参数解析异常!"
  149. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  150. return
  151. }
  152. codeLen := len(req.IndexCodes)
  153. if codeLen > codeMax {
  154. br.Msg = "批量添加指标数量不得超过" + strconv.Itoa(codeMax) + "个"
  155. br.ErrMsg = "批量添加指标数量不得超过" + strconv.Itoa(codeMax) + "个"
  156. return
  157. }
  158. // 校验指标编码是否存在
  159. addValidate, err := data.LyIndexAddValidate(req.IndexCodes)
  160. if err != nil {
  161. return
  162. }
  163. br.Data = addValidate
  164. br.Ret = 200
  165. br.Success = true
  166. br.Msg = "操作成功"
  167. }
  168. // LyIndexAdd
  169. // @Title 指标添加到指标库
  170. // @Description 指标添加到指标库
  171. // @Param req body []data_manage.AddEdbInfoReq true "请求参数"
  172. // @Success 200 string "操作成功"
  173. // @router /ly/index/add [post]
  174. func (this *BaseFromLyIndexController) LyIndexAdd() {
  175. br := new(models.BaseResponse).Init()
  176. defer func() {
  177. if br.ErrMsg == "" {
  178. br.IsSendEmail = false
  179. }
  180. this.Data["json"] = br
  181. this.ServeJSON()
  182. }()
  183. sysUser := this.SysUser
  184. if sysUser == nil {
  185. br.Msg = "请登录"
  186. br.ErrMsg = "请登录,SysUser Is Empty"
  187. br.Ret = 408
  188. return
  189. }
  190. deleteCache := true
  191. cacheKey := "CACHE_EDB_INFO_BATCH_ADD_LY_" + strconv.Itoa(sysUser.AdminId)
  192. defer func() {
  193. if deleteCache {
  194. _ = utils.Rc.Delete(cacheKey)
  195. }
  196. }()
  197. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  198. deleteCache = false
  199. br.Msg = "系统处理中,请稍后重试!"
  200. br.ErrMsg = "系统处理中,请稍后重试!" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  201. return
  202. }
  203. var req []*data_manage.AddEdbInfoReq
  204. if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil {
  205. br.Msg = "参数解析异常!"
  206. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  207. return
  208. }
  209. if len(req) == 0 {
  210. br.Msg = "请选择指标"
  211. return
  212. }
  213. if len(req) > codeMax {
  214. br.Msg = "批量添加指标数量不得超过" + strconv.Itoa(codeMax) + "个"
  215. return
  216. }
  217. indexNames := make([]string, 0)
  218. resp := make([]*data_manage.NameCheckResult, 0)
  219. for _, index := range req {
  220. index.EdbCode = strings.TrimSpace(index.EdbCode)
  221. if index.EdbCode == "" {
  222. br.Msg = "指标ID不可为空"
  223. return
  224. }
  225. index.EdbName = strings.TrimSpace(index.EdbName)
  226. if index.EdbName == "" {
  227. br.Msg = "请输入指标名称"
  228. return
  229. }
  230. index.Frequency = strings.TrimSpace(index.Frequency)
  231. if index.Frequency == "" {
  232. br.Msg = "请选择频度"
  233. return
  234. }
  235. index.Unit = strings.TrimSpace(index.Unit)
  236. if index.Unit == "" {
  237. br.Msg = "请输入单位"
  238. return
  239. }
  240. if index.ClassifyId <= 0 {
  241. br.Msg = "请选择分类"
  242. return
  243. }
  244. indexNames = append(indexNames, index.EdbName)
  245. resp = append(resp, &data_manage.NameCheckResult{
  246. IndexCode: index.EdbCode,
  247. IndexName: index.EdbName,
  248. Exist: false,
  249. })
  250. }
  251. // 指标名称重复校验
  252. nameCheck, err := data.LyIndexNameCheck(indexNames, resp)
  253. if err != nil {
  254. br.Msg = err.Error()
  255. br.ErrMsg = err.Error()
  256. return
  257. }
  258. for _, v := range nameCheck {
  259. if v.Exist {
  260. br.Msg = "指标名称重复"
  261. br.Data = nameCheck
  262. br.Ret = 200
  263. br.Success = true
  264. return
  265. }
  266. }
  267. for _, v := range req {
  268. var r data.LyIndexAddReq
  269. r.EdbCode = v.EdbCode
  270. r.EdbName = v.EdbName
  271. r.Frequency = v.Frequency
  272. r.Unit = v.Unit
  273. r.ClassifyId = v.ClassifyId
  274. r.AdminId = sysUser.AdminId
  275. r.AdminRealName = sysUser.RealName
  276. // 新增指标到指标库
  277. edbInfo, e, errMsg, skip := data.LyIndexAdd(r, this.Lang)
  278. if e != nil {
  279. br.Msg = "操作失败"
  280. if errMsg != "" {
  281. br.Msg = errMsg
  282. }
  283. br.ErrMsg = e.Error()
  284. return
  285. }
  286. if skip {
  287. continue
  288. }
  289. // todo 下面两段代码能否抽离出来???
  290. // 试用平台更新用户累计新增指标数
  291. if utils.BusinessCode == utils.BusinessCodeSandbox {
  292. go func() {
  293. adminItem, e := system.GetSysAdminById(sysUser.AdminId)
  294. if e != nil {
  295. tips := fmt.Sprintf("试用平台更新用户累计新增指标数-获取用户失败, Err: " + e.Error())
  296. utils.FileLog.Info(tips)
  297. return
  298. }
  299. if adminItem.DepartmentName != "ETA试用客户" {
  300. return
  301. }
  302. var ur etaTrialService.EtaTrialUserReq
  303. ur.Mobile = adminItem.Mobile
  304. _, _ = etaTrialService.UpdateUserIndexNum(ur)
  305. }()
  306. }
  307. // 新增操作日志
  308. {
  309. edbLog := new(data_manage.EdbInfoLog)
  310. edbLog.EdbInfoId = edbInfo.EdbInfoId
  311. edbLog.SourceName = edbInfo.SourceName
  312. edbLog.Source = edbInfo.Source
  313. edbLog.EdbCode = edbInfo.EdbCode
  314. edbLog.EdbName = edbInfo.EdbName
  315. edbLog.ClassifyId = edbInfo.ClassifyId
  316. edbLog.SysUserId = sysUser.AdminId
  317. edbLog.SysUserRealName = sysUser.RealName
  318. edbLog.CreateTime = time.Now()
  319. edbLog.Content = string(this.Ctx.Input.RequestBody)
  320. edbLog.Status = "新增指标"
  321. edbLog.Method = this.Ctx.Input.URI()
  322. go data_manage.AddEdbInfoLog(edbLog)
  323. }
  324. }
  325. br.Msg = "操作成功"
  326. br.Ret = 200
  327. br.Success = true
  328. br.IsAddLog = true
  329. }
  330. // LyIndexDataExport
  331. // @Title 导出指标数据
  332. // @Description 导出指标数据
  333. // @Param IndexCodes query string true "指标编码"
  334. // @Success 200 string "操作成功"
  335. // @router /ly/index/data/export [get]
  336. func (this *BaseFromLyIndexController) LyIndexDataExport() {
  337. br := new(models.BaseResponse).Init()
  338. defer func() {
  339. this.Data["json"] = br
  340. this.ServeJSON()
  341. }()
  342. sysUser := this.SysUser
  343. if sysUser == nil {
  344. br.Msg = "请重新登录"
  345. return
  346. }
  347. classifyId, _ := this.GetInt("ClassifyId") //分类
  348. indexCode := this.GetString("IndexCode") //指标唯一编码
  349. if classifyId <= 0 {
  350. br.Msg = "请选择分类"
  351. return
  352. }
  353. //userId := sysUser.AdminId
  354. //超管账号可以查看分类下的所有频度数据
  355. /*if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_ADMIN {
  356. userId = 0
  357. }*/
  358. //获取账户所拥有权限的分类id集合
  359. /*classifyIdStrList, err := data.GetEdbClassifyListByAdminId(int64(userId))
  360. if err != nil {
  361. br.Msg = "获取分类数据失败"
  362. return
  363. }*/
  364. dir, _ := os.Executable()
  365. exPath := filepath.Dir(dir)
  366. downLoadFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  367. xlsxFile := xlsx.NewFile()
  368. frequencies, err := data_manage.GetLyIndexFrequency(classifyId)
  369. if err != nil {
  370. br.Msg = "查询频度失败"
  371. br.ErrMsg = "查询频度失败"
  372. return
  373. }
  374. fileName := `粮油商务网`
  375. if classifyId >= 0 && indexCode == "" {
  376. lyClassify, err := data_manage.GetLyClassifyById(classifyId)
  377. if err != nil {
  378. return
  379. }
  380. fileName = lyClassify.ClassifyName
  381. }
  382. if frequencies == nil {
  383. sheet, err := xlsxFile.AddSheet("无数据")
  384. if err != nil {
  385. br.Msg = "新增Sheet失败"
  386. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  387. return
  388. }
  389. rowSecName := sheet.AddRow()
  390. celSecName := rowSecName.AddCell()
  391. celSecName.SetValue("")
  392. }
  393. for _, frequency := range frequencies {
  394. lyIndices, err := data_manage.GetLyIndexByCodeAndClassify(indexCode, classifyId, frequency)
  395. if err != nil {
  396. return
  397. }
  398. if indexCode != "" {
  399. fileName = lyIndices[0].IndexName
  400. }
  401. var sheet *xlsx.Sheet
  402. if len(lyIndices) > 0 {
  403. sheet, err = xlsxFile.AddSheet(*frequency)
  404. if err != nil {
  405. br.Msg = "新增Sheet失败"
  406. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  407. return
  408. }
  409. } else {
  410. continue
  411. }
  412. //获取指标数据
  413. rowSecName := sheet.AddRow()
  414. celSecName := rowSecName.AddCell()
  415. celSecName.SetValue("指标名称")
  416. rowFrequency := sheet.AddRow()
  417. celFrequency := rowFrequency.AddCell()
  418. celFrequency.SetValue("频率")
  419. rowUnit := sheet.AddRow()
  420. celUnit := rowUnit.AddCell()
  421. celUnit.SetValue("单位")
  422. rowModifyDate := sheet.AddRow()
  423. rowModifyCell := rowModifyDate.AddCell()
  424. rowModifyCell.SetValue("更新时间")
  425. dataMap := make(map[string]map[string]*data_manage.BaseFromLyData)
  426. var tradeCodeList []string
  427. for _, v := range lyIndices {
  428. cellSenName := rowSecName.AddCell()
  429. cellSenName.SetValue(v.IndexName)
  430. celFrequency := rowFrequency.AddCell()
  431. celFrequency.SetValue(v.Frequency)
  432. celUnit := rowUnit.AddCell()
  433. celUnit.SetValue(v.Unit)
  434. rowModifyCell := rowModifyDate.AddCell()
  435. rowModifyCell.SetValue(v.ModifyTime)
  436. tradeCodeList = append(tradeCodeList, v.IndexCode)
  437. var lyDataList []*data_manage.BaseFromLyData
  438. lyDataList, err = data_manage.GetBaseFromLyDataByIndexCode(v.IndexCode)
  439. if err != nil && err.Error() != utils.ErrNoRow() {
  440. br.ErrMsg = "GetBaseFromLyDataByIndexCode,Err:" + err.Error()
  441. br.Msg = "获取数据失败"
  442. return
  443. }
  444. for _, item := range lyDataList {
  445. if dataMap[item.IndexCode] == nil {
  446. dataMap[item.IndexCode] = make(map[string]*data_manage.BaseFromLyData)
  447. }
  448. dataMap[item.IndexCode][item.DataTime] = item
  449. }
  450. }
  451. tradeCodeStr := strings.Join(tradeCodeList, "','")
  452. tradeCodeStr = "'" + tradeCodeStr + "'"
  453. dataTimeList, err := data_manage.GetLyDataListByIndexCodes(tradeCodeStr)
  454. if err != nil {
  455. br.Msg = "获取数据失败"
  456. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  457. return
  458. }
  459. for _, dataTime := range dataTimeList {
  460. rowData := sheet.AddRow()
  461. celDate := rowData.AddCell()
  462. celDate.SetValue(dataTime)
  463. for _, m := range lyIndices {
  464. celData := rowData.AddCell()
  465. if dataMap[m.IndexCode][dataTime] != nil {
  466. celData.SetValue(dataMap[m.IndexCode][dataTime].Value)
  467. }
  468. }
  469. }
  470. }
  471. err = xlsxFile.Save(downLoadFilePath)
  472. if err != nil {
  473. //有指标无数据时先导出一遍空表
  474. sheet, err := xlsxFile.AddSheet("无数据")
  475. if err != nil {
  476. br.Msg = "新增Sheet失败"
  477. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  478. return
  479. }
  480. rowSecName := sheet.AddRow()
  481. celSecName := rowSecName.AddCell()
  482. celSecName.SetValue("")
  483. err = xlsxFile.Save(downLoadFilePath)
  484. if err != nil {
  485. br.Msg = "保存文件失败"
  486. br.ErrMsg = "保存文件失败"
  487. return
  488. }
  489. }
  490. fileName += time.Now().Format("06.01.02") + `.xlsx` //文件名称
  491. this.Ctx.Output.Download(downLoadFilePath, fileName)
  492. defer func() {
  493. os.Remove(downLoadFilePath)
  494. }()
  495. br.Ret = 200
  496. br.Success = true
  497. br.Msg = "success"
  498. }