base_from_wind.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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. // wind
  13. type WindController struct {
  14. BaseAuthController
  15. }
  16. // @Title 新增wind指标接口
  17. // @Description 新增wind指标接口
  18. // @Success 200 {object} models.AddEdbInfoReq
  19. // @router /add [post]
  20. func (this *WindController) 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_WIND
  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. cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
  42. if !utils.Rc.IsExist(cacheKey) {
  43. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  44. //期货数据,就默认到今天,特殊处理下
  45. endDate := utils.BASE_END_DATE
  46. if strings.Contains(req.EdbCode, ".") {
  47. endDate = time.Now().Format(utils.FormatDate)
  48. }
  49. windUrl := ``
  50. // 试用平台的话,需要额外从弘则这边获取下地址
  51. if utils.BusinessCode == utils.HZ_TRIAL_BUSSINESS_CODE {
  52. tmpWindUrl, err, errMsg := services.GetHzWindUrl(req.EdbCode, source)
  53. if err != nil {
  54. br.Msg = "添加失败!"
  55. br.ErrMsg = "添加失败,Err:" + err.Error()
  56. if errMsg != `` {
  57. br.Msg = errMsg
  58. }
  59. return
  60. }
  61. windUrl = tmpWindUrl
  62. }
  63. if windUrl == `` {
  64. // 先配置中获取,如果有指定配置的话,那么取配置中的数据
  65. tmpConfig, err := models.GetConfigDetailByCode("wind_data_url")
  66. if err != nil && err.Error() != utils.ErrNoRow() {
  67. br.Msg = "获取配置的wind地址失败!"
  68. br.ErrMsg = "获取配置的wind地址失败,err:" + err.Error()
  69. return
  70. }
  71. if tmpConfig != nil {
  72. windUrl = tmpConfig.ConfigValue
  73. } else {
  74. windUrl, err = GetServerUrl(req.EdbCode)
  75. if err != nil {
  76. br.Msg = "获取使用的wind地址失败!"
  77. br.ErrMsg = "获取使用的wind地址失败,err:" + err.Error()
  78. return
  79. }
  80. }
  81. }
  82. if windUrl == `` {
  83. br.Msg = "没有配置wind地址!"
  84. br.ErrMsg = "没有配置wind地址"
  85. return
  86. }
  87. //windUrl = utils.Hz_Wind_Data_Url_LIST[1].Url
  88. dataItem, errCode, err := services.GetEdbDataFromWindUrl(windUrl, req.EdbCode, utils.BASE_START_DATE, endDate)
  89. //dataItem, errCode, err := services.GetEdbDataFromWind(req.EdbCode, utils.BASE_START_DATE, endDate)
  90. if errCode == 421 { //指标超限
  91. br.Ret = 421
  92. br.Msg = "指标超限!"
  93. return
  94. }
  95. if err != nil {
  96. br.Msg = "获取指标信息失败!"
  97. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  98. return
  99. }
  100. err = models.AddEdbDataFromWind(req.EdbCode, dataItem)
  101. if err != nil {
  102. br.Msg = "获取指标信息失败!"
  103. br.ErrMsg = "获取指标信息失败 AddEdbDataFromWind,Err:" + err.Error()
  104. return
  105. }
  106. br.Ret = 200
  107. br.Success = true
  108. br.Msg = "获取成功"
  109. } else {
  110. br.Ret = 501
  111. br.Success = true
  112. br.Msg = "系统处理中,请稍后重试"
  113. }
  114. }
  115. // @Title 刷新wind指标接口
  116. // @Description 刷新wind指标接口
  117. // @Success 200 {object} models.RefreshEdbInfoReq
  118. // @router /refresh [post]
  119. func (this *WindController) Refresh() {
  120. br := new(models.BaseResponse).Init()
  121. var cacheKey string
  122. defer func() {
  123. this.Data["json"] = br
  124. this.ServeJSON()
  125. }()
  126. source := utils.DATA_SOURCE_WIND
  127. var req models.RefreshEdbInfoReq
  128. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  129. if err != nil {
  130. br.Msg = "参数解析异常!"
  131. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  132. return
  133. }
  134. if req.EdbCode == "" {
  135. br.Msg = "请输入指标编码!"
  136. br.ErrMsg = "请输入指标编码,指标编码为空"
  137. return
  138. }
  139. if req.EdbInfoId <= 0 {
  140. br.Msg = "请输入指标ID!"
  141. br.ErrMsg = "请输入指标ID"
  142. return
  143. }
  144. cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
  145. if utils.Rc.IsExist(cacheKey) {
  146. br.Ret = 501
  147. br.Success = true
  148. br.Msg = "系统处理中,请稍后重试"
  149. return
  150. }
  151. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  152. defer func() {
  153. utils.Rc.Delete(cacheKey)
  154. }()
  155. //获取指标信息
  156. edbInfo, err := models.GetEdbInfoById(req.EdbInfoId)
  157. if err != nil {
  158. br.Msg = "查询指标信息失败!"
  159. br.ErrMsg = "查询指标信息失败 Err:" + err.Error()
  160. return
  161. }
  162. //期货数据,就默认到今天,特殊处理下
  163. endDate := utils.BASE_END_DATE
  164. if strings.Contains(req.EdbCode, ".") {
  165. endDate = time.Now().Format(utils.FormatDate)
  166. }
  167. dataItem, errCode, err := services.GetEdbDataFromWindUrl(edbInfo.ServerUrl, req.EdbCode, req.StartDate, endDate)
  168. if errCode == 421 { //指标超限
  169. br.Ret = 421
  170. br.Msg = "指标超限!"
  171. return
  172. }
  173. if err != nil {
  174. br.Msg = "获取指标信息失败!"
  175. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  176. return
  177. }
  178. err = models.RefreshEdbDataFromWind(req.EdbInfoId, req.EdbCode, req.StartDate, dataItem)
  179. if err != nil && err.Error() != utils.ErrNoRow() {
  180. br.Msg = "刷新指标信息失败!"
  181. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromWind,Err:" + err.Error()
  182. return
  183. }
  184. // 更新指标最大最小值
  185. err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfo(edbInfo)
  186. if err != nil {
  187. br.Msg = errMsg
  188. br.ErrMsg = err.Error()
  189. return
  190. }
  191. // 更新ES
  192. go logic.UpdateEs(edbInfo.EdbInfoId)
  193. br.Ret = 200
  194. br.Success = true
  195. br.Msg = "获取成功"
  196. }
  197. // GetServerUrl 获取服务器地址
  198. func GetServerUrl(edbCode string) (windUrl string, err error) {
  199. list, err := models.GetServerUrlCountGroupByServerUrl()
  200. if err != nil {
  201. return
  202. }
  203. windUrlNum := 0
  204. //现有系统的wind数据服务地址分配
  205. windUrlMap := make(map[string]int)
  206. for _, v := range list {
  207. windUrlMap[v.ServerUrl] = v.Total
  208. }
  209. for _, tmpWind := range utils.Hz_Wind_Data_Url_LIST {
  210. tmpWindUrl := tmpWind.Url
  211. tmpNum := windUrlMap[tmpWindUrl]
  212. if windUrl == `` || (windUrl != `` && tmpNum < windUrlNum) {
  213. windUrl = tmpWindUrl
  214. windUrlNum = tmpNum
  215. }
  216. }
  217. //windUrl = `http://datawind.hzinsights.com:8040/`
  218. // 设置缓存
  219. cacheKey := utils.CACHE_WIND_URL + ":" + edbCode
  220. _ = utils.Rc.SetNX(cacheKey, windUrl, utils.GetTodayLastSecond())
  221. return
  222. }