base_from_wind.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "hongze/hongze_edb_lib/models"
  5. "hongze/hongze_edb_lib/services"
  6. "hongze/hongze_edb_lib/utils"
  7. "strconv"
  8. "strings"
  9. "time"
  10. )
  11. //wind
  12. type WindController struct {
  13. BaseAuthController
  14. }
  15. // @Title 新增wind指标接口
  16. // @Description 新增wind指标接口
  17. // @Success 200 {object} models.AddEdbInfoReq
  18. // @router /add [post]
  19. func (this *WindController) Add() {
  20. br := new(models.BaseResponse).Init()
  21. var cacheKey string
  22. defer func() {
  23. utils.Rc.Delete(cacheKey)
  24. this.Data["json"] = br
  25. this.ServeJSON()
  26. }()
  27. source := utils.DATA_SOURCE_WIND
  28. var req models.AddEdbInfoReq
  29. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  30. if err != nil {
  31. br.Msg = "参数解析异常!"
  32. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  33. return
  34. }
  35. if req.EdbCode == "" {
  36. br.Msg = "请输入指标编码!"
  37. br.ErrMsg = "请输入指标编码,指标编码为空"
  38. return
  39. }
  40. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  41. if !utils.Rc.IsExist(cacheKey) {
  42. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  43. //期货数据,就默认到今天,特殊处理下
  44. endDate := utils.BASE_END_DATE
  45. if strings.Contains(req.EdbCode, ".") {
  46. endDate = time.Now().Format(utils.FormatDate)
  47. }
  48. dataItem, err := services.GetEdbDataFromWind(req.EdbCode, utils.BASE_START_DATE, endDate)
  49. if err != nil {
  50. br.Msg = "获取指标信息失败!"
  51. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  52. return
  53. }
  54. err = models.AddEdbDataFromWind(req.EdbCode, dataItem)
  55. if err != nil {
  56. br.Msg = "获取指标信息失败!"
  57. br.ErrMsg = "获取指标信息失败 AddEdbDataFromWind,Err:" + err.Error()
  58. return
  59. }
  60. br.Ret = 200
  61. br.Success = true
  62. br.Msg = "获取成功"
  63. } else {
  64. br.Ret = 501
  65. br.Success = true
  66. br.Msg = "系统处理中,请稍后重试"
  67. }
  68. }
  69. // @Title 刷新wind指标接口
  70. // @Description 刷新wind指标接口
  71. // @Success 200 {object} models.RefreshEdbInfoReq
  72. // @router /refresh [post]
  73. func (this *WindController) Refresh() {
  74. br := new(models.BaseResponse).Init()
  75. var cacheKey string
  76. defer func() {
  77. utils.Rc.Delete(cacheKey)
  78. this.Data["json"] = br
  79. this.ServeJSON()
  80. }()
  81. source := utils.DATA_SOURCE_WIND
  82. var req models.RefreshEdbInfoReq
  83. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  84. if err != nil {
  85. br.Msg = "参数解析异常!"
  86. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  87. return
  88. }
  89. if req.EdbCode == "" {
  90. br.Msg = "请输入指标编码!"
  91. br.ErrMsg = "请输入指标编码,指标编码为空"
  92. return
  93. }
  94. if req.EdbInfoId <= 0 {
  95. br.Msg = "请输入指标ID!"
  96. br.ErrMsg = "请输入指标ID"
  97. return
  98. }
  99. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  100. if !utils.Rc.IsExist(cacheKey) {
  101. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  102. //期货数据,就默认到今天,特殊处理下
  103. endDate := utils.BASE_END_DATE
  104. if strings.Contains(req.EdbCode, ".") {
  105. endDate = time.Now().Format(utils.FormatDate)
  106. }
  107. dataItem, err := services.GetEdbDataFromWind(req.EdbCode, req.StartDate, endDate)
  108. if err != nil {
  109. br.Msg = "获取指标信息失败!"
  110. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  111. return
  112. }
  113. err = models.RefreshEdbDataFromWind(req.EdbInfoId, req.EdbCode, req.StartDate, dataItem)
  114. if err != nil && err.Error() != utils.ErrNoRow() {
  115. br.Msg = "刷新指标信息失败!"
  116. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromWind,Err:" + err.Error()
  117. return
  118. }
  119. br.Ret = 200
  120. br.Success = true
  121. br.Msg = "获取成功"
  122. } else {
  123. br.Ret = 501
  124. br.Success = true
  125. br.Msg = "系统处理中,请稍后重试"
  126. }
  127. }