base_from_sci_hq.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  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/utils"
  7. "strconv"
  8. "time"
  9. )
  10. type SciHqController struct {
  11. BaseAuthController
  12. }
  13. // Add
  14. // @Title 新增卓创红期指标接口
  15. // @Description 新增卓创红期指标接口
  16. // @Success 200 {object} models.AddEdbInfoReq
  17. // @router /add [post]
  18. func (this *SciHqController) Add() {
  19. br := new(models.BaseResponse).Init()
  20. var cacheKey string
  21. defer func() {
  22. utils.Rc.Delete(cacheKey)
  23. this.Data["json"] = br
  24. this.ServeJSON()
  25. }()
  26. source := utils.DATA_SOURCE_SCI
  27. var req models.AddEdbInfoReq
  28. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  29. if err != nil {
  30. br.Msg = "参数解析异常!"
  31. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  32. return
  33. }
  34. if req.EdbCode == "" {
  35. br.Msg = "请输入指标编码!"
  36. br.ErrMsg = "请输入指标编码,指标编码为空"
  37. return
  38. }
  39. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  40. if !utils.Rc.IsExist(cacheKey) {
  41. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  42. err = models.AddEdbDataFromSci(req.EdbCode)
  43. if err != nil {
  44. br.Msg = "获取指标信息失败!"
  45. br.ErrMsg = "获取指标信息失败 AddEdbDataFromSci,Err:" + err.Error()
  46. return
  47. }
  48. br.Ret = 200
  49. br.Success = true
  50. br.Msg = "获取成功"
  51. } else {
  52. br.Ret = 501
  53. br.Success = true
  54. br.Msg = "系统处理中,请稍后重试"
  55. }
  56. }
  57. // Refresh
  58. // @Title 刷新卓创红期指标接口
  59. // @Description 刷新卓创红期指标接口
  60. // @Success 200 {object} models.RefreshEdbInfoReq
  61. // @router /refresh [post]
  62. func (this *SciHqController) Refresh() {
  63. br := new(models.BaseResponse).Init()
  64. defer func() {
  65. this.Data["json"] = br
  66. this.ServeJSON()
  67. }()
  68. source := utils.DATA_SOURCE_SCI
  69. var req models.RefreshEdbInfoReq
  70. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  71. if err != nil {
  72. br.Msg = "参数解析异常!"
  73. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  74. return
  75. }
  76. if req.EdbCode == "" {
  77. br.Msg = "请输入指标编码!"
  78. br.ErrMsg = "请输入指标编码,指标编码为空"
  79. return
  80. }
  81. if req.EdbInfoId < 0 {
  82. br.Msg = "请输入指标ID!"
  83. br.ErrMsg = "请输入指标ID"
  84. return
  85. }
  86. // 获取指标详情
  87. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  88. if err != nil {
  89. br.Msg = "指标不存在!"
  90. br.ErrMsg = "指标不存在"
  91. return
  92. }
  93. isHandling, errMsg, err := logic.RefreshBaseEdbInfo(edbInfo, req.StartDate)
  94. if isHandling {
  95. br.Ret = 501
  96. br.Success = true
  97. br.Msg = "系统处理中,请稍后重试"
  98. return
  99. }
  100. if err != nil {
  101. br.Msg = errMsg
  102. br.ErrMsg = err.Error()
  103. return
  104. }
  105. br.Ret = 200
  106. br.Success = true
  107. br.Msg = "获取成功"
  108. }
  109. // HandleExcelData
  110. // @Title 处理卓创(红桃3)指标的接口
  111. // @Description 处理卓创(红桃3)指标的接口
  112. // @Success 200 {object} models.HandleMysteelIndexResp
  113. // @router /handle/excel_data [post]
  114. func (this *SciHqController) HandleExcelData() {
  115. br := new(models.BaseResponse).Init()
  116. defer func() {
  117. this.Data["json"] = br
  118. this.ServeJSON()
  119. }()
  120. var req []*models.HandleSciHqExcelDataReq
  121. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  122. if err != nil {
  123. br.Msg = "参数解析异常!"
  124. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  125. return
  126. }
  127. indexList, err := models.GetAllBaseFromSciHqIndex()
  128. if err != nil {
  129. br.Msg = "获取指标列表失败!"
  130. br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
  131. return
  132. }
  133. allIndexMap := make(map[string]*models.BaseFromSciHqIndex)
  134. for _, v := range indexList {
  135. allIndexMap[v.IndexCode] = v
  136. }
  137. addSciHqIndexList := make([]*models.BaseFromSciHqIndex, 0)
  138. for _, v := range req {
  139. t := new(models.BaseFromSciHqIndex)
  140. if _, ok := allIndexMap[v.ExcelIndexCode]; !ok {
  141. t.ClassifyId = 0
  142. t.IndexName = v.IndexName
  143. t.IndexCode = v.ExcelIndexCode
  144. t.Frequency = v.Frequency
  145. t.Unit = v.Unit
  146. t.TerminalCode = v.TerminalCode
  147. t.FilePath = v.FilePath
  148. t.CreateTime = time.Now()
  149. t.ModifyTime = time.Now()
  150. addSciHqIndexList = append(addSciHqIndexList, t)
  151. }
  152. }
  153. if len(addSciHqIndexList) > 0 {
  154. err = models.BatchAddBaseFromSciHqIndex(addSciHqIndexList)
  155. if err != nil {
  156. br.Msg = "添加指标失败!"
  157. br.ErrMsg = "添加指标失败,Err:" + err.Error()
  158. return
  159. }
  160. }
  161. indexList, err = models.GetAllBaseFromSciHqIndex()
  162. if err != nil {
  163. br.Msg = "获取指标列表失败!"
  164. br.ErrMsg = "获取指标列表失败,Err:" + err.Error()
  165. return
  166. }
  167. allIndexMap = make(map[string]*models.BaseFromSciHqIndex)
  168. for _, v := range indexList {
  169. allIndexMap[v.IndexCode] = v
  170. }
  171. for _, v := range req {
  172. if indexInfo, ok := allIndexMap[v.ExcelIndexCode]; !ok {
  173. utils.FileLog.Info("指标不存在,indexCode:" + v.ExcelIndexCode)
  174. continue
  175. } else {
  176. indexDataList, err := models.GetBaseFromSciHqDataByIndexCode(indexInfo.IndexCode)
  177. if err != nil {
  178. br.Msg = "获取指标数据失败!"
  179. br.ErrMsg = "获取指标数据失败,Err:" + err.Error()
  180. return
  181. }
  182. indexDataExistMap := make(map[string]*models.BaseFromSciHqData)
  183. for _, indexData := range indexDataList {
  184. indexDataExistMap[indexData.DataTime] = indexData
  185. }
  186. addSciHqDataList := make([]*models.BaseFromSciHqData, 0)
  187. for dataDate, dataVal := range v.Data {
  188. currDataTime, err := time.ParseInLocation(utils.FormatDate, dataDate, time.Local)
  189. if err != nil {
  190. utils.FileLog.Info("时间格式化失败,indexCode:" + v.ExcelIndexCode + "Err:" + err.Error())
  191. continue
  192. }
  193. timestamp := currDataTime.UnixNano() / 1e6
  194. sciHqData, ok := indexDataExistMap[dataDate]
  195. if !ok {
  196. tmpBaseFromSciData := &models.BaseFromSciHqData{
  197. BaseFromSciHqIndexId: indexInfo.BaseFromSciHqIndexId,
  198. IndexCode: indexInfo.IndexCode,
  199. DataTime: dataDate,
  200. Value: dataVal,
  201. CreateTime: time.Now(),
  202. ModifyTime: time.Now(),
  203. DataTimestamp: timestamp,
  204. }
  205. addSciHqDataList = append(addSciHqDataList, tmpBaseFromSciData)
  206. } else {
  207. existValue := sciHqData.Value
  208. if dataVal != "" && existValue != dataVal {
  209. sciHqData.Value = dataVal
  210. sciHqData.ModifyTime = time.Now()
  211. if sciHqData.SciHqDataId > 0 {
  212. err = sciHqData.Update([]string{"value", "modify_time"})
  213. if err != nil {
  214. utils.FileLog.Info("更新指标数据失败,indexCode:" + v.ExcelIndexCode + "Err:" + err.Error())
  215. continue
  216. }
  217. }
  218. }
  219. }
  220. }
  221. if len(addSciHqDataList) > 0 {
  222. err = models.BatchAddBaseFromSciHqData(addSciHqDataList)
  223. if err != nil {
  224. utils.FileLog.Info("添加指标数据失败,indexCode:" + v.ExcelIndexCode + "Err:" + err.Error())
  225. continue
  226. }
  227. }
  228. // 同步刷新ETA图库卓创红期的指标
  229. {
  230. // 获取指标详情
  231. edbInfo, err := models.GetEdbInfoByEdbCode(utils.DATA_SOURCE_SCI_HQ, indexInfo.IndexCode)
  232. if err != nil && err.Error() != utils.ErrNoRow() {
  233. utils.FileLog.Info("刷新指标异常,indexCode:" + v.ExcelIndexCode + "Err:" + err.Error())
  234. continue
  235. }
  236. // 已经加入到指标库的话,那么就去更新ETA指标库吧
  237. if edbInfo != nil {
  238. go logic.RefreshBaseEdbInfo(edbInfo, ``)
  239. }
  240. }
  241. }
  242. }
  243. br.Msg = "处理成功"
  244. br.Success = true
  245. br.Ret = 200
  246. }