future_good_edb_info.go 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. package future_good
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_edb_lib/controllers"
  6. "hongze/hongze_edb_lib/logic"
  7. "hongze/hongze_edb_lib/models"
  8. "hongze/hongze_edb_lib/models/future_good"
  9. "hongze/hongze_edb_lib/services"
  10. "hongze/hongze_edb_lib/utils"
  11. "strings"
  12. "time"
  13. )
  14. // FutureGoodEdbInfoController 期货数据
  15. type FutureGoodEdbInfoController struct {
  16. controllers.BaseAuthController
  17. }
  18. // Add
  19. // @Title 新增wind商品指标接口
  20. // @Description 新增wind指标接口
  21. // @Success 200 {object} models.AddEdbInfoReq
  22. // @router /add [post]
  23. func (this *FutureGoodEdbInfoController) Add() {
  24. br := new(models.BaseResponse).Init()
  25. var cacheKey string
  26. defer func() {
  27. this.Data["json"] = br
  28. this.ServeJSON()
  29. }()
  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. req.EdbCode = utils.TrimStr(req.EdbCode)
  43. cacheKey = utils.CACHE_EDB_DATA_ADD + "_futuregood_" + req.EdbCode
  44. if true {
  45. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  46. defer func() {
  47. utils.Rc.Delete(cacheKey)
  48. }()
  49. //期货数据,就默认到今天,特殊处理下
  50. futureGoodEdbInfo, err := future_good.GetFutureGoodEdbInfoByCode(req.EdbCode)
  51. if err != nil {
  52. if err.Error() != utils.ErrNoRow() {
  53. br.Msg = "系统内找不到该指标"
  54. } else {
  55. br.Msg = "添加失败"
  56. br.ErrMsg = "添加失败,ERR:" + err.Error()
  57. }
  58. return
  59. }
  60. //endDate := utils.BASE_END_DATE
  61. endDateTime := time.Now()
  62. //每天下午三点之前刷新数据的话,截止日期就到昨天,三点之后才刷新到今天的日期
  63. if endDateTime.Hour() < 15 {
  64. endDateTime = endDateTime.AddDate(0, 0, -1)
  65. }
  66. endDate := time.Now().Format(utils.FormatDate)
  67. dataItem, err := services.GetFutureGoodDataFromThs(req.EdbCode, utils.BASE_START_DATE, endDate, 0)
  68. if err != nil {
  69. br.Msg = "获取指标信息失败!"
  70. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  71. return
  72. }
  73. err = future_good.AddEdbDataFromWind(futureGoodEdbInfo.FutureGoodEdbInfoId, req.EdbCode, dataItem)
  74. if err != nil {
  75. br.Msg = "获取指标信息失败!"
  76. br.ErrMsg = "获取指标信息失败 AddEdbDataFromWind,Err:" + err.Error()
  77. return
  78. }
  79. // 更新指标最大最小值
  80. err, errMsg := future_good.UnifiedModifyEdbInfoMaxAndMinInfo(futureGoodEdbInfo)
  81. if err != nil {
  82. br.Msg = errMsg
  83. br.ErrMsg = err.Error()
  84. return
  85. }
  86. br.Ret = 200
  87. br.Success = true
  88. br.Msg = "获取成功"
  89. } else {
  90. br.Ret = 501
  91. br.Success = true
  92. br.Msg = "系统处理中,请稍后重试"
  93. }
  94. }
  95. // Refresh
  96. // @Title 刷新wind期货数据指标接口
  97. // @Description 刷新wind指标接口
  98. // @Success 200 {object} models.RefreshEdbInfoReq
  99. // @router /refresh [post]
  100. func (this *FutureGoodEdbInfoController) Refresh() {
  101. br := new(models.BaseResponse).Init()
  102. var cacheKey string
  103. defer func() {
  104. this.Data["json"] = br
  105. this.ServeJSON()
  106. }()
  107. var req future_good.RefreshFutureEdbEdbInfoReq
  108. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  109. if err != nil {
  110. br.Msg = "参数解析异常!"
  111. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  112. return
  113. }
  114. if req.FutureGoodEdbCode == "" {
  115. br.Msg = "请输入指标编码!"
  116. br.ErrMsg = "请输入指标编码,指标编码为空"
  117. return
  118. }
  119. if req.FutureGoodEdbInfoId <= 0 {
  120. br.Msg = "请输入指标ID!"
  121. br.ErrMsg = "请输入指标ID"
  122. return
  123. }
  124. cacheKey = utils.CACHE_EDB_DATA_REFRESH + "_futuregood_" + req.FutureGoodEdbCode
  125. if utils.Rc.IsExist(cacheKey) {
  126. br.Ret = 501
  127. br.Success = true
  128. br.Msg = "系统处理中,请稍后重试"
  129. return
  130. }
  131. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  132. defer func() {
  133. utils.Rc.Delete(cacheKey)
  134. }()
  135. //获取指标信息
  136. futureGoodEdbInfo, err := future_good.GetFutureGoodEdbInfoByCode(req.FutureGoodEdbCode)
  137. if err != nil {
  138. if err.Error() != utils.ErrNoRow() {
  139. br.Msg = "系统内找不到该指标"
  140. } else {
  141. br.Msg = "添加失败"
  142. br.ErrMsg = "添加失败,ERR:" + err.Error()
  143. }
  144. return
  145. }
  146. //期货数据,就默认到今天,特殊处理下
  147. endDateTime := time.Now()
  148. //每天下午三点之前刷新数据的话,截止日期就到昨天,三点之后才刷新到今天的日期
  149. if endDateTime.Hour() < 15 {
  150. endDateTime = endDateTime.AddDate(0, 0, -1)
  151. }
  152. endDate := endDateTime.Format(utils.FormatDate)
  153. // 数据开始日期
  154. startDate := req.StartDate
  155. if startDate == `` { // 如果传入的日期为空的话,那么就默认兼容一周的数据吧
  156. startDate = endDateTime.AddDate(0, 0, -7).Format(utils.FormatDate)
  157. }
  158. dataItem, err := services.GetFutureGoodDataFromThs(req.FutureGoodEdbCode, req.StartDate, endDate, 0)
  159. if err != nil {
  160. br.Msg = "获取指标信息失败!"
  161. br.ErrMsg = "获取指标信息失败 GetEdbDataFromWind,Err:" + err.Error()
  162. return
  163. }
  164. err = future_good.RefreshFutureGoodEdbDataFromThs(req.FutureGoodEdbInfoId, req.FutureGoodEdbCode, req.StartDate, dataItem)
  165. if err != nil && err.Error() != utils.ErrNoRow() {
  166. br.Msg = "刷新指标信息失败!"
  167. br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromWind,Err:" + err.Error()
  168. return
  169. }
  170. // 更新指标最大最小值
  171. err, errMsg := future_good.UnifiedModifyEdbInfoMaxAndMinInfo(futureGoodEdbInfo)
  172. if err != nil {
  173. br.Msg = errMsg
  174. br.ErrMsg = err.Error()
  175. return
  176. }
  177. br.Ret = 200
  178. br.Success = true
  179. br.Msg = "获取成功"
  180. }
  181. // RefreshRelation
  182. // @Title 刷新商品期货指标相关的接口
  183. // @Description 刷新商品期货指标相关的接口
  184. // @Success 200 {object} models.RefreshEdbInfoReq
  185. // @router /relation/refresh [post]
  186. func (this *FutureGoodEdbInfoController) RefreshRelation() {
  187. br := new(models.BaseResponse).Init()
  188. var cacheKey string
  189. defer func() {
  190. this.Data["json"] = br
  191. this.ServeJSON()
  192. }()
  193. var req future_good.RefreshFutureEdbEdbInfoReq
  194. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  195. if err != nil {
  196. br.Msg = "参数解析异常!"
  197. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  198. return
  199. }
  200. if req.FutureGoodEdbInfoId <= 0 {
  201. br.Msg = "请输入指标ID!"
  202. br.ErrMsg = "请输入指标ID"
  203. return
  204. }
  205. cacheKey = utils.CACHE_EDB_DATA_REFRESH + "_futuregood_relation_" + req.FutureGoodEdbCode
  206. if utils.Rc.IsExist(cacheKey) {
  207. br.Ret = 501
  208. br.Success = true
  209. br.Msg = "系统处理中,请稍后重试"
  210. return
  211. }
  212. utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
  213. defer func() {
  214. utils.Rc.Delete(cacheKey)
  215. }()
  216. //获取指标信息
  217. futureGoodEdbInfo, err := future_good.GetFutureGoodEdbInfo(req.FutureGoodEdbInfoId)
  218. if err != nil {
  219. if err.Error() != utils.ErrNoRow() {
  220. br.Msg = "系统内找不到该指标"
  221. } else {
  222. br.Msg = "刷新失败"
  223. br.ErrMsg = "添加失败,ERR:" + err.Error()
  224. }
  225. return
  226. }
  227. // 获取相关图表
  228. list, err := models.GetGroupChartEdbMappingListByEdbInfoId(futureGoodEdbInfo.FutureGoodEdbInfoId, 2)
  229. if err != nil {
  230. br.Msg = "查找相关图表id失败"
  231. br.ErrMsg = "添加失败,ERR:" + err.Error()
  232. return
  233. }
  234. errMsgList := make([]string, 0)
  235. for _, v := range list {
  236. err, errMsg := logic.RefreshByChartId(v.ChartInfoId)
  237. if err != nil {
  238. errMsgList = append(errMsgList, fmt.Sprint(v.ChartInfoId, "更新失败,"+errMsg))
  239. }
  240. }
  241. if len(errMsgList) > 0 {
  242. br.Msg = "部分刷新失败"
  243. br.ErrMsg = "部分刷新失败,Err:" + strings.Join(errMsgList, ";")
  244. return
  245. }
  246. br.Ret = 200
  247. br.Success = true
  248. br.Msg = "刷新成功"
  249. }
  250. //func init() {
  251. //
  252. // list, err := future_good.GetFutureGoodEdbInfoList(" AND start_date = '0000-00-00' ", []interface{}{})
  253. // if err != nil {
  254. // fmt.Println("list err:", err)
  255. // return
  256. // }
  257. //
  258. // fmt.Println("start")
  259. // for _, futureGoodEdbInfo := range list {
  260. // // 更新指标最大最小值
  261. // err, errMsg := future_good.UnifiedModifyEdbInfoMaxAndMinInfo(futureGoodEdbInfo)
  262. // if err != nil {
  263. // fmt.Println(futureGoodEdbInfo.FutureGoodEdbCode, "更新失败:", errMsg, ";err:", err)
  264. // return
  265. // }
  266. // }
  267. // fmt.Println("end")
  268. //}