base_from_ths_ds.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. // 同花顺
  13. type ThsDsController struct {
  14. BaseAuthController
  15. }
  16. // @Title 新增同花顺指标接口
  17. // @Description 新增同花顺指标接口
  18. // @Success 200 {object} models.AddEdbInfoReq
  19. // @router /ds/add [post]
  20. func (this *ThsDsController) Add() {
  21. br := new(models.BaseResponse).Init()
  22. var cacheKey string
  23. defer func() {
  24. utils.Rc.Delete(cacheKey)
  25. this.Data["json"] = br
  26. this.ServeJSON()
  27. }()
  28. source := utils.DATA_SOURCE_THS
  29. var req models.AddEdbInfoReq
  30. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  31. if err != nil {
  32. br.Msg = "参数解析异常!"
  33. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  34. return
  35. }
  36. if req.EdbCode == "" {
  37. br.Msg = "请输入指标编码!"
  38. br.ErrMsg = "请输入指标编码,指标编码为空"
  39. return
  40. }
  41. //期货数据,就默认到今天,特殊处理下
  42. endDate := utils.BASE_END_DATE
  43. if strings.Contains(req.EdbCode, ".") {
  44. endDate = time.Now().Format(utils.FormatDate)
  45. }
  46. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.StockCode + req.EdbCode
  47. if !utils.Rc.IsExist(cacheKey) {
  48. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  49. dataItem, err := services.GetEdbDataFromThsDs(req.StockCode, req.EdbCode, utils.BASE_START_DATE, endDate, "")
  50. if err != nil {
  51. br.Msg = "获取指标信息失败!"
  52. br.ErrMsg = "获取指标信息失败 GetEdbDataFromThsDs,Err:" + err.Error()
  53. return
  54. }
  55. err = models.AddEdbDataFromThsDs(req.StockCode,req.EdbCode, dataItem)
  56. if err != nil {
  57. br.Msg = "获取指标信息失败!"
  58. br.ErrMsg = "获取指标信息失败 AddEdbDataFromThs,Err:" + err.Error()
  59. return
  60. }
  61. br.Ret = 200
  62. br.Success = true
  63. br.Msg = "获取成功"
  64. } else {
  65. br.Ret = 501
  66. br.Success = true
  67. br.Msg = "系统处理中,请稍后重试"
  68. }
  69. }
  70. // @Title 刷新同花顺指标接口
  71. // @Description 刷新同花顺指标接口
  72. // @Success 200 {object} models.RefreshEdbInfoReq
  73. // @router /ds/refresh [post]
  74. func (this *ThsDsController) Refresh() {
  75. br := new(models.BaseResponse).Init()
  76. var cacheKey string
  77. defer func() {
  78. this.Data["json"] = br
  79. this.ServeJSON()
  80. }()
  81. source := utils.DATA_SOURCE_THS
  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. //期货数据,就默认到今天,特殊处理下
  100. endDate := utils.BASE_END_DATE
  101. if strings.Contains(req.EdbCode, ".") {
  102. endDate = time.Now().Format(utils.FormatDate)
  103. }
  104. // 获取指标详情
  105. edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
  106. if err != nil {
  107. br.Msg = "指标不存在!"
  108. br.ErrMsg = "指标不存在"
  109. return
  110. }
  111. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  112. if utils.Rc.IsExist(cacheKey) {
  113. br.Ret = 501
  114. br.Success = true
  115. br.Msg = "系统处理中,请稍后重试"
  116. return
  117. }
  118. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  119. defer func() {
  120. utils.Rc.Delete(cacheKey)
  121. }()
  122. dataItem, err := services.GetEdbDataFromThsDs(edbInfo.StockCode, edbInfo.IndicatorCode, req.StartDate, endDate, edbInfo.TerminalCode)
  123. if err != nil {
  124. br.Msg = "获取指标信息失败!"
  125. br.ErrMsg = "获取指标信息失败 GetEdbDataFromThsDs,Err:" + err.Error()
  126. return
  127. }
  128. err = models.RefreshEdbDataFromThsDs(req.EdbInfoId, req.EdbCode, req.StartDate, dataItem)
  129. if err != nil && err.Error() != utils.ErrNoRow() {
  130. br.Msg = "刷新指标信息失败!"
  131. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromThsDs,Err:" + err.Error()
  132. return
  133. }
  134. // 更新指标最大最小值
  135. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  136. if err != nil {
  137. br.Msg = errMsg
  138. br.ErrMsg = err.Error()
  139. return
  140. }
  141. // 更新ES
  142. go logic.UpdateEs(edbInfo.EdbInfoId)
  143. br.Ret = 200
  144. br.Success = true
  145. br.Msg = "获取成功"
  146. }
  147. //func init() {
  148. // //?EdbCode=s005696248&StartDate=2023-02-03&EndDate=2027-03-23
  149. // //edbCode := `s005696248`
  150. // //startDate := `2023-02-03`
  151. // //endDate := `2027-03-23`
  152. // //EdbCode=S011292460&StartDate=1993-03-23&EndDate=2027-03-23
  153. // edbCode := `S011292460`
  154. // startDate := `1993-03-23`
  155. // endDate := `2027-03-23`
  156. // //edbCode := `@CL0W.NMX`
  157. // //startDate := `20221218`
  158. // //endDate := `20230118`
  159. // list, err := services.GetEdbDataFromThsHttp(edbCode, startDate, endDate, 0)
  160. // //list, err := services.GetFutureGoodDataFromThsHttp(edbCode, startDate, endDate)
  161. //
  162. // //token, err := services.GetAccessToken()
  163. // if err != nil {
  164. // fmt.Println("err:", err)
  165. // return
  166. // }
  167. // fmt.Println(list)
  168. // //fmt.Println(token)
  169. //}