pcsg_bloomberg.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package index_data
  2. import (
  3. "encoding/json"
  4. "eta/eta_bridge/global"
  5. "eta/eta_bridge/models/pcsg"
  6. "fmt"
  7. "io/ioutil"
  8. "net/http"
  9. )
  10. // GetPCSGBloombergGeneralIndex 获取指标信息
  11. func GetPCSGBloombergGeneralIndex(taskKey, frequency string) (indexes []pcsg.BaseFromBloombergApiIndexAndData, err error) {
  12. apiData, e := CurlPCSGBloombergGeneralDataApi(taskKey)
  13. if e != nil {
  14. err = fmt.Errorf("CurlPCSGBloombergDailyApi err: %s", e.Error())
  15. return
  16. }
  17. if len(apiData) == 0 {
  18. return
  19. }
  20. conf, e := LoadPCSGBloombergTask(taskKey)
  21. if e != nil {
  22. err = fmt.Errorf("加载配置失败, Err: %v", e)
  23. return
  24. }
  25. if conf == nil {
  26. err = fmt.Errorf("加载配置异常, %s", taskKey)
  27. return
  28. }
  29. for _, v := range apiData {
  30. t := pcsg.FormatPythonBloombergGeneralData2Base(v, conf)
  31. if t.IndexCode != "" {
  32. indexes = append(indexes, t)
  33. }
  34. }
  35. return
  36. }
  37. // CurlPCSGBloombergGeneralDataApi 请求通用格式数据接口
  38. func CurlPCSGBloombergGeneralDataApi(taskKey string) (resultData []map[string]interface{}, err error) {
  39. if taskKey == "" {
  40. err = fmt.Errorf("任务Key为空")
  41. return
  42. }
  43. if global.CONFIG.PCSG.BloombergApiUrl == "" {
  44. err = fmt.Errorf("服务地址为空")
  45. return
  46. }
  47. url := fmt.Sprintf("%s/api/bloomberg/general_data?task_key=%s", global.CONFIG.PCSG.BloombergApiUrl, taskKey)
  48. resp, e := http.Get(url)
  49. if e != nil {
  50. err = fmt.Errorf("http post err: %s", e.Error())
  51. return
  52. }
  53. defer resp.Body.Close()
  54. b, e := ioutil.ReadAll(resp.Body)
  55. if e != nil {
  56. err = fmt.Errorf("resp body read err: %s", e.Error())
  57. return
  58. }
  59. if len(b) == 0 {
  60. err = fmt.Errorf("resp body is empty")
  61. return
  62. }
  63. //str := `{"Code":200,"Msg":"","Data":[{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-09T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B001","RC":0,"DATE":"2024-05-09","PX_LAST":1183.88},{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-10T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B001","RC":0,"DATE":"2024-05-10","PX_LAST":1182.79},{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-09T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B002","RC":0,"DATE":"2024-05-10","PX_LAST":1162.63}]}`
  64. //b := []byte(str)
  65. result := new(pcsg.PythonBloombergGeneralResult)
  66. if e = json.Unmarshal(b, &result); e != nil {
  67. err = fmt.Errorf("result unmarshal err: %s\nresult: %s", e.Error(), string(b))
  68. return
  69. }
  70. if result.Code != 200 {
  71. err = fmt.Errorf("result: %s", string(b))
  72. return
  73. }
  74. resultData = result.Data
  75. return
  76. }
  77. // LoadPCSGBloombergTask 加载配置
  78. func LoadPCSGBloombergTask(taskName string) (conf *pcsg.TaskConfPCSGBloomberg, err error) {
  79. filePath := "./static/pcsg_task.json"
  80. b, e := ioutil.ReadFile(filePath)
  81. if e != nil {
  82. err = fmt.Errorf("读取配置失败, err: %v", e)
  83. return
  84. }
  85. tasks := make([]*pcsg.TaskConfPCSGBloomberg, 0)
  86. if e = json.Unmarshal(b, &tasks); e != nil {
  87. err = fmt.Errorf("解析配置失败, err: %v", e)
  88. return
  89. }
  90. for _, v := range tasks {
  91. if v.TaskKey == taskName {
  92. conf = v
  93. break
  94. }
  95. }
  96. return
  97. }