base_from_ly_index_controller.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537
  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 IndexCode query string false "指标编码"
  334. // @Param ClassifyId query int false "分类ID"
  335. // @Success 200 string "操作成功"
  336. // @router /ly/index/data/export [get]
  337. func (this *BaseFromLyIndexController) LyIndexDataExport() {
  338. br := new(models.BaseResponse).Init()
  339. defer func() {
  340. this.Data["json"] = br
  341. this.ServeJSON()
  342. }()
  343. sysUser := this.SysUser
  344. if sysUser == nil {
  345. br.Msg = "请重新登录"
  346. return
  347. }
  348. classifyId, _ := this.GetInt("ClassifyId") //分类
  349. indexCode := this.GetString("IndexCode") //指标唯一编码
  350. //userId := sysUser.AdminId
  351. //超管账号可以查看分类下的所有频度数据
  352. /*if sysUser.RoleTypeCode == utils.ROLE_TYPE_CODE_ADMIN {
  353. userId = 0
  354. }*/
  355. //获取账户所拥有权限的分类id集合
  356. /*classifyIdStrList, err := data.GetEdbClassifyListByAdminId(int64(userId))
  357. if err != nil {
  358. br.Msg = "获取分类数据失败"
  359. return
  360. }*/
  361. dir, _ := os.Executable()
  362. exPath := filepath.Dir(dir)
  363. downLoadFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  364. xlsxFile := xlsx.NewFile()
  365. frequencies, err := data_manage.GetLyIndexFrequency(classifyId)
  366. if err != nil {
  367. br.Msg = "查询频度失败"
  368. br.ErrMsg = "查询频度失败"
  369. return
  370. }
  371. fileName := `粮油商务网`
  372. if classifyId > 0 && indexCode == "" {
  373. lyClassify, err := data_manage.GetLyClassifyById(classifyId)
  374. if err != nil {
  375. return
  376. }
  377. fileName = lyClassify.ClassifyName
  378. }
  379. if frequencies == nil {
  380. sheet, err := xlsxFile.AddSheet("无数据")
  381. if err != nil {
  382. br.Msg = "新增Sheet失败"
  383. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  384. return
  385. }
  386. rowSecName := sheet.AddRow()
  387. celSecName := rowSecName.AddCell()
  388. celSecName.SetValue("")
  389. }
  390. for _, frequency := range frequencies {
  391. lyIndices, err := data_manage.GetLyIndexByCodeAndClassify(indexCode, classifyId, frequency)
  392. if err != nil {
  393. return
  394. }
  395. var sheet *xlsx.Sheet
  396. if len(lyIndices) > 0 {
  397. sheet, err = xlsxFile.AddSheet(*frequency)
  398. if err != nil {
  399. br.Msg = "新增Sheet失败"
  400. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  401. return
  402. }
  403. } else {
  404. continue
  405. }
  406. if indexCode != "" {
  407. fileName = lyIndices[0].IndexName
  408. }
  409. //获取指标数据
  410. rowSecName := sheet.AddRow()
  411. celSecName := rowSecName.AddCell()
  412. celSecName.SetValue("指标名称")
  413. rowFrequency := sheet.AddRow()
  414. celFrequency := rowFrequency.AddCell()
  415. celFrequency.SetValue("频率")
  416. rowUnit := sheet.AddRow()
  417. celUnit := rowUnit.AddCell()
  418. celUnit.SetValue("单位")
  419. rowModifyDate := sheet.AddRow()
  420. rowModifyCell := rowModifyDate.AddCell()
  421. rowModifyCell.SetValue("更新时间")
  422. dataMap := make(map[string]map[string]*data_manage.BaseFromLyData)
  423. var tradeCodeList []string
  424. for _, v := range lyIndices {
  425. cellSenName := rowSecName.AddCell()
  426. cellSenName.SetValue(v.IndexName)
  427. celFrequency := rowFrequency.AddCell()
  428. celFrequency.SetValue(v.Frequency)
  429. celUnit := rowUnit.AddCell()
  430. celUnit.SetValue(v.Unit)
  431. rowModifyCell := rowModifyDate.AddCell()
  432. rowModifyCell.SetValue(v.ModifyTime)
  433. tradeCodeList = append(tradeCodeList, v.IndexCode)
  434. var lyDataList []*data_manage.BaseFromLyData
  435. lyDataList, err = data_manage.GetBaseFromLyDataByIndexCode(v.IndexCode)
  436. if err != nil && err.Error() != utils.ErrNoRow() {
  437. br.ErrMsg = "GetBaseFromLyDataByIndexCode,Err:" + err.Error()
  438. br.Msg = "获取数据失败"
  439. return
  440. }
  441. for _, item := range lyDataList {
  442. if dataMap[item.IndexCode] == nil {
  443. dataMap[item.IndexCode] = make(map[string]*data_manage.BaseFromLyData)
  444. }
  445. dataMap[item.IndexCode][item.DataTime] = item
  446. }
  447. }
  448. tradeCodeStr := strings.Join(tradeCodeList, "','")
  449. tradeCodeStr = "'" + tradeCodeStr + "'"
  450. dataTimeList, err := data_manage.GetLyDataListByIndexCodes(tradeCodeStr)
  451. if err != nil {
  452. br.Msg = "获取数据失败"
  453. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  454. return
  455. }
  456. for _, dataTime := range dataTimeList {
  457. rowData := sheet.AddRow()
  458. celDate := rowData.AddCell()
  459. celDate.SetValue(dataTime)
  460. for _, m := range lyIndices {
  461. celData := rowData.AddCell()
  462. if dataMap[m.IndexCode][dataTime] != nil {
  463. celData.SetValue(dataMap[m.IndexCode][dataTime].Value)
  464. }
  465. }
  466. }
  467. }
  468. err = xlsxFile.Save(downLoadFilePath)
  469. if err != nil {
  470. //有指标无数据时先导出一遍空表
  471. sheet, err := xlsxFile.AddSheet("无数据")
  472. if err != nil {
  473. br.Msg = "新增Sheet失败"
  474. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  475. return
  476. }
  477. rowSecName := sheet.AddRow()
  478. celSecName := rowSecName.AddCell()
  479. celSecName.SetValue("")
  480. err = xlsxFile.Save(downLoadFilePath)
  481. if err != nil {
  482. br.Msg = "保存文件失败"
  483. br.ErrMsg = "保存文件失败"
  484. return
  485. }
  486. }
  487. fileName += time.Now().Format("06.01.02") + `.xlsx` //文件名称
  488. this.Ctx.Output.Download(downLoadFilePath, fileName)
  489. defer func() {
  490. os.Remove(downLoadFilePath)
  491. }()
  492. br.Ret = 200
  493. br.Success = true
  494. br.Msg = "success"
  495. }