From 19be3926c88d19645f43dd926d00615225f30802 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Fri, 11 Jul 2025 17:36:46 +0800
Subject: [PATCH] 外汇接口调整

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java |  122 ++++++++++++++++++++++++++++------------
 1 files changed, 86 insertions(+), 36 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
index 12918b0..e70c08a 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/hobi/internal/XinLangDataServiceImpl.java
@@ -10,16 +10,20 @@
 import com.yami.trading.bean.cms.Infomation;
 import com.yami.trading.bean.data.domain.*;
 import com.yami.trading.bean.data.respDto.TradeTickResp;
+import com.yami.trading.bean.item.domain.Item;
 import com.yami.trading.common.util.RedisUtil;
 import com.yami.trading.common.util.StringUtils;
 import com.yami.trading.common.util.UTCDateUtils;
 import com.yami.trading.huobi.data.DataCache;
 import com.yami.trading.huobi.data.internal.DepthTimeObject;
+import com.yami.trading.huobi.data.internal.KlineConstant;
 import com.yami.trading.huobi.data.internal.KlineService;
 import com.yami.trading.huobi.data.internal.TradeTimeObject;
 import com.yami.trading.huobi.data.model.AlltickBatchKlineResult;
 import com.yami.trading.huobi.data.model.AlltickNewPriceResult;
 import com.yami.trading.huobi.data.model.AllticktradeResult;
+import com.yami.trading.huobi.hobi.HobiDataService;
+import com.yami.trading.huobi.hobi.constant.AllticktradeMadeOptions;
 import com.yami.trading.huobi.hobi.http.HttpHelper;
 import com.yami.trading.huobi.hobi.http.HttpMethodType;
 import com.yami.trading.service.cms.InfomationService;
@@ -174,20 +178,47 @@
                     for (Realtime realtime : realtimes){
                         if(tickNewPrice.getCode().equals(realtime.getName())){
                             realtime.setCloseOld(realtime.getClose());
-                            realtime.setClose(new BigDecimal(tickNewPrice.getPrice()));
-                            realtime.setVolume(new BigDecimal(tickNewPrice.getVolume()));
+//                            realtime.setClose(new BigDecimal(tickNewPrice.getPrice()));
+//                            realtime.setVolume(new BigDecimal(tickNewPrice.getVolume()));
                         }
+//                        Item bySymbol = itemService.findBySymbol(realtime.getSymbol());
+//                        if(null != bySymbol.getYesterdayLastPrice() && bySymbol.getYesterdayLastPrice().compareTo(BigDecimal.ZERO) != 0){
+//                            BigDecimal changePercent = (realtime.getClose().subtract(bySymbol.getYesterdayLastPrice()))
+//                                    .divide(bySymbol.getYesterdayLastPrice(), 5, RoundingMode.HALF_UP) // 精确到4位小数
+//                                    .multiply(new BigDecimal("100").setScale(2)).setScale(4,RoundingMode.HALF_UP); // 乘以100得到百分比
+//                            realtime.setChangeRatioStr(changePercent);
+//                        }
                     }
                 }
             }
+            //            Map<String, Object> requestData = createRequest(strings);
+//            String resultStr = HttpHelper.sendPostRequest(batchKline,requestData);
+//            JSONObject resultJson = JSON.parseObject(resultStr);
+//            if(null == resultJson || 200 != resultJson.getInteger("ret")){
+//                logger.error("数据,返回:{} ", resultJson);
+//            }
+//            JSONObject tempdata = resultJson.getJSONObject("data");
+//            JSONArray dataArray = tempdata.getJSONArray("kline_list");
+//            if (dataArray.size() > 0) {
+//                List<AlltickBatchKlineResult> batchKlines = JSONObject.parseArray(JSONObject.toJSONString(dataArray), AlltickBatchKlineResult.class);
+//                for (AlltickBatchKlineResult batchKline : batchKlines) {
+//                    for (AllticktradeResult result : batchKline.getKline_data()){
+//                        for (Realtime realtime : list){
+//                            if(realtime.getSymbol().equals(batchKline.getCode())){
+//                                int decimal = itemService.getDecimal(realtime.getSymbol());
+//                                realtime.setOpen(result.getOpen_price().setScale(decimal, RoundingMode.HALF_UP));
+//                                realtime.setHigh(result.getHigh_price().setScale(decimal, RoundingMode.HALF_UP));
+//                                realtime.setLow(result.getLow_price().setScale(decimal, RoundingMode.HALF_UP));
+//                                realtime.setClose(result.getClose_price().setScale(decimal, RoundingMode.HALF_UP));
+////                                realtime.setAmount(tickNewPrice.getPrice().multiply(tickNewPrice.getVolume()).setScale(item.getDecimals(), RoundingMode.HALF_UP));
+////                                realtime.setVolume(tickNewPrice.getVolume());
+//                            }
+//                        }
+//                    }
+//                }
+//            }
         } catch (Exception e){
             logger.error("error", e);
-        }
-        for (Realtime realtime : realtimes) {
-            if(realtime.getName().equals("USDSGD")){
-                System.out.println("USDSGD实时价格数据替换前=="+realtime.getCloseOld());
-                System.out.println("USDSGD实时价格数据替换后=="+realtime.getClose());
-            }
         }
         return realtimes;
     }
