base_edb_lib.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. package data
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/models"
  5. "eta/eta_api/models/data_manage"
  6. "eta/eta_api/models/data_manage/response"
  7. "eta/eta_api/utils"
  8. "fmt"
  9. "io/ioutil"
  10. "net/http"
  11. "strings"
  12. )
  13. // AddEdbData 新增指标数据
  14. func AddEdbData(source int, edbCode, frequency string) (resp *models.BaseResponse, err error) {
  15. param := make(map[string]interface{})
  16. param["EdbCode"] = edbCode
  17. param["Source"] = source
  18. param["Frequency"] = frequency
  19. urlStr := ``
  20. switch source {
  21. case utils.DATA_SOURCE_THS:
  22. urlStr = "ths/add"
  23. case utils.DATA_SOURCE_WIND:
  24. urlStr = "wind/add"
  25. case utils.DATA_SOURCE_PB:
  26. urlStr = "pb/add"
  27. case utils.DATA_SOURCE_PB_FINANCE:
  28. urlStr = "pb_finance/add"
  29. case utils.DATA_SOURCE_MANUAL:
  30. urlStr = "manual/add"
  31. case utils.DATA_SOURCE_LZ:
  32. urlStr = "lz/add"
  33. case utils.DATA_SOURCE_YS:
  34. urlStr = "smm/add"
  35. case utils.DATA_SOURCE_GL:
  36. urlStr = "mysteel/add"
  37. case utils.DATA_SOURCE_ZZ:
  38. urlStr = "zz/add"
  39. case utils.DATA_SOURCE_DL:
  40. urlStr = "dl/add"
  41. case utils.DATA_SOURCE_SH:
  42. urlStr = "sh/add"
  43. case utils.DATA_SOURCE_CFFEX:
  44. urlStr = "cffex/add"
  45. case utils.DATA_SOURCE_SHFE:
  46. urlStr = "shfe/add"
  47. case utils.DATA_SOURCE_GIE:
  48. urlStr = "gie/add"
  49. case utils.DATA_SOURCE_LT:
  50. urlStr = "lt/add"
  51. case utils.DATA_SOURCE_COAL:
  52. urlStr = "coal/add"
  53. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  54. urlStr = "google_travel/add"
  55. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  56. urlStr = "mysteel_chemical/add"
  57. case utils.DATA_SOURCE_EIA_STEO:
  58. urlStr = "eia_steo/add"
  59. case utils.DATA_SOURCE_COM_TRADE:
  60. urlStr = "com_trade/add"
  61. case utils.DATA_SOURCE_SCI:
  62. urlStr = "sci/add"
  63. case utils.DATA_SOURCE_BAIINFO:
  64. urlStr = "baiinfo/add"
  65. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  66. urlStr = "national_statistics/add"
  67. case utils.DATA_SOURCE_FUBAO:
  68. urlStr = "fubao/add"
  69. case utils.DATA_SOURCE_GFEX:
  70. urlStr = "gz/add"
  71. case utils.DATA_SOURCE_ICPI:
  72. urlStr = "icpi/add"
  73. case utils.DATA_SOURCE_SCI99:
  74. urlStr = "sci99/add"
  75. case utils.DATA_SOURCE_SCI_HQ:
  76. urlStr = "sci_hq/add"
  77. case utils.DATA_SOURCE_LY:
  78. urlStr = "ly/add"
  79. case utils.DATA_SOURCE_RZD:
  80. urlStr = "rzd/add"
  81. case utils.DATA_SOURCE_CLARKSONS:
  82. urlStr = "clarksons/add"
  83. default:
  84. edbSource := data_manage.EdbSourceIdMap[source]
  85. if edbSource != nil {
  86. urlStr = edbSource.EdbAddMethod
  87. }
  88. }
  89. if urlStr == "" {
  90. err = fmt.Errorf("未实现该指标的刷新接口,请联系管理员")
  91. return
  92. }
  93. resp, err = postRefreshEdbData(param, urlStr)
  94. return
  95. }
  96. // AddEdbDataWindWsd 新增指标数据
  97. func AddEdbDataWindWsd(source int, stockCode, edbCode, days, period, priceAdj string) (resp *models.BaseResponse, err error) {
  98. param := make(map[string]interface{})
  99. param["EdbCode"] = edbCode
  100. param["StockCode"] = stockCode
  101. param["Source"] = source
  102. param["Days"] = days
  103. param["Period"] = period
  104. param["PriceAdj"] = priceAdj
  105. urlStr := `wind/wsd/add`
  106. resp, err = postRefreshEdbData(param, urlStr)
  107. return
  108. }
  109. // AddEdbDataThsDs 新增指标数据
  110. func AddEdbDataThsDs(source int, stockCode, edbCode, extraPars, days, period string) (resp *models.BaseResponse, err error) {
  111. param := make(map[string]interface{})
  112. param["EdbCode"] = edbCode
  113. param["StockCode"] = stockCode
  114. param["Source"] = source
  115. param["Days"] = days
  116. param["Period"] = period
  117. param["ExtraPars"] = extraPars
  118. urlStr := `ths/ds/add`
  119. resp, err = postRefreshEdbData(param, urlStr)
  120. return
  121. }
  122. type AddPredictEdbDataResponse struct {
  123. Ret int
  124. Msg string
  125. ErrMsg string
  126. ErrCode string
  127. Data data_manage.AddEdbInfoResp
  128. Success bool `description:"true 执行成功,false 执行失败"`
  129. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  130. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  131. }
  132. // EdbCalculateSaveMultiResponse 批量计算返回值
  133. type EdbCalculateSaveMultiResponse struct {
  134. Ret int
  135. Msg string
  136. ErrMsg string
  137. ErrCode string
  138. Data data_manage.BatchEdbInfoCalculateBatchSaveResp
  139. Success bool `description:"true 执行成功,false 执行失败"`
  140. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  141. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  142. }
  143. // SaveBasePredictEdbData 新增/编辑预测指标运算
  144. func SaveBasePredictEdbData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  145. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict/save", lang)
  146. err = json.Unmarshal(resultByte, &resp)
  147. if err != nil {
  148. return
  149. }
  150. return
  151. }
  152. type PredictRuleCalculateByNineRespResponse struct {
  153. Ret int
  154. Msg string
  155. ErrMsg string
  156. ErrCode string
  157. Data response.PredictRuleCalculateByNineResp
  158. Success bool `description:"true 执行成功,false 执行失败"`
  159. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  160. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  161. }
  162. // PredictCalculateByNinePreview 预测指标动态环差演算
  163. func PredictCalculateByNinePreview(RuleConfigReqStr, lang string) (resp *PredictRuleCalculateByNineRespResponse, err error) {
  164. _, resultByte, err := postAddEdbData(RuleConfigReqStr, "predict/calculate_by_nine/preview", lang)
  165. err = json.Unmarshal(resultByte, &resp)
  166. if err != nil {
  167. return
  168. }
  169. return
  170. }
  171. // SavePredictEdbData 新增/编辑预测指标运算
  172. func SavePredictEdbData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  173. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/save", lang)
  174. err = json.Unmarshal(resultByte, &resp)
  175. if err != nil {
  176. return
  177. }
  178. return
  179. }
  180. // BatchSavePredictEdbData 新增/编辑 预测指标运算(同比、同差)
  181. func BatchSavePredictEdbData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  182. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/batch/save", lang)
  183. if err != nil {
  184. return
  185. }
  186. err = json.Unmarshal(resultByte, &resp)
  187. if err != nil {
  188. return
  189. }
  190. return
  191. }
  192. // RefreshEdbData 刷新指标数据
  193. func RefreshEdbData(edbInfoId, source, subSource int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  194. param := make(map[string]interface{})
  195. param["EdbCode"] = edbCode
  196. param["EdbInfoId"] = edbInfoId
  197. param["StartDate"] = startDate
  198. param["Source"] = source
  199. urlStr := ``
  200. switch source {
  201. case utils.DATA_SOURCE_THS:
  202. switch subSource {
  203. case utils.DATA_SUB_SOURCE_DATE:
  204. urlStr = "ths/ds/refresh"
  205. case utils.DATA_SUB_SOURCE_HIGH_FREQUENCY:
  206. urlStr = "ths/hf/edb/refresh"
  207. default:
  208. urlStr = "ths/refresh"
  209. }
  210. case utils.DATA_SOURCE_WIND:
  211. if subSource == 0 {
  212. urlStr = "wind/refresh"
  213. } else {
  214. urlStr = "wind/wsd/refresh"
  215. }
  216. case utils.DATA_SOURCE_PB:
  217. urlStr = "pb/refresh"
  218. case utils.DATA_SOURCE_PB_FINANCE:
  219. urlStr = "pb_finance/refresh"
  220. case utils.DATA_SOURCE_MANUAL:
  221. urlStr = "manual/refresh"
  222. case utils.DATA_SOURCE_LZ:
  223. urlStr = "lz/refresh"
  224. case utils.DATA_SOURCE_YS:
  225. urlStr = "smm/refresh"
  226. case utils.DATA_SOURCE_GL:
  227. urlStr = "mysteel/refresh"
  228. case utils.DATA_SOURCE_ZZ:
  229. urlStr = "zz/refresh"
  230. case utils.DATA_SOURCE_DL:
  231. urlStr = "dl/refresh"
  232. case utils.DATA_SOURCE_SH:
  233. urlStr = "sh/refresh"
  234. case utils.DATA_SOURCE_CFFEX:
  235. urlStr = "cffex/refresh"
  236. case utils.DATA_SOURCE_SHFE:
  237. urlStr = "shfe/refresh"
  238. case utils.DATA_SOURCE_GIE:
  239. urlStr = "gie/refresh"
  240. case utils.DATA_SOURCE_LT:
  241. urlStr = "lt/refresh"
  242. case utils.DATA_SOURCE_COAL:
  243. urlStr = "coal/refresh"
  244. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  245. urlStr = "google_travel/refresh"
  246. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  247. urlStr = "mysteel_chemical/refresh"
  248. case utils.DATA_SOURCE_EIA_STEO:
  249. urlStr = "eia_steo/refresh"
  250. case utils.DATA_SOURCE_PREDICT:
  251. urlStr = "predict/refresh"
  252. case utils.DATA_SOURCE_COM_TRADE:
  253. urlStr = "com_trade/refresh"
  254. case utils.DATA_SOURCE_SCI:
  255. urlStr = "sci/refresh"
  256. case utils.DATA_SOURCE_BAIINFO:
  257. urlStr = "baiinfo/refresh"
  258. case utils.DATA_SOURCE_STOCK_PLANT:
  259. urlStr = "stock_plant/refresh"
  260. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  261. urlStr = "national_statistics/refresh"
  262. case utils.DATA_SOURCE_FUBAO:
  263. urlStr = "fubao/refresh"
  264. case utils.DATA_SOURCE_GFEX:
  265. urlStr = "gz/refresh"
  266. case utils.DATA_SOURCE_ICPI:
  267. urlStr = "icpi/refresh"
  268. case utils.DATA_SOURCE_SCI99:
  269. urlStr = "sci99/refresh"
  270. case utils.DATA_SOURCE_SCI_HQ:
  271. urlStr = "sci_hq/refresh"
  272. case utils.DATA_SOURCE_LY:
  273. urlStr = "ly/refresh"
  274. case utils.DATA_SOURCE_TRADE_ANALYSIS:
  275. urlStr = "trade_analysis/edb/refresh"
  276. case utils.DATA_SOURCE_CLARKSONS:
  277. urlStr = "clarksons/refresh"
  278. default:
  279. edbSource := data_manage.EdbSourceIdMap[source]
  280. if edbSource != nil {
  281. urlStr = edbSource.EdbRefreshMethod
  282. }
  283. }
  284. if urlStr == "" {
  285. err = fmt.Errorf(fmt.Sprint("source:", source, ";未实现该指标的刷新接口,请联系管理员"))
  286. return
  287. }
  288. resp, err = postRefreshEdbData(param, urlStr)
  289. return
  290. }
  291. // RefreshEdbCalculateData 刷新普通计算指标数据请求
  292. func RefreshEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  293. param := make(map[string]interface{})
  294. param["EdbCode"] = edbCode
  295. param["EdbInfoId"] = edbInfoId
  296. param["StartDate"] = startDate
  297. resp, err = postRefreshEdbData(param, "calculate/refresh")
  298. return
  299. }
  300. // RefreshPredictEdbCalculateData 刷新 预测计算指标 数据请求
  301. func RefreshPredictEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  302. param := make(map[string]interface{})
  303. param["EdbCode"] = edbCode
  304. param["EdbInfoId"] = edbInfoId
  305. param["StartDate"] = startDate
  306. resp, err = postRefreshEdbData(param, "predict_calculate/refresh")
  307. return
  308. }
  309. // AddEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  310. func AddEdbCalculateData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  311. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/add", lang)
  312. err = json.Unmarshal(resultByte, &resp)
  313. if err != nil {
  314. return
  315. }
  316. return
  317. }
  318. // EditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  319. func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  320. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/edit", lang)
  321. err = json.Unmarshal(resultByte, &resp)
  322. if err != nil {
  323. return
  324. }
  325. return
  326. }
  327. // BatchSaveEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  328. func BatchSaveEdbCalculateData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  329. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/save", lang)
  330. err = json.Unmarshal(resultByte, &resp)
  331. if err != nil {
  332. return
  333. }
  334. return
  335. }
  336. // BatchEditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  337. func BatchEditEdbCalculateData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  338. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/edit", lang)
  339. err = json.Unmarshal(resultByte, &resp)
  340. if err != nil {
  341. return
  342. }
  343. return
  344. }
  345. // BatchSaveEdbCalculateMultiData 批量新增 累计值转月-同比值-同差等计算新增
  346. func BatchSaveEdbCalculateMultiData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *EdbCalculateSaveMultiResponse, err error) {
  347. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/save/multi", lang)
  348. err = json.Unmarshal(resultByte, &resp)
  349. if err != nil {
  350. return
  351. }
  352. return
  353. }
  354. // BatchEditEdbCalculateMultiData 批量编辑 累计值转月-同比值-同差等计算新增
  355. func BatchEditEdbCalculateMultiData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *EdbCalculateSaveMultiResponse, err error) {
  356. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/edit/multi", lang)
  357. err = json.Unmarshal(resultByte, &resp)
  358. if err != nil {
  359. return
  360. }
  361. return
  362. }
  363. //// EditEdbCalculateData 修改计算指标数据请求
  364. //func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *models.BaseResponse, err error) {
  365. // resp, _, err = postAddEdbData(edbInfoCalculateBatchSaveReqStr, "batch/save")
  366. // return
  367. //}
  368. // ExecPythonCode 执行python代码
  369. func ExecPythonCode(pythonCode string) (resp *models.BaseResponse, err error) {
  370. param := make(map[string]interface{})
  371. param["PythonCode"] = pythonCode
  372. urlStr := `/python/exec`
  373. resp, err = postRefreshEdbData(param, urlStr)
  374. return
  375. }
  376. // AddPythonEdbData 新增python指标
  377. func AddPythonEdbData(param, lang string) (resp *models.BaseResponse, err error) {
  378. urlStr := ``
  379. urlStr = "python/add"
  380. resp, _, err = postAddEdbData(param, urlStr, lang)
  381. return
  382. }
  383. // EditPythonEdbData 编辑python指标
  384. func EditPythonEdbData(param, lang string) (resp *models.BaseResponse, err error) {
  385. urlStr := ``
  386. urlStr = "python/edit"
  387. resp, _, err = postAddEdbData(param, urlStr, lang)
  388. return
  389. }
  390. // SaveAdjustEdbInfo 保存数据调整指标
  391. func SaveAdjustEdbInfo(param, lang string) (resp *models.BaseResponse, err error) {
  392. urlStr := ``
  393. urlStr = "calculate/adjust/save"
  394. resp, _, err = postAddEdbData(param, urlStr, lang)
  395. return
  396. }
  397. // ResetCustomAnalysisData 重置自定义表格的数据
  398. func ResetCustomAnalysisData(reqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  399. _, resultByte, err := postAddEdbData(reqStr, "calculate/custom_analysis/reset", lang)
  400. err = json.Unmarshal(resultByte, &resp)
  401. if err != nil {
  402. return
  403. }
  404. return
  405. }
  406. // CalculateComputeCorrelationResp 拟合残差计算相关性的值返回
  407. type CalculateComputeCorrelationResp struct {
  408. Ret int
  409. Msg string
  410. ErrMsg string
  411. ErrCode string
  412. Data string
  413. Success bool `description:"true 执行成功,false 执行失败"`
  414. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  415. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  416. }
  417. // CalculateComputeCorrelation 拟合残差计算相关性的值
  418. func CalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr, lang string) (resp *CalculateComputeCorrelationResp, err error) {
  419. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/compute_correlation", lang)
  420. err = json.Unmarshal(resultByte, &resp)
  421. if err != nil {
  422. return
  423. }
  424. return
  425. }
  426. // PredictCalculateComputeCorrelation 拟合残差计算相关性的值(预测指标)
  427. func PredictCalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr, lang string) (resp *CalculateComputeCorrelationResp, err error) {
  428. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/compute_correlation", lang)
  429. err = json.Unmarshal(resultByte, &resp)
  430. if err != nil {
  431. return
  432. }
  433. return
  434. }
  435. // BaseCalculateResp 拟合残差计算相关性的值返回
  436. type BaseCalculateResp struct {
  437. Ret int
  438. Msg string
  439. ErrMsg string
  440. ErrCode string
  441. Data BaseCalculateDataResp
  442. Success bool `description:"true 执行成功,false 执行失败"`
  443. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  444. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  445. }
  446. // BaseCalculateDataResp
  447. // @Description: 基础计算的返回结果
  448. type BaseCalculateDataResp struct {
  449. DataMap map[string]float64
  450. DateList []string
  451. }
  452. // BaseCalculate 基础计算
  453. func BaseCalculate(param, lang string) (resp *BaseCalculateResp, err error) {
  454. urlStr := "calculate/base"
  455. _, resultByte, err := postAddEdbData(param, urlStr, lang)
  456. err = json.Unmarshal(resultByte, &resp)
  457. if err != nil {
  458. return
  459. }
  460. return
  461. }
  462. // AddBaseEdbInfo 新增基础指标
  463. func AddBaseEdbInfo(addBaseEdbInfoReqStr string, source, subSource int, lang string) (resp *AddPredictEdbDataResponse, err error) {
  464. urlStr := ``
  465. switch source {
  466. case utils.DATA_SOURCE_BUSINESS:
  467. urlStr = "business_index/add"
  468. case utils.DATA_SOURCE_THS:
  469. if subSource == utils.DATA_SUB_SOURCE_HIGH_FREQUENCY {
  470. urlStr = "ths/hf/edb/add"
  471. }
  472. default:
  473. edbSource := data_manage.EdbSourceIdMap[source]
  474. if edbSource != nil {
  475. urlStr = edbSource.EdbRefreshMethod
  476. }
  477. }
  478. if urlStr == "" {
  479. err = fmt.Errorf(fmt.Sprint("source:", source, ";未实现该指标的刷新接口,请联系管理员"))
  480. return
  481. }
  482. _, resultByte, err := postAddEdbData(addBaseEdbInfoReqStr, urlStr, lang)
  483. if err != nil {
  484. return
  485. }
  486. err = json.Unmarshal(resultByte, &resp)
  487. return
  488. }
  489. // postRefreshEdbData 刷新指标数据
  490. func postRefreshEdbData(param map[string]interface{}, urlStr string) (resp *models.BaseResponse, err error) {
  491. postUrl := utils.EDB_LIB_URL + urlStr
  492. postData, err := json.Marshal(param)
  493. if err != nil {
  494. return
  495. }
  496. result, err := HttpPost(postUrl, string(postData), utils.ZhLangVersion, "application/json")
  497. if err != nil {
  498. return
  499. }
  500. utils.FileLog.Info("postRefreshEdbData:" + postUrl + ";" + string(postData) + ";result:" + string(result))
  501. err = json.Unmarshal(result, &resp)
  502. if err != nil {
  503. return
  504. }
  505. return resp, nil
  506. }
  507. // postAddEdbData 新增指标数据
  508. func postAddEdbData(paramStr string, urlStr, lang string) (resp *models.BaseResponse, result []byte, err error) {
  509. postUrl := utils.EDB_LIB_URL + urlStr
  510. result, err = HttpPost(postUrl, paramStr, lang, "application/json")
  511. if err != nil {
  512. return
  513. }
  514. err = json.Unmarshal(result, &resp)
  515. if err != nil {
  516. return
  517. }
  518. return
  519. }
  520. func HttpPost(url, postData, lang string, params ...string) ([]byte, error) {
  521. body := ioutil.NopCloser(strings.NewReader(postData))
  522. client := &http.Client{}
  523. req, err := http.NewRequest("POST", url, body)
  524. if err != nil {
  525. return nil, err
  526. }
  527. contentType := "application/x-www-form-urlencoded;charset=utf-8"
  528. if len(params) > 0 && params[0] != "" {
  529. contentType = params[0]
  530. }
  531. req.Header.Set("Content-Type", contentType)
  532. req.Header.Set("Lang", lang)
  533. req.Header.Set("authorization", utils.MD5(utils.APP_EDB_LIB_NAME_EN+utils.EDB_LIB_Md5_KEY))
  534. resp, err := client.Do(req)
  535. if err != nil {
  536. return nil, err
  537. }
  538. defer resp.Body.Close()
  539. b, err := ioutil.ReadAll(resp.Body)
  540. utils.FileLog.Debug("HttpPost:" + string(b))
  541. return b, err
  542. }
  543. // BaseStepCalculate 基础运算-多步骤
  544. func BaseStepCalculate(param, lang string) (resp *BaseCalculateResp, err error) {
  545. urlStr := "calculate/base/step_calculate"
  546. _, resultByte, err := postAddEdbData(param, urlStr, lang)
  547. err = json.Unmarshal(resultByte, &resp)
  548. if err != nil {
  549. return
  550. }
  551. return
  552. }
  553. // SavePredictStaticEdbData 新增预测指标-静态指标
  554. func SavePredictStaticEdbData(edbInfoCalculateBatchSaveReqStr, lang string) (resp *AddPredictEdbDataResponse, err error) {
  555. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict/static_edb/add", lang)
  556. err = json.Unmarshal(resultByte, &resp)
  557. if err != nil {
  558. return
  559. }
  560. return
  561. }