From 6e09aa2c20ff596c2dfae165d94a9af8ce281030 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Fri, 05 Jun 2026 10:12:12 +0800
Subject: [PATCH] 1
---
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1QuarterJob.java | 5
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java | 2
trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java | 43 +++++-----
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5DayJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MinuteJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineServiceImpl.java | 18 ++--
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1WeekJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline15MinuteJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MonJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1YearJob.java | 7 -
trading-order-bean/src/main/java/com/yami/trading/bean/item/domain/Item.java | 7 +
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline60MinuteJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineInitServiceImpl.java | 31 +++----
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5MinuteJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1DayJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline30MinuteJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline2HourJob.java | 6
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline4HourJob.java | 2
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java | 86 +++++++++++----------
19 files changed, 113 insertions(+), 112 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
index 61df12d..d4e1106 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/KlineController.java
@@ -181,30 +181,27 @@
map.put("low", low.setScale(decimal, RoundingMode.HALF_UP));
map.put("volume", kline.getVolume());
- if (i == data.size() - 1) {
- BigDecimal periodHigh = high;
- BigDecimal periodLow = low;
- BigDecimal closePrice = close;
- Realtime realtime = DataCache.getLatestRealTime(symbol);
- if (realtime != null && realtime.getClose() != null
- && realtime.getClose().compareTo(BigDecimal.ZERO) > 0) {
- closePrice = realtime.getClose();
- map.put("close", closePrice.setScale(decimal, RoundingMode.HALF_UP));
+ //if (line.equalsIgnoreCase(Kline.PERIOD_15MIN) || line.equalsIgnoreCase(Kline.PERIOD_30MIN) || line.equalsIgnoreCase(Kline.PERIOD_60MIN)) {
+ if (i == data.size() - 1) {
+ Realtime realtime = DataCache.getLatestRealTime(symbol);
+ if (realtime != null && realtime.getClose() != null && realtime.getClose().compareTo(BigDecimal.ZERO) > 0) {
+ map.put("close", realtime.getClose().setScale(decimal, RoundingMode.HALF_UP));
+ }
+ BeforeClose beforeClose = dataDBService.getBeforeClose(kline.getSymbol(), line, ts, realtime);
+ if (beforeClose != null) {
+ map.put("high", beforeClose.getMaxClose().setScale(decimal, RoundingMode.HALF_UP));
+ map.put("low", beforeClose.getMinClose().setScale(decimal, RoundingMode.HALF_UP));
+ }
+ BigDecimal openVal = (BigDecimal) map.get("open");
+ BigDecimal closeVal = (BigDecimal) map.get("close");
+ BigDecimal highVal = (BigDecimal) map.get("high");
+ BigDecimal lowVal = (BigDecimal) map.get("low");
+ if (openVal != null && closeVal != null) {
+ map.put("high", highVal.max(openVal).max(closeVal));
+ map.put("low", lowVal.min(openVal).min(closeVal));
+ }
}
- BeforeClose beforeClose = dataDBService.getBeforeClose(kline.getSymbol(), line, ts, realtime);
- if (beforeClose != null
- && beforeClose.getMaxClose() != null && beforeClose.getMaxClose().compareTo(BigDecimal.ZERO) > 0
- && beforeClose.getMinClose() != null && beforeClose.getMinClose().compareTo(BigDecimal.ZERO) > 0) {
- periodHigh = periodHigh.max(beforeClose.getMaxClose());
- periodLow = periodLow.min(beforeClose.getMinClose());
- }
- if (closePrice != null && closePrice.compareTo(BigDecimal.ZERO) > 0) {
- periodHigh = periodHigh.max(closePrice);
- periodLow = periodLow.min(closePrice);
- }
- map.put("high", periodHigh.setScale(decimal, RoundingMode.HALF_UP));
- map.put("low", periodLow.setScale(decimal, RoundingMode.HALF_UP));
- }
+ //}
list.add(map);
}
return list;
diff --git a/trading-order-bean/src/main/java/com/yami/trading/bean/item/domain/Item.java b/trading-order-bean/src/main/java/com/yami/trading/bean/item/domain/Item.java
index a22d9a4..808e687 100644
--- a/trading-order-bean/src/main/java/com/yami/trading/bean/item/domain/Item.java
+++ b/trading-order-bean/src/main/java/com/yami/trading/bean/item/domain/Item.java
@@ -178,6 +178,13 @@
}
/**
+ * 是否为平台自定义币(机器人行情)
+ */
+ public boolean isFake() {
+ return "1".equalsIgnoreCase(fake);
+ }
+
+ /**
* 板块
*/
private String board;
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
index 9b42c5b..eb73aa7 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/DataDBServiceImpl.java
@@ -119,10 +119,10 @@
LocalDate yesterday = LocalDate.now(ZoneId.of("America/New_York")).minusDays(1);
// 4. 判断是否为昨天
- boolean isYesterday = tsDate.equals(yesterday);
- if (isYesterday) {
- return realtime;
- }
+ boolean isYesterday = tsDate.equals(yesterday);
+ if (isYesterday) {
+ return realtime;
+ }
}
// 没缓存重新保存
// 计算当天0点的时间戳(毫秒级)
@@ -144,63 +144,65 @@
public BeforeClose getBeforeClose(String symbol, String line, Long ts, Realtime realtime) {
BeforeClose beforeClose = (BeforeClose) redisTemplate.opsForValue().get(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line);
- //超出时间重新计算
- if (beforeClose == null || ts > beforeClose.getTs()) {
+ long queryTs = normalizeToMillis(ts);
+ if (beforeClose == null || queryTs > beforeClose.getTs()) {
long currentTimeStamp = System.currentTimeMillis();
RequestDataHelper.set("symbol", symbol);
QueryWrapper<Realtime> queryWrapper = new QueryWrapper<Realtime>()
.eq("symbol", symbol)
- .ge("ts", ts)
+ .ge("ts", queryTs)
.le("ts", currentTimeStamp)
- .select("MAX(close) as maxClose", "MIN(close) as minClose");
+ .select("MAX(CAST(close AS DECIMAL(20,8))) as maxClose",
+ "MIN(CAST(close AS DECIMAL(20,8))) as minClose");
Map<String, Object> resultMap = realtimeService.getMap(queryWrapper);
RequestDataHelper.clear();
beforeClose = new BeforeClose();
- BigDecimal maxClose = extractAggregateValue(resultMap, "maxClose");
- BigDecimal minClose = extractAggregateValue(resultMap, "minClose");
- mergeRealtimeIntoBeforeClose(beforeClose, maxClose, minClose, realtime);
- beforeClose.setTs(ts);
+ beforeClose.setTs(queryTs);
+ if (resultMap != null && !resultMap.isEmpty()) {
+ beforeClose.setMaxClose(convertToBigDecimal(resultMap.get("maxClose")));
+ beforeClose.setMinClose(convertToBigDecimal(resultMap.get("minClose")));
+ }
redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
- } else if (realtime != null) {
- mergeRealtimeIntoBeforeClose(beforeClose, beforeClose.getMaxClose(), beforeClose.getMinClose(), realtime);
- redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
+ }
+
+ mergeRealtimeIntoBeforeClose(beforeClose, realtime, symbol, line);
+ if (!isValidBeforeClose(beforeClose)) {
+ return null;
}
return beforeClose;
}
- private void mergeRealtimeIntoBeforeClose(BeforeClose beforeClose, BigDecimal maxClose, BigDecimal minClose, Realtime realtime) {
- BigDecimal max = maxClose;
- BigDecimal min = minClose;
- if (realtime != null && realtime.getClose() != null) {
- BigDecimal latest = realtime.getClose();
- if (max == null || max.compareTo(BigDecimal.ZERO) <= 0) {
- max = latest;
- } else {
- max = max.max(latest);
+ private void mergeRealtimeIntoBeforeClose(BeforeClose beforeClose, Realtime realtime, String symbol, String line) {
+ if (realtime == null || realtime.getClose() == null || realtime.getClose().compareTo(BigDecimal.ZERO) <= 0) {
+ return;
+ }
+ BigDecimal close = realtime.getClose();
+ if (!isValidBeforeClose(beforeClose)) {
+ beforeClose.setMaxClose(close);
+ beforeClose.setMinClose(close);
+ } else {
+ if (close.compareTo(beforeClose.getMaxClose()) > 0) {
+ beforeClose.setMaxClose(close);
}
- if (min == null || min.compareTo(BigDecimal.ZERO) <= 0) {
- min = latest;
- } else {
- min = min.min(latest);
+ if (beforeClose.getMinClose().compareTo(BigDecimal.ZERO) <= 0
+ || close.compareTo(beforeClose.getMinClose()) < 0) {
+ beforeClose.setMinClose(close);
}
}
- beforeClose.setMaxClose(max == null ? BigDecimal.ZERO : max);
- beforeClose.setMinClose(min == null ? BigDecimal.ZERO : min);
+ redisTemplate.opsForValue().set(RedisKeys.REAL_TIME_BEFORE_CLOSE + symbol + line, beforeClose);
}
- private BigDecimal extractAggregateValue(Map<String, Object> resultMap, String key) {
- if (resultMap == null || resultMap.isEmpty()) {
- return null;
+ private boolean isValidBeforeClose(BeforeClose beforeClose) {
+ return beforeClose != null
+ && beforeClose.getMaxClose() != null && beforeClose.getMaxClose().compareTo(BigDecimal.ZERO) > 0
+ && beforeClose.getMinClose() != null && beforeClose.getMinClose().compareTo(BigDecimal.ZERO) > 0;
+ }
+
+ private long normalizeToMillis(Long ts) {
+ if (ts == null) {
+ return System.currentTimeMillis();
}
- if (resultMap.containsKey(key)) {
- return convertToBigDecimal(resultMap.get(key));
- }
- for (Map.Entry<String, Object> entry : resultMap.entrySet()) {
- if (entry.getKey() != null && entry.getKey().equalsIgnoreCase(key)) {
- return convertToBigDecimal(entry.getValue());
- }
- }
- return null;
+ return String.valueOf(ts).length() <= 10 ? ts * 1000 : ts;
}
// 辅助方法:统一转换为BigDecimal,避免类型错误
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineInitServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineInitServiceImpl.java
index f487b7f..52a6b80 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineInitServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineInitServiceImpl.java
@@ -35,32 +35,27 @@
public void klineInit(String symbols) {
logger.info("当前开始初始化币对k线图: {}", symbols);
if (!symbols.contains(",")) {
- Item bySymbol = itemService.findBySymbol(symbols);
- if (Item.cryptos.equalsIgnoreCase(bySymbol.getType())) {
- cryptosKlineService.init(symbols);
- } else if ("1".equalsIgnoreCase(bySymbol.getFake())) {
- fakeKlineInitService.saveInit(symbols);
- } else {
- saveInit(symbols);
- }
+ initOne(symbols);
} else {
String[] symbolsArrays = symbols.split(",");
for (String symbol : symbolsArrays) {
threadPoolComponent.getExecutor().submit(() -> {
logger.info("当前开始初始化币对单个k线图: {}", symbol);
- Item bySymbol = itemService.findBySymbol(symbol);
- if (Item.cryptos.equalsIgnoreCase(bySymbol.getType())) {
- cryptosKlineService.init(symbol);
- } else if ("1".equalsIgnoreCase(bySymbol.getFake())) {
- fakeKlineInitService.saveInit(symbols);
- } else {
- saveInit(symbol);
- }
+ initOne(symbol);
logger.info("当前开始初始化完成币对k线图: {}", symbol);
});
-
}
+ }
+ }
+ private void initOne(String symbol) {
+ Item bySymbol = itemService.findBySymbol(symbol);
+ if (bySymbol.isFake()) {
+ fakeKlineInitService.saveInit(symbol);
+ } else if (Item.cryptos.equalsIgnoreCase(bySymbol.getType())) {
+ cryptosKlineService.init(symbol);
+ } else {
+ saveInit(symbol);
}
}
@@ -68,7 +63,7 @@
private final void saveInit(String symbol) {
Item bySymbol = itemService.findBySymbol(symbol);
// 机器人的价格,无需初始化
- if ("1".equalsIgnoreCase(bySymbol.getFake())) {
+ if (bySymbol.isFake()) {
return;
}
Map<String, List<Kline>> dailyWeekMonthHistoryMap = hobiDataService.getDailyWeekMonthHistory(symbol);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineServiceImpl.java
index 112215e..2f7a1e8 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/KlineServiceImpl.java
@@ -207,12 +207,11 @@
}
// 1分钟K线最新的5条数据,上个层级最近的几条数据
List<Kline> klineOneTop5 = new ArrayList<>(klineOne.subList(klineOne.size() - nums, klineOne.size()));
- Kline realtimeKline = klineOneTop5.get(klineOneTop5.size() - 1);
+ Kline realtimeKline = klineOneTop5.get(nums - 1);
if (realtimeKline == null) {
return null;
}
- long periodTs = klineOneTop5.get(0).getTs();
- if (latestSameLineKline != null && latestSameLineKline.getTs() >= periodTs) {
+ if (latestSameLineKline != null && latestSameLineKline.getTs() >= realtimeKline.getTs()) {
return null;
}
if (latestSameLineKline != null) {
@@ -222,8 +221,6 @@
if (klineOneTop5.isEmpty()) {
return null;
}
- periodTs = klineOneTop5.get(0).getTs();
- realtimeKline = klineOneTop5.get(klineOneTop5.size() - 1);
Double high = null;
Double low = null;
@@ -238,7 +235,7 @@
Kline kline = new Kline();
kline.setSymbol(symbol);
- kline.setTs(periodTs);
+ kline.setTs(realtimeKline.getTs());
if (latestSameLineKline != null) {
kline.setOpen(latestSameLineKline.getClose());
} else {
@@ -681,8 +678,13 @@
if (latestKilne != null && latestKilne.getTs() >= realtime.getTs()) {
return null;
}
- long lastKlineTs = latestKilne.getTs();
- realTimeList = realTimeList.stream().filter(r -> r.getTs() > lastKlineTs).collect(Collectors.toList());
+ if (latestKilne != null) {
+ long lastKlineTs = latestKilne.getTs();
+ realTimeList = realTimeList.stream().filter(r -> r.getTs() > lastKlineTs).collect(Collectors.toList());
+ }
+ if (realTimeList.isEmpty()) {
+ return null;
+ }
Double high = null;
Double low = null;
for (Realtime realTime : realTimeList) {
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
index 0bca53d..539d133 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
@@ -78,7 +78,7 @@
@Override
public List<Kline> kline(String symbol, String line) {
Item bySymbol = itemService.findBySymbol(symbol);
- if(Item.cryptos.equals(bySymbol.getType())){
+ if (Item.cryptos.equals(bySymbol.getType()) && !bySymbol.isFake()) {
return klineCryptos(symbol, line);
}
KlineTimeObject timeObject = DataCache.getKline(symbol, line);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline15MinuteJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline15MinuteJob.java
index 1efaac6..50c2ab8 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline15MinuteJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline15MinuteJob.java
@@ -36,7 +36,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_15MIN);
} else {
klineService.saveKline15Minute(item.getSymbol(), Kline.PERIOD_15MIN);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1DayJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1DayJob.java
index 95d484b..cd0b388 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1DayJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1DayJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_1DAY);
} else {
klineService.saveKline1Day(item.getSymbol(), Kline.PERIOD_1DAY);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MinuteJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MinuteJob.java
index 74eb006..f88dd55 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MinuteJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MinuteJob.java
@@ -38,7 +38,7 @@
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
//log.debug("--------------- 1min kline --------- {}", item.getSymbol());
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_1MIN);
} else {
klineService.saveKline1Minute(item.getSymbol(), Kline.PERIOD_1MIN);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MonJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MonJob.java
index 1751669..099e68f 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MonJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1MonJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_1MON);
} else {
klineService.saveKline1Mon(item.getSymbol(), Kline.PERIOD_1MON);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1QuarterJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1QuarterJob.java
index d94b4e0..fcf4b93 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1QuarterJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1QuarterJob.java
@@ -37,11 +37,10 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
continue;
- } else {
- klineService.saveKlineQuarter(item.getSymbol(), Kline.PERIOD_QUARTER);
}
+ klineService.saveKlineQuarter(item.getSymbol(), Kline.PERIOD_QUARTER);
}
stopWatch.stop();
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1WeekJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1WeekJob.java
index d327640..d15a48b 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1WeekJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1WeekJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_1WEEK);
} else {
klineService.saveKline1Week(item.getSymbol(), Kline.PERIOD_1WEEK);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1YearJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1YearJob.java
index 0a77889..22d246a 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1YearJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline1YearJob.java
@@ -37,11 +37,10 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
- continue;
- } else {
- klineService.saveKline1Mon(item.getSymbol(), Kline.PERIOD_YEAR);
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
+ continue;
}
+ klineService.saveKlineYear(item.getSymbol(), Kline.PERIOD_YEAR);
}
stopWatch.stop();
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline2HourJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline2HourJob.java
index 6a42b2e..a003443 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline2HourJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline2HourJob.java
@@ -37,11 +37,11 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType()) || Item.forex.equalsIgnoreCase(item.getType())) {
+ if (Item.forex.equalsIgnoreCase(item.getType())
+ || (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake())) {
continue;
- } else {
- klineService.saveKline2Hour(item.getSymbol(), Kline.PERIOD_2HOUR);
}
+ klineService.saveKline2Hour(item.getSymbol(), Kline.PERIOD_2HOUR);
}
}
stopWatch.stop();
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline30MinuteJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline30MinuteJob.java
index fb48326..caee92f 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline30MinuteJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline30MinuteJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_30MIN);
} else {
klineService.saveKline30Minute(item.getSymbol(), Kline.PERIOD_30MIN);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline4HourJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline4HourJob.java
index d086d6a..c015161 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline4HourJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline4HourJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_4HOUR);
} else {
klineService.saveKline4Hour(item.getSymbol(), Kline.PERIOD_4HOUR);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5DayJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5DayJob.java
index 6d0300e..f7c2e1b 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5DayJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5DayJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (!Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (!Item.cryptos.equalsIgnoreCase(item.getType()) || item.isFake()) {
klineService.saveKline5Day(item.getSymbol(), Kline.PERIOD_5DAY);
}
}
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5MinuteJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5MinuteJob.java
index 6a48f93..7dc336a 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5MinuteJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline5MinuteJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_5MIN);
} else {
klineService.saveKline5Minute(item.getSymbol(), Kline.PERIOD_5MIN);
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline60MinuteJob.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline60MinuteJob.java
index ea1e1d6..fcc3ef1 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline60MinuteJob.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/klinejob/Kline60MinuteJob.java
@@ -37,7 +37,7 @@
for (int i = 0; i < item_list.size(); i++) {
Item item = item_list.get(i);
if (MarketOpenChecker.isMarketOpenByItemCloseType(item.getOpenCloseType()) && item.getType().equals("cryptos")) {
- if (Item.cryptos.equalsIgnoreCase(item.getType())) {
+ if (Item.cryptos.equalsIgnoreCase(item.getType()) && !item.isFake()) {
cryptosKlineService.saveOne(item.getSymbol(), Kline.PERIOD_60MIN);
} else {
klineService.saveKline60Minute(item.getSymbol(), Kline.PERIOD_60MIN);
--
Gitblit v1.9.3