新版仿ok交易所-后端
1
zyy
2025-09-25 0b4c87807860c0bfff0759a5cdc736c80e5f5772
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
@@ -7,6 +7,7 @@
import com.yami.trading.common.config.RequestDataHelper;
import com.yami.trading.common.constants.Constants;
import com.yami.trading.common.util.DateUtils;
import com.yami.trading.huobi.data.AdjustmentValueCache;
import com.yami.trading.huobi.data.DataCache;
import com.yami.trading.huobi.hobi.HobiDataService;
import com.yami.trading.service.data.KlineDBService;
@@ -18,6 +19,7 @@
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcOperations;
import org.springframework.stereotype.Component;
import java.math.BigDecimal;
import java.util.*;
@Component
@@ -34,6 +36,19 @@
    private SysparaService sysparaService;
    @Autowired
    private NamedParameterJdbcOperations namedParameterJdbcTemplate;
    @Override
    public void init(String symbol) {
        this.bulid(symbol, Kline.PERIOD_1MIN);
        this.bulid(symbol, Kline.PERIOD_5MIN);
        this.bulid(symbol, Kline.PERIOD_15MIN);
        this.bulid(symbol, Kline.PERIOD_30MIN);
        this.bulid(symbol, Kline.PERIOD_60MIN);
        this.bulid(symbol, Kline.PERIOD_4HOUR);
        this.bulid(symbol, Kline.PERIOD_1DAY);
        this.bulid(symbol, Kline.PERIOD_1MON);
        this.bulid(symbol, Kline.PERIOD_1WEEK);
    }
    @Override
    public void saveInit(String symbol) {
@@ -55,6 +70,19 @@
    }
    public void bulid(String symbol, String line) {
        RequestDataHelper.set("symbol", symbol);
        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
                0);
        KlineTimeObject model = new KlineTimeObject();
        Collections.sort(list); // 按时间升序
        model.setKline(list);
        model.setLastTime(new Date());
        DataCache.putKline(symbol, line, model);
        RequestDataHelper.clear();
    }
    public void bulidInit(String symbol, String line) {
        RequestDataHelper.set("symbol", symbol);
        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, null,
@@ -68,6 +96,8 @@
        RequestDataHelper.clear();
    }
    @Override
    public void saveOne(String symbol, String line) {
@@ -87,12 +117,13 @@
        String key = symbol + "_" + line;
        Kline hobiOne = DataCache.getKline_hobi().get(key);
        if (hobiOne == null || lastOne == null) {
        /*if (hobiOne == null || lastOne == null) {
            logger.error("saveOne error, hobiOne is null,symbol [" + symbol + "]");
            // 取不到远程数据,直接退出
            return;
        }
        }*/
        RequestDataHelper.set("symbol", symbol);
        Kline kline = this.bulidKline(realtime, lastOne, hobiOne, line);
        Kline kline = this.bulidKline(realtime, lastOne, null, line);
        kline.setPeriod(line);
        klineDBService.save(kline);
@@ -124,8 +155,17 @@
        if (lastOne != null) {
            kline.setOpen(lastOne.getClose());
            kline.setHigh(lastOne.getHigh());
            kline.setLow(lastOne.getLow());
            if (realtime.getClose().compareTo(kline.getHigh()) > 0) {
                kline.setHigh(realtime.getClose());
            }
            if (realtime.getClose().compareTo(kline.getOpen()) < 0) {
                kline.setLow(realtime.getClose());
            }
        }
        int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
        /*int interval = this.sysparaService.find("data_interval").getInteger().intValue() / 1000;
        HighLow highLow = null;
        switch (line) {
@@ -169,9 +209,10 @@
        }
        if (highLow != null && highLow.getLow() != null) {
            kline.setLow(highLow.getLow());
        }
        }*/
        kline.setVolume(hobiOne.getVolume());
        //kline.setVolume(hobiOne.getVolume());
        return kline;
    }