@@ -195,38 +226,57 @@
         List<Realtime> list = new ArrayList<Realtime>();
         try {
             List<String> strings = Arrays.asList(symbols.split(","));
-            Map<String, Object> requestData = createRequest(strings);
-            String resultStr = HttpHelper.sendPostRequest(batchKline,requestData);
-            JSONObject resultJson = JSON.parseObject(resultStr);
-            if(null == resultJson || 200 != resultJson.getInteger("ret")){
-                logger.error("数据,返回:{} ", resultJson);
+            Map<String, Object> requestDataTick = createRequestTick(strings);
+            String url = tradeTick.replace("{1}", URLEncoder.encode(requestDataTick.toString(), "UTF-8"));
+            HttpGet request = new HttpGet(url);
+            HttpResponse response = HttpHelper.getHttpclient().execute(request);
+            String resultTickStr = HttpHelper.responseProc(response);
+            JSONObject resultJsonTick = JSON.parseObject(resultTickStr);
+            if(null == resultJsonTick || 200 != resultJsonTick.getInteger("ret")){
+                logger.error("数据,返回:{} ", resultJsonTick);
             }
-            JSONObject tempdata = resultJson.getJSONObject("data");
-            JSONArray dataArray = tempdata.getJSONArray("kline_list");
-            if (dataArray.size() > 0) {
-                List<AlltickBatchKlineResult> batchKlines = JSONObject.parseArray(JSONObject.toJSONString(dataArray), AlltickBatchKlineResult.class);
-                for (AlltickBatchKlineResult batchKline : batchKlines) {
-                    for (AllticktradeResult result : batchKline.getKline_data()){
-                        Realtime realtime = new Realtime();
-                        int decimal = itemService.getDecimal(batchKline.getCode());
-                        realtime.setSymbol(batchKline.getCode());
-                        realtime.setTs(Long.parseLong(result.getTimestamp()));
-                        realtime.setName(batchKline.getCode());
-                        realtime.setOpen(result.getOpen_price().setScale(decimal, RoundingMode.HALF_UP));
-                        realtime.setHigh(result.getHigh_price().setScale(decimal, RoundingMode.HALF_UP));
-                        realtime.setLow(result.getLow_price().setScale(decimal, RoundingMode.HALF_UP));
-                        realtime.setClose(result.getClose_price().setScale(decimal, RoundingMode.HALF_UP));
-                        realtime.setMarketCapital(0L);
-                        realtime.setFloatMarketCapital(0L);
-                        realtime.setPeForecast(BigDecimal.ZERO);
-                        realtime.setVolumeRatio(BigDecimal.ZERO);
-                        realtime.setTurnoverRate(BigDecimal.ZERO);
-                        realtime.setAmount(result.getVolume());
-                        realtime.setVolume(result.getTurnover());
-                        list.add(realtime);
+            JSONObject tempdataTick = resultJsonTick.getJSONObject("data");
+            JSONArray dataArrayTick = tempdataTick.getJSONArray("tick_list");
+            if (dataArrayTick.size() > 0) {
+                List<AlltickNewPriceResult> alltickNewPriceResults = JSONObject.parseArray(JSONObject.toJSONString(dataArrayTick), AlltickNewPriceResult.class);
+                for (AlltickNewPriceResult tickNewPrice : alltickNewPriceResults) {
+                    Realtime realtime = new Realtime();
+                    Item item = itemService.findBySymbol(tickNewPrice.getCode());
+                    realtime.setSymbol(tickNewPrice.getCode());
+                    realtime.setTs(Long.parseLong(tickNewPrice.getTickTime()));
+                    realtime.setName(tickNewPrice.getCode());
+                    realtime.setClose(tickNewPrice.getPrice().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+//                    //涨跌幅 = (当天收盘价 - 前一日收盘价) / 前一日收盘价 * 100%
+//                    if(null != item.getYesterdayLastPrice() && item.getYesterdayLastPrice().compareTo(BigDecimal.ZERO) != 0){
+//                        BigDecimal changePercent = (realtime.getClose().subtract(item.getYesterdayLastPrice()))
+//                                .divide(item.getYesterdayLastPrice(), 5, RoundingMode.HALF_UP) // 精确到4位小数
+//                                .multiply(new BigDecimal("100").setScale(2)).setScale(4,RoundingMode.HALF_UP); // 乘以100得到百分比
+//                        realtime.setChangeRatioStr(changePercent);
+//                    }
+                    realtime.setMarketCapital(0L);
+                    realtime.setFloatMarketCapital(0L);
+                    realtime.setPeForecast(BigDecimal.ZERO);
+                    realtime.setVolumeRatio(BigDecimal.ZERO);
+                    realtime.setTurnoverRate(BigDecimal.ZERO);
+
+                    Kline kline = klineService.getLast(tickNewPrice.getCode(),Kline.PERIOD_1DAY);
+                    if(null != kline){
+                        realtime.setOpen(kline.getOpen().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+                        realtime.setHigh(kline.getHigh().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+                        realtime.setLow(kline.getLow().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+                        realtime.setAmount(kline.getAmount().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+                        realtime.setVolume(kline.getVolume().setScale(item.getDecimals(), RoundingMode.HALF_UP));
+                    }else {
+                        realtime.setOpen(BigDecimal.ZERO);
+                        realtime.setHigh(BigDecimal.ZERO);
+                        realtime.setLow(BigDecimal.ZERO);
+                        realtime.setAmount(BigDecimal.ZERO);
+                        realtime.setVolume(BigDecimal.ZERO);
                     }
+                    list.add(realtime);
                 }
             }
+
         } catch (Exception e) {
             logger.error("error", e);
         }

--
Gitblit v1.9.3