base_edb_lib.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. package data
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/models"
  5. "eta/eta_api/models/data_manage"
  6. "eta/eta_api/utils"
  7. "fmt"
  8. "io/ioutil"
  9. "net/http"
  10. "strings"
  11. )
  12. // AddEdbData 新增指标数据
  13. func AddEdbData(source int, edbCode string) (resp *models.BaseResponse, err error) {
  14. param := make(map[string]interface{})
  15. param["EdbCode"] = edbCode
  16. param["Source"] = source
  17. urlStr := ``
  18. switch source {
  19. case utils.DATA_SOURCE_THS:
  20. urlStr = "ths/add"
  21. case utils.DATA_SOURCE_WIND:
  22. urlStr = "wind/add"
  23. case utils.DATA_SOURCE_PB:
  24. urlStr = "pb/add"
  25. case utils.DATA_SOURCE_PB_FINANCE:
  26. urlStr = "pb_finance/add"
  27. case utils.DATA_SOURCE_MANUAL:
  28. urlStr = "manual/add"
  29. case utils.DATA_SOURCE_LZ:
  30. urlStr = "lz/add"
  31. case utils.DATA_SOURCE_YS:
  32. urlStr = "smm/add"
  33. case utils.DATA_SOURCE_GL:
  34. urlStr = "mysteel/add"
  35. case utils.DATA_SOURCE_ZZ:
  36. urlStr = "zz/add"
  37. case utils.DATA_SOURCE_DL:
  38. urlStr = "dl/add"
  39. case utils.DATA_SOURCE_SH:
  40. urlStr = "sh/add"
  41. case utils.DATA_SOURCE_CFFEX:
  42. urlStr = "cffex/add"
  43. case utils.DATA_SOURCE_SHFE:
  44. urlStr = "shfe/add"
  45. case utils.DATA_SOURCE_GIE:
  46. urlStr = "gie/add"
  47. case utils.DATA_SOURCE_LT:
  48. urlStr = "lt/add"
  49. case utils.DATA_SOURCE_COAL:
  50. urlStr = "coal/add"
  51. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  52. urlStr = "google_travel/add"
  53. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  54. urlStr = "mysteel_chemical/add"
  55. case utils.DATA_SOURCE_EIA_STEO:
  56. urlStr = "eia_steo/add"
  57. case utils.DATA_SOURCE_COM_TRADE:
  58. urlStr = "com_trade/add"
  59. case utils.DATA_SOURCE_SCI:
  60. urlStr = "sci/add"
  61. case utils.DATA_SOURCE_BAIINFO:
  62. urlStr = "baiinfo/add"
  63. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  64. urlStr = "national_statistics/add"
  65. case utils.DATA_SOURCE_FUBAO:
  66. urlStr = "fubao/add"
  67. default:
  68. urlStr = data_manage.EdbDataAddMethodMap[source] // 没有对应的从edb_source中取
  69. }
  70. if urlStr == "" {
  71. err = fmt.Errorf("未实现该指标的刷新接口,请联系管理员")
  72. return
  73. }
  74. resp, err = postRefreshEdbData(param, urlStr)
  75. return
  76. }
  77. type AddPredictEdbDataResponse struct {
  78. Ret int
  79. Msg string
  80. ErrMsg string
  81. ErrCode string
  82. Data data_manage.AddEdbInfoResp
  83. Success bool `description:"true 执行成功,false 执行失败"`
  84. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  85. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  86. }
  87. // SaveBasePredictEdbData 新增/编辑预测指标运算
  88. func SaveBasePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  89. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict/save")
  90. err = json.Unmarshal(resultByte, &resp)
  91. if err != nil {
  92. return
  93. }
  94. return
  95. }
  96. // SavePredictEdbData 新增/编辑预测指标运算
  97. func SavePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  98. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/save")
  99. err = json.Unmarshal(resultByte, &resp)
  100. if err != nil {
  101. return
  102. }
  103. return
  104. }
  105. // BatchSavePredictEdbData 新增/编辑 预测指标运算(同比、同差)
  106. func BatchSavePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  107. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/batch/save")
  108. if err != nil {
  109. return
  110. }
  111. err = json.Unmarshal(resultByte, &resp)
  112. if err != nil {
  113. return
  114. }
  115. return
  116. }
  117. // RefreshEdbData 刷新指标数据
  118. func RefreshEdbData(edbInfoId, source int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  119. param := make(map[string]interface{})
  120. param["EdbCode"] = edbCode
  121. param["EdbInfoId"] = edbInfoId
  122. param["StartDate"] = startDate
  123. param["Source"] = source
  124. urlStr := ``
  125. switch source {
  126. case utils.DATA_SOURCE_THS:
  127. urlStr = "ths/refresh"
  128. case utils.DATA_SOURCE_WIND:
  129. urlStr = "wind/refresh"
  130. case utils.DATA_SOURCE_PB:
  131. urlStr = "pb/refresh"
  132. case utils.DATA_SOURCE_PB_FINANCE:
  133. urlStr = "pb_finance/refresh"
  134. case utils.DATA_SOURCE_MANUAL:
  135. urlStr = "manual/refresh"
  136. case utils.DATA_SOURCE_LZ:
  137. urlStr = "lz/refresh"
  138. case utils.DATA_SOURCE_YS:
  139. urlStr = "smm/refresh"
  140. case utils.DATA_SOURCE_GL:
  141. urlStr = "mysteel/refresh"
  142. case utils.DATA_SOURCE_ZZ:
  143. urlStr = "zz/refresh"
  144. case utils.DATA_SOURCE_DL:
  145. urlStr = "dl/refresh"
  146. case utils.DATA_SOURCE_SH:
  147. urlStr = "sh/refresh"
  148. case utils.DATA_SOURCE_CFFEX:
  149. urlStr = "cffex/refresh"
  150. case utils.DATA_SOURCE_SHFE:
  151. urlStr = "shfe/refresh"
  152. case utils.DATA_SOURCE_GIE:
  153. urlStr = "gie/refresh"
  154. case utils.DATA_SOURCE_LT:
  155. urlStr = "lt/refresh"
  156. case utils.DATA_SOURCE_COAL:
  157. urlStr = "coal/refresh"
  158. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  159. urlStr = "google_travel/refresh"
  160. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  161. urlStr = "mysteel_chemical/refresh"
  162. case utils.DATA_SOURCE_EIA_STEO:
  163. urlStr = "eia_steo/refresh"
  164. case utils.DATA_SOURCE_PREDICT:
  165. urlStr = "predict/refresh"
  166. case utils.DATA_SOURCE_COM_TRADE:
  167. urlStr = "com_trade/refresh"
  168. case utils.DATA_SOURCE_SCI:
  169. urlStr = "sci/refresh"
  170. case utils.DATA_SOURCE_BAIINFO:
  171. urlStr = "baiinfo/refresh"
  172. case utils.DATA_SOURCE_STOCK_PLANT:
  173. urlStr = "stock_plant/refresh"
  174. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  175. urlStr = "national_statistics/refresh"
  176. case utils.DATA_SOURCE_FUBAO:
  177. urlStr = "fubao/refresh"
  178. default:
  179. urlStr = data_manage.EdbDataRefreshMethodMap[source] // 没有对应的从edb_source中取
  180. }
  181. if urlStr == "" {
  182. err = fmt.Errorf(fmt.Sprint("source:", source, ";未实现该指标的刷新接口,请联系管理员"))
  183. return
  184. }
  185. resp, err = postRefreshEdbData(param, urlStr)
  186. return
  187. }
  188. // RefreshEdbCalculateData 刷新普通计算指标数据请求
  189. func RefreshEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  190. param := make(map[string]interface{})
  191. param["EdbCode"] = edbCode
  192. param["EdbInfoId"] = edbInfoId
  193. param["StartDate"] = startDate
  194. resp, err = postRefreshEdbData(param, "calculate/refresh")
  195. return
  196. }
  197. // RefreshPredictEdbCalculateData 刷新 预测计算指标 数据请求
  198. func RefreshPredictEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  199. param := make(map[string]interface{})
  200. param["EdbCode"] = edbCode
  201. param["EdbInfoId"] = edbInfoId
  202. param["StartDate"] = startDate
  203. resp, err = postRefreshEdbData(param, "predict_calculate/refresh")
  204. return
  205. }
  206. // AddEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  207. func AddEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  208. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/add")
  209. err = json.Unmarshal(resultByte, &resp)
  210. if err != nil {
  211. return
  212. }
  213. return
  214. }
  215. // EditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  216. func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  217. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/edit")
  218. err = json.Unmarshal(resultByte, &resp)
  219. if err != nil {
  220. return
  221. }
  222. return
  223. }
  224. // BatchSaveEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  225. func BatchSaveEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  226. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/save")
  227. err = json.Unmarshal(resultByte, &resp)
  228. if err != nil {
  229. return
  230. }
  231. return
  232. }
  233. // BatchEditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  234. func BatchEditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  235. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/edit")
  236. err = json.Unmarshal(resultByte, &resp)
  237. if err != nil {
  238. return
  239. }
  240. return
  241. }
  242. //// EditEdbCalculateData 修改计算指标数据请求
  243. //func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *models.BaseResponse, err error) {
  244. // resp, _, err = postAddEdbData(edbInfoCalculateBatchSaveReqStr, "batch/save")
  245. // return
  246. //}
  247. // ExecPythonCode 执行python代码
  248. func ExecPythonCode(pythonCode string) (resp *models.BaseResponse, err error) {
  249. param := make(map[string]interface{})
  250. param["PythonCode"] = pythonCode
  251. urlStr := `/python/exec`
  252. resp, err = postRefreshEdbData(param, urlStr)
  253. return
  254. }
  255. // AddPythonEdbData 新增python指标
  256. func AddPythonEdbData(param string) (resp *models.BaseResponse, err error) {
  257. urlStr := ``
  258. urlStr = "python/add"
  259. resp, _, err = postAddEdbData(param, urlStr)
  260. return
  261. }
  262. // EditPythonEdbData 编辑python指标
  263. func EditPythonEdbData(param string) (resp *models.BaseResponse, err error) {
  264. urlStr := ``
  265. urlStr = "python/edit"
  266. resp, _, err = postAddEdbData(param, urlStr)
  267. return
  268. }
  269. // SaveAdjustEdbInfo 保存数据调整指标
  270. func SaveAdjustEdbInfo(param string) (resp *models.BaseResponse, err error) {
  271. urlStr := ``
  272. urlStr = "calculate/adjust/save"
  273. resp, _, err = postAddEdbData(param, urlStr)
  274. return
  275. }
  276. // ResetCustomAnalysisData 重置自定义表格的数据
  277. func ResetCustomAnalysisData(reqStr string) (resp *AddPredictEdbDataResponse, err error) {
  278. _, resultByte, err := postAddEdbData(reqStr, "calculate/custom_analysis/reset")
  279. err = json.Unmarshal(resultByte, &resp)
  280. if err != nil {
  281. return
  282. }
  283. return
  284. }
  285. // CalculateComputeCorrelationResp 拟合残差计算相关性的值返回
  286. type CalculateComputeCorrelationResp struct {
  287. Ret int
  288. Msg string
  289. ErrMsg string
  290. ErrCode string
  291. Data string
  292. Success bool `description:"true 执行成功,false 执行失败"`
  293. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  294. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  295. }
  296. // CalculateComputeCorrelation 拟合残差计算相关性的值
  297. func CalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr string) (resp *CalculateComputeCorrelationResp, err error) {
  298. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/compute_correlation")
  299. err = json.Unmarshal(resultByte, &resp)
  300. if err != nil {
  301. return
  302. }
  303. return
  304. }
  305. // PredictCalculateComputeCorrelation 拟合残差计算相关性的值(预测指标)
  306. func PredictCalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr string) (resp *CalculateComputeCorrelationResp, err error) {
  307. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/compute_correlation")
  308. err = json.Unmarshal(resultByte, &resp)
  309. if err != nil {
  310. return
  311. }
  312. return
  313. }
  314. // postRefreshEdbData 刷新指标数据
  315. func postRefreshEdbData(param map[string]interface{}, urlStr string) (resp *models.BaseResponse, err error) {
  316. postUrl := utils.EDB_LIB_URL + urlStr
  317. postData, err := json.Marshal(param)
  318. if err != nil {
  319. return
  320. }
  321. result, err := HttpPost(postUrl, string(postData), "application/json")
  322. if err != nil {
  323. return
  324. }
  325. utils.FileLog.Info("postRefreshEdbData:" + postUrl + ";" + string(postData) + ";result:" + string(result))
  326. err = json.Unmarshal(result, &resp)
  327. if err != nil {
  328. return
  329. }
  330. return resp, nil
  331. }
  332. // postAddEdbData 新增指标数据
  333. func postAddEdbData(paramStr string, urlStr string) (resp *models.BaseResponse, result []byte, err error) {
  334. postUrl := utils.EDB_LIB_URL + urlStr
  335. result, err = HttpPost(postUrl, paramStr, "application/json")
  336. if err != nil {
  337. return
  338. }
  339. err = json.Unmarshal(result, &resp)
  340. if err != nil {
  341. return
  342. }
  343. return
  344. }
  345. func HttpPost(url, postData string, params ...string) ([]byte, error) {
  346. body := ioutil.NopCloser(strings.NewReader(postData))
  347. client := &http.Client{}
  348. req, err := http.NewRequest("POST", url, body)
  349. if err != nil {
  350. return nil, err
  351. }
  352. contentType := "application/x-www-form-urlencoded;charset=utf-8"
  353. if len(params) > 0 && params[0] != "" {
  354. contentType = params[0]
  355. }
  356. req.Header.Set("Content-Type", contentType)
  357. req.Header.Set("authorization", utils.MD5(utils.APP_EDB_LIB_NAME_EN+utils.EDB_LIB_Md5_KEY))
  358. resp, err := client.Do(req)
  359. if err != nil {
  360. return nil, err
  361. }
  362. defer resp.Body.Close()
  363. b, err := ioutil.ReadAll(resp.Body)
  364. fmt.Println("HttpPost:" + string(b))
  365. return b, err
  366. }