base_from_mysteel_chemical.go 22 KB

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