base_from_mysteel_chemical.go 22 KB

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