base_from_mysteel_chemical.go 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_index_lib/logic"
  5. "eta/eta_index_lib/models"
  6. "eta/eta_index_lib/services"
  7. "eta/eta_index_lib/utils"
  8. "fmt"
  9. "strconv"
  10. "time"
  11. )
  12. // MySteelChemicalController 钢联化工
  13. type MySteelChemicalController struct {
  14. BaseAuthController
  15. }
  16. // Add
  17. // @Title 新增钢联化工指标接口
  18. // @Description 新增钢联化工指标接口
  19. // @Success 200 {object} models.AddEdbInfoReq
  20. // @router /add [post]
  21. func (this *MySteelChemicalController) Add() {
  22. br := new(models.BaseResponse).Init()
  23. var cacheKey string
  24. defer func() {
  25. utils.Rc.Delete(cacheKey)
  26. this.Data["json"] = br
  27. this.ServeJSON()
  28. }()
  29. source := utils.DATA_SOURCE_MYSTEEL_CHEMICAL
  30. var req models.AddEdbInfoReq
  31. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  32. if err != nil {
  33. br.Msg = "参数解析异常!"
  34. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  35. return
  36. }
  37. if req.EdbCode == "" {
  38. br.Msg = "请输入指标编码!"
  39. br.ErrMsg = "请输入指标编码,指标编码为空"
  40. return
  41. }
  42. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  43. if !utils.Rc.IsExist(cacheKey) {
  44. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  45. err = models.AddEdbDataFromMysteelChemical(req.EdbCode)
  46. if err != nil {
  47. br.Msg = "获取指标信息失败!"
  48. br.ErrMsg = "获取指标信息失败 AddEdbDataFromMysteelChemical,Err:" + err.Error()
  49. return
  50. }
  51. br.Ret = 200
  52. br.Success = true
  53. br.Msg = "获取成功"
  54. } else {
  55. br.Ret = 501
  56. br.Success = true
  57. br.Msg = "系统处理中,请稍后重试"
  58. }
  59. }
  60. // Refresh
  61. // @Title 刷新钢联化工指标接口
  62. // @Description 刷新钢联化工指标接口
  63. // @Success 200 {object} models.RefreshEdbInfoReq
  64. // @router /refresh [post]
  65. func (this *MySteelChemicalController) Refresh() {
  66. br := new(models.BaseResponse).Init()
  67. var cacheKey string
  68. defer func() {
  69. utils.Rc.Delete(cacheKey)
  70. this.Data["json"] = br
  71. this.ServeJSON()
  72. }()
  73. source := utils.DATA_SOURCE_MYSTEEL_CHEMICAL
  74. var req models.RefreshEdbInfoReq
  75. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  76. if err != nil {
  77. br.Msg = "参数解析异常!"
  78. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  79. return
  80. }
  81. if req.EdbCode == "" {
  82. br.Msg = "请输入指标编码!"
  83. br.ErrMsg = "请输入指标编码,指标编码为空"
  84. return
  85. }
  86. if req.EdbInfoId <= 0 {
  87. br.Msg = "请输入指标ID!"
  88. br.ErrMsg = "请输入指标ID"
  89. return
  90. }
  91. // 获取指标详情
  92. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  93. if err != nil {
  94. br.Msg = "指标不存在!"
  95. br.ErrMsg = "指标不存在"
  96. return
  97. }
  98. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  99. if utils.Rc.IsExist(cacheKey) {
  100. br.Ret = 501
  101. br.Success = true
  102. br.Msg = "系统处理中,请稍后重试"
  103. return
  104. }
  105. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  106. err = models.RefreshEdbDataFromMysteelChemical(req.EdbInfoId, req.EdbCode, req.StartDate)
  107. if err != nil && err.Error() != utils.ErrNoRow() {
  108. br.Msg = "刷新指标信息失败!"
  109. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromMysteel,Err:" + err.Error()
  110. return
  111. }
  112. // 更新指标最大最小值
  113. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  114. if err != nil {
  115. br.Msg = errMsg
  116. br.ErrMsg = err.Error()
  117. return
  118. }
  119. // 更新ES
  120. go logic.UpdateEs(edbInfo.EdbInfoId)
  121. br.Ret = 200
  122. br.Success = true
  123. br.Msg = "获取成功"
  124. }
  125. // @Title 查询刷新钢联指标的接口
  126. // @Description 查询刷新钢联指标的接口
  127. // @Success 200 {object} models.CheckDeleteClassifyResp
  128. // @router /query/refresh [post]
  129. func (this *MySteelChemicalController) QueryRefresh() {
  130. br := new(models.BaseResponse).Init()
  131. defer func() {
  132. this.Data["json"] = br
  133. this.ServeJSON()
  134. }()
  135. mysteelIndex := new(models.BaseFromMysteelChemicalIndex)
  136. list, err := mysteelIndex.GetIndexRefreshAllByMergeFile()
  137. if err != nil && err.Error() != utils.ErrNoRow() {
  138. br.Msg = "获取失败!"
  139. br.ErrMsg = "获取失败,Err:" + err.Error()
  140. return
  141. }
  142. if list == nil {
  143. list = make([]*models.BaseFromMysteelChemicalIndex, 0)
  144. }
  145. br.Ret = 200
  146. br.Data = list
  147. br.Success = true
  148. br.Msg = "获取成功"
  149. }
  150. // @Title 处理钢联指标的接口
  151. // @Description 处理钢联指标的接口
  152. // @Success 200 {object} models.HandleMysteelIndexResp
  153. // @router /handle/mysteel/index [post]
  154. func (this *MySteelChemicalController) HandleMysteelIndex() {
  155. br := new(models.BaseResponse).Init()
  156. defer func() {
  157. this.Data["json"] = br
  158. this.ServeJSON()
  159. }()
  160. body := this.Ctx.Input.RequestBody
  161. var req models.HandleMysteelIndexResp
  162. err := json.Unmarshal(body, &req)
  163. if err != nil {
  164. br.Msg = "参数解析异常!"
  165. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  166. return
  167. }
  168. err = services.HandleMysteelIndex(&req)
  169. if err != nil {
  170. fmt.Println("HandleMysteelIndex Err:" + err.Error())
  171. br.Msg = "处理失败"
  172. br.ErrMsg = "处理失败,Err:" + err.Error()
  173. return
  174. }
  175. br.Ret = 200
  176. br.Success = true
  177. br.Msg = "处理成功"
  178. }
  179. // GetMaxFileIndex
  180. // @Title 获取最大的文件编号下标
  181. // @Description 获取最大的文件编号下标
  182. // @Success 200 {object} models.HandleMysteelIndexResp
  183. // @router /getMaxFileIndex [post]
  184. func (this *MySteelChemicalController) GetMaxFileIndex() {
  185. br := new(models.BaseResponse).Init()
  186. defer func() {
  187. this.Data["json"] = br
  188. this.ServeJSON()
  189. }()
  190. var req models.GetMaxFileIndexReq
  191. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  192. if err != nil {
  193. br.Msg = "参数解析异常!"
  194. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  195. return
  196. }
  197. indexObj := new(models.BaseFromMysteelChemicalIndex)
  198. // 获取最大的文件编号下标
  199. item, err := indexObj.GetMaxFileIndex(req.Frequency)
  200. if err != nil {
  201. return
  202. }
  203. br.Data = item
  204. br.Ret = 200
  205. br.Success = true
  206. br.Msg = "处理成功"
  207. }
  208. // GetNoMergeIndexByFrequencyCount
  209. // @Title 获取未合并的指标总数量
  210. // @Description 获取未合并的指标总数量
  211. // @Success 200 {object} models.HandleMysteelIndexResp
  212. // @router /getNoMergeIndexByFrequencyCount [post]
  213. func (this *MySteelChemicalController) GetNoMergeIndexByFrequencyCount() {
  214. br := new(models.BaseResponse).Init()
  215. defer func() {
  216. this.Data["json"] = br
  217. this.ServeJSON()
  218. }()
  219. var req models.GetMaxFileIndexReq
  220. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  221. if err != nil {
  222. br.Msg = "参数解析异常!"
  223. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  224. return
  225. }
  226. indexObj := new(models.BaseFromMysteelChemicalIndex)
  227. // 获取未合并的指标总数量
  228. indexTotal, err := indexObj.GetNoMergeIndexByFrequencyCount(req.Frequency)
  229. if err != nil {
  230. return
  231. }
  232. br.Data = indexTotal
  233. br.Ret = 200
  234. br.Success = true
  235. br.Msg = "处理成功"
  236. }
  237. // GetNoMergeIndexByFrequencyPage
  238. // @Title 获取未合并的指标列表
  239. // @Description 获取未合并的指标列表
  240. // @Success 200 {object} models.HandleMysteelIndexResp
  241. // @router /getNoMergeIndexByFrequencyPage [post]
  242. func (this *MySteelChemicalController) GetNoMergeIndexByFrequencyPage() {
  243. br := new(models.BaseResponse).Init()
  244. defer func() {
  245. this.Data["json"] = br
  246. this.ServeJSON()
  247. }()
  248. var req models.GetNoMergeIndexByFrequencyPageReq
  249. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  250. if err != nil {
  251. br.Msg = "参数解析异常!"
  252. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  253. return
  254. }
  255. indexObj := new(models.BaseFromMysteelChemicalIndex)
  256. // 获取未合并的指标总数量
  257. indexTotal, err := indexObj.GetNoMergeIndexByFrequencyPage(req.Frequency, req.Limit)
  258. if err != nil {
  259. return
  260. }
  261. br.Data = indexTotal
  262. br.Ret = 200
  263. br.Success = true
  264. br.Msg = "处理成功"
  265. }
  266. // GetIndexCountByMergeFilePath
  267. // @Title 获取该文件下标已经存在多少的指标
  268. // @Description 获取该文件下标已经存在多少的指标
  269. // @Success 200 {object} models.HandleMysteelIndexResp
  270. // @router /getIndexCountByMergeFilePath [post]
  271. func (this *MySteelChemicalController) GetIndexCountByMergeFilePath() {
  272. br := new(models.BaseResponse).Init()
  273. defer func() {
  274. this.Data["json"] = br
  275. this.ServeJSON()
  276. }()
  277. var req models.GetIndexCountByMergeFilePathReq
  278. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  279. if err != nil {
  280. br.Msg = "参数解析异常!"
  281. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  282. return
  283. }
  284. if req.MergeFilePath == "" {
  285. br.Msg = "参数有误"
  286. br.ErrMsg = "参数有误, 文件路径有误"
  287. return
  288. }
  289. indexObj := new(models.BaseFromMysteelChemicalIndex)
  290. indexTotal, err := indexObj.GetIndexCountByMergeFilePath(req.MergeFilePath)
  291. if err != nil {
  292. return
  293. }
  294. br.Data = indexTotal
  295. br.Ret = 200
  296. br.Success = true
  297. br.Msg = "获取成功"
  298. }
  299. // GetIndexCreate
  300. // @Title 获取两分钟前新增的指标
  301. // @Description 获取两分钟前新增的指标
  302. // @Success 200 {object} models.BaseFromMysteelChemicalIndex
  303. // @router /getIndexCreate [post]
  304. func (this *MySteelChemicalController) GetIndexCreate() {
  305. br := new(models.BaseResponse).Init()
  306. defer func() {
  307. this.Data["json"] = br
  308. this.ServeJSON()
  309. }()
  310. // 终端编码
  311. terminalCode := this.GetString("TerminalCode")
  312. indexObj := new(models.BaseFromMysteelChemicalIndex)
  313. items, err := indexObj.GetIndexCreate(terminalCode)
  314. if err != nil {
  315. br.Msg = "获取失败"
  316. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  317. return
  318. }
  319. if items == nil {
  320. items = make([]*models.BaseFromMysteelChemicalIndex, 0)
  321. }
  322. br.Data = items
  323. br.Ret = 200
  324. br.Success = true
  325. br.Msg = "获取成功"
  326. }
  327. // GetIndexRefreshMethanolByMergeFile
  328. // @Title 获取需要刷新的甲醇文件
  329. // @Description 获取需要刷新的甲醇文件
  330. // @Success 200 {object} models.BaseFromMysteelChemicalIndex
  331. // @router /getIndexRefreshMethanolByMergeFile [post]
  332. func (this *MySteelChemicalController) GetIndexRefreshMethanolByMergeFile() {
  333. br := new(models.BaseResponse).Init()
  334. defer func() {
  335. this.Data["json"] = br
  336. this.ServeJSON()
  337. }()
  338. indexObj := new(models.BaseFromMysteelChemicalIndex)
  339. items, err := indexObj.GetIndexRefreshMethanolByMergeFile()
  340. if err != nil {
  341. br.Msg = "获取失败"
  342. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  343. return
  344. }
  345. if items == nil {
  346. items = make([]*models.BaseFromMysteelChemicalIndex, 0)
  347. }
  348. br.Data = items
  349. br.Ret = 200
  350. br.Success = true
  351. br.Msg = "获取成功"
  352. }
  353. // GetIndexRefreshMethanolByTimely
  354. // @Title 获取需要及时刷新的文件
  355. // @Description 获取需要及时刷新的文件
  356. // @Success 200 {object} models.BaseFromMysteelChemicalIndex
  357. // @router /getIndexRefreshMethanolByTimely [post]
  358. func (this *MySteelChemicalController) GetIndexRefreshMethanolByTimely() {
  359. br := new(models.BaseResponse).Init()
  360. defer func() {
  361. this.Data["json"] = br
  362. this.ServeJSON()
  363. }()
  364. indexObj := new(models.BaseFromMysteelChemicalIndex)
  365. items, err := indexObj.GetIndexRefreshMethanolByTimely()
  366. if err != nil {
  367. br.Msg = "获取失败"
  368. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  369. return
  370. }
  371. if items == nil {
  372. items = make([]*models.BaseFromMysteelChemicalIndex, 0)
  373. }
  374. br.Data = items
  375. br.Ret = 200
  376. br.Success = true
  377. br.Msg = "获取成功"
  378. }
  379. // GetIndexByFrequency
  380. // @Title 根据频率获取指标
  381. // @Description 根据频率获取指标
  382. // @Success 200 {object} models.BaseFromMysteelChemicalIndex
  383. // @router /getIndexByFrequency [post]
  384. func (this *MySteelChemicalController) GetIndexByFrequency() {
  385. br := new(models.BaseResponse).Init()
  386. defer func() {
  387. this.Data["json"] = br
  388. this.ServeJSON()
  389. }()
  390. var req models.GetIndexByFrequencyReq
  391. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  392. if err != nil {
  393. br.Msg = "参数解析异常!"
  394. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  395. return
  396. }
  397. if req.Frequency == "" {
  398. br.Msg = "参数有误"
  399. br.ErrMsg = "参数有误"
  400. return
  401. }
  402. indexObj := new(models.BaseFromMysteelChemicalIndex)
  403. items, err := indexObj.GetIndexByFrequency(req.Frequency)
  404. if err != nil {
  405. br.Msg = "获取失败"
  406. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  407. return
  408. }
  409. if items == nil {
  410. items = make([]*models.BaseFromMysteelChemicalIndex, 0)
  411. }
  412. br.Data = items
  413. br.Ret = 200
  414. br.Success = true
  415. br.Msg = "获取成功"
  416. }
  417. // GetIndexRefreshWeek
  418. // @Title 根据周获取指标
  419. // @Description 根据周获取指标
  420. // @Success 200 {object} models.BaseFromMysteelChemicalIndex
  421. // @router /getIndexRefreshWeek [post]
  422. func (this *MySteelChemicalController) GetIndexRefreshWeek() {
  423. br := new(models.BaseResponse).Init()
  424. defer func() {
  425. this.Data["json"] = br
  426. this.ServeJSON()
  427. }()
  428. var req models.GetIndexRefreshWeekReq
  429. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  430. if err != nil {
  431. br.Msg = "参数解析异常!"
  432. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  433. return
  434. }
  435. if req.NowWeekZn == "" || req.StartTime == "" || req.EndTime == "" {
  436. br.Msg = "参数有误"
  437. br.ErrMsg = "参数有误"
  438. return
  439. }
  440. indexObj := new(models.BaseFromMysteelChemicalIndex)
  441. items, err := indexObj.GetIndexRefreshWeek(req.NowWeekZn, req.StartTime, req.EndTime)
  442. if err != nil {
  443. br.Msg = "获取失败"
  444. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  445. return
  446. }
  447. if items == nil {
  448. items = make([]*models.BaseFromMysteelChemicalIndex, 0)
  449. }
  450. br.Data = items
  451. br.Ret = 200
  452. br.Success = true
  453. br.Msg = "获取成功"
  454. }
  455. // UpdateIndex
  456. // @Title 更新指标
  457. // @Description 更新指标
  458. // @Success 200 string "操作成功"
  459. // @router /updateIndex [post]
  460. //func (this *MySteelChemicalController) UpdateIndex() {
  461. // br := new(models.BaseResponse).Init()
  462. // defer func() {
  463. // this.Data["json"] = br
  464. // this.ServeJSON()
  465. // }()
  466. // var req models.UpdateIndexReq
  467. // err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  468. // if err != nil {
  469. // br.Msg = "参数解析异常!"
  470. // br.ErrMsg = "参数解析失败,Err:" + err.Error()
  471. // return
  472. // }
  473. // if req.Item == nil {
  474. // br.Msg = "参数有误"
  475. // br.ErrMsg = "参数有误, 指标信息有误"
  476. // return
  477. // }
  478. // if len(req.UpdateCols) == 0 {
  479. // br.Msg = "参数有误"
  480. // br.ErrMsg = "参数有误, 无更新字段"
  481. // return
  482. // }
  483. //
  484. // // 更新指标
  485. // indexObj := new(models.BaseFromMysteelChemicalIndex)
  486. // err = indexObj.UpdateIndex(req.Item, req.UpdateCols)
  487. // if err != nil {
  488. // br.Msg = "操作失败"
  489. // br.ErrMsg = "批量更新指标失败, MultiUpdateIndexByIndexCode err: " + err.Error()
  490. // return
  491. // }
  492. //
  493. // br.Ret = 200
  494. // br.Success = true
  495. // br.Msg = "操作成功"
  496. //}
  497. // MultiUpdateIndex
  498. // @Title 批量更新指标
  499. // @Description 批量更新指标
  500. // @Success 200 string "操作成功"
  501. // @router /multiUpdateIndex [post]
  502. func (this *MySteelChemicalController) MultiUpdateIndex() {
  503. br := new(models.BaseResponse).Init()
  504. defer func() {
  505. this.Data["json"] = br
  506. this.ServeJSON()
  507. }()
  508. var req []models.UpdateIndexReq
  509. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  510. if err != nil {
  511. br.Msg = "参数解析异常!"
  512. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  513. return
  514. }
  515. if len(req) == 0 {
  516. br.Msg = "参数有误"
  517. br.ErrMsg = "参数有误, 无指标需要更新"
  518. return
  519. }
  520. // 批量更新指标
  521. indexObj := new(models.BaseFromMysteelChemicalIndex)
  522. err = indexObj.MultiUpdateIndex(req)
  523. if err != nil {
  524. br.Msg = "操作失败"
  525. br.ErrMsg = "批量更新指标失败, MultiUpdateIndex err: " + err.Error()
  526. return
  527. }
  528. br.Ret = 200
  529. br.Success = true
  530. br.Msg = "操作成功"
  531. }
  532. // AddMysteelIndex
  533. // @Title 处理钢联指标的接口
  534. // @Description 处理钢联指标的接口
  535. // @Success 200 {object} models.AddMysteelIndexResp
  536. // @router /add/mysteel/index [post]
  537. func (this *MySteelChemicalController) AddMysteelIndex() {
  538. br := new(models.BaseResponse).Init()
  539. defer func() {
  540. this.Data["json"] = br
  541. this.ServeJSON()
  542. }()
  543. var req models.AddMysteelIndexResp
  544. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  545. if err != nil {
  546. br.Msg = "参数解析异常!"
  547. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  548. return
  549. }
  550. mysteelIndexObj := new(models.BaseFromMysteelChemicalIndex)
  551. indexItem, err := mysteelIndexObj.GetIndexItem(req.EdbCode)
  552. var isAdd bool
  553. if err != nil {
  554. if err.Error() == utils.ErrNoRow() {
  555. isAdd = true
  556. } else {
  557. br.Msg = "判断指标是否存在失败"
  558. br.ErrMsg = "判断指标是否存在失败,Err:" + err.Error()
  559. return
  560. }
  561. }
  562. if indexItem == nil {
  563. isAdd = true
  564. }
  565. if isAdd {
  566. mysteelIndexObj.IndexCode = req.EdbCode
  567. mysteelIndexObj.BaseFromMysteelChemicalClassifyId = req.BaseFromMysteelChemicalClassifyId
  568. mysteelIndexObj.SysUserId = req.SysUserId
  569. mysteelIndexObj.SysUserRealName = req.SysUserRealName
  570. mysteelIndexObj.CreateTime = time.Now()
  571. mysteelIndexObj.ModifyTime = time.Now()
  572. err = mysteelIndexObj.Add()
  573. if err != nil {
  574. br.Msg = "新增指标失败"
  575. br.ErrMsg = "新增指标失败,Err:" + err.Error()
  576. return
  577. }
  578. }
  579. br.Ret = 200
  580. br.Success = true
  581. br.Msg = "新增成功"
  582. }
  583. // GetIndexDetailByCode
  584. // @Title 获取指标详情
  585. // @Description 获取指标详情
  586. // @Success 200 {object} models.GetIndexDetailReq
  587. // @router /index_detail [post]
  588. func (this *MySteelChemicalController) GetIndexDetailByCode() {
  589. br := new(models.BaseResponse).Init()
  590. defer func() {
  591. this.Data["json"] = br
  592. this.ServeJSON()
  593. }()
  594. var req models.GetIndexDetailReq
  595. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  596. if err != nil {
  597. br.Msg = "参数解析异常!"
  598. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  599. return
  600. }
  601. if req.IndexCode == "" {
  602. br.Msg = "参数有误"
  603. br.ErrMsg = "参数有误"
  604. return
  605. }
  606. indexObj := new(models.BaseFromMysteelChemicalIndex)
  607. item, err := indexObj.GetIndexItem(req.IndexCode)
  608. if err != nil {
  609. br.Msg = "获取失败"
  610. br.ErrMsg = "获取指标失败, Err: " + err.Error()
  611. return
  612. }
  613. br.Data = item
  614. br.Ret = 200
  615. br.Success = true
  616. br.Msg = "获取成功"
  617. }
  618. // GetIndexCountByFrequency
  619. // @Title 根据频度获取指标总数量
  620. // @Description 根据频度获取指标总数量
  621. // @Success 200 {object} models.HandleMysteelIndexResp
  622. // @router /getIndexCountByFrequency [post]
  623. func (this *MySteelChemicalController) GetIndexCountByFrequency() {
  624. br := new(models.BaseResponse).Init()
  625. defer func() {
  626. this.Data["json"] = br
  627. this.ServeJSON()
  628. }()
  629. var req models.GetMaxFileIndexReq
  630. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  631. if err != nil {
  632. br.Msg = "参数解析异常!"
  633. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  634. return
  635. }
  636. var condition string
  637. var pars []interface{}
  638. if req.Frequency != "" {
  639. condition += ` AND frequency = ? `
  640. pars = append(pars, req.Frequency)
  641. }
  642. if req.EndDate != "" {
  643. condition += ` AND end_date < ? `
  644. pars = append(pars, req.EndDate)
  645. }
  646. // 终端编码
  647. condition += ` AND terminal_code = ? `
  648. pars = append(pars, req.TerminalCode)
  649. condition += ` AND is_stop = 0 `
  650. indexObj := new(models.BaseFromMysteelChemicalIndex)
  651. // 获取未合并的指标总数量
  652. indexTotal, err := indexObj.GetIndexCountByFrequency(condition, pars)
  653. if err != nil {
  654. return
  655. }
  656. br.Data = indexTotal
  657. br.Ret = 200
  658. br.Success = true
  659. br.Msg = "处理成功"
  660. }
  661. // GetIndexLimitByFrequency
  662. // @Title 获取未合并的指标列表
  663. // @Description 获取未合并的指标列表
  664. // @Success 200 {object} models.HandleMysteelIndexResp
  665. // @router /getIndexLimitByFrequency [post]
  666. func (this *MySteelChemicalController) GetIndexLimitByFrequency() {
  667. br := new(models.BaseResponse).Init()
  668. defer func() {
  669. this.Data["json"] = br
  670. this.ServeJSON()
  671. }()
  672. var req models.GetNoMergeIndexByFrequencyPageReq
  673. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  674. if err != nil {
  675. br.Msg = "参数解析异常!"
  676. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  677. return
  678. }
  679. indexObj := new(models.BaseFromMysteelChemicalIndex)
  680. // 获取未合并的指标总数量
  681. indexTotal, err := indexObj.GetIndexLimitByFrequency(req.Frequency, req.Limit)
  682. if err != nil {
  683. return
  684. }
  685. br.Data = indexTotal
  686. br.Ret = 200
  687. br.Success = true
  688. br.Msg = "处理成功"
  689. }
  690. // GetIndexPageByFrequency
  691. // @Title 获取钢联指标分页数据
  692. // @Description 获取钢联指标分页数据
  693. // @Success 200 {object} models.HandleMysteelIndexResp
  694. // @router /getIndexPageByFrequency [post]
  695. func (this *MySteelChemicalController) GetIndexPageByFrequency() {
  696. br := new(models.BaseResponse).Init()
  697. defer func() {
  698. this.Data["json"] = br
  699. this.ServeJSON()
  700. }()
  701. var req models.GetIndexPageByFrequencyPageReq
  702. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  703. if err != nil {
  704. br.Msg = "参数解析异常!"
  705. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  706. return
  707. }
  708. var condition string
  709. var pars []interface{}
  710. if req.Frequency != "" {
  711. condition += ` AND frequency = ? `
  712. pars = append(pars, req.Frequency)
  713. }
  714. if req.EndDate != "" {
  715. condition += ` AND end_date < ? `
  716. pars = append(pars, req.EndDate)
  717. }
  718. // 终端编码
  719. condition += ` AND terminal_code = ? `
  720. pars = append(pars, req.TerminalCode)
  721. condition += ` AND is_stop = 0 `
  722. indexObj := new(models.BaseFromMysteelChemicalIndex)
  723. // 获取未合并的指标总数量
  724. indexTotal, err := indexObj.GetIndexPageByFrequency(condition, pars, req.StartSize, req.PageSize)
  725. if err != nil {
  726. return
  727. }
  728. br.Data = indexTotal
  729. br.Ret = 200
  730. br.Success = true
  731. br.Msg = "处理成功"
  732. }