base_from_mysteel_chemical.go 22 KB

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