From f5e6133809c553cfd9fb28ee61019927c547c374 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 08 Dec 2021 15:58:33 +0800
Subject: [PATCH] 20211208  fish

---
 src/main/java/com/xcong/excoin/quartz/job/KLineGeneratorJob.java |   65 +++++++-------------------------
 1 files changed, 15 insertions(+), 50 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/quartz/job/KLineGeneratorJob.java b/src/main/java/com/xcong/excoin/quartz/job/KLineGeneratorJob.java
index 110c1fc..b6194ee 100644
--- a/src/main/java/com/xcong/excoin/quartz/job/KLineGeneratorJob.java
+++ b/src/main/java/com/xcong/excoin/quartz/job/KLineGeneratorJob.java
@@ -1,21 +1,18 @@
 package com.xcong.excoin.quartz.job;
 
-import com.alibaba.fastjson.JSON;
-import com.huobi.client.model.Candlestick;
+import com.xcong.excoin.modules.coin.entity.OrderCoinsDealEntity;
+import com.xcong.excoin.modules.coin.service.OrderCoinService;
 import com.xcong.excoin.processor.CoinProcessorFactory;
-import com.xcong.excoin.trade.TradePlateModel;
-import com.xcong.excoin.utils.RedisUtils;
-import com.xcong.excoin.websocket.TradePlateSendWebSocket;
 import lombok.extern.slf4j.Slf4j;
-import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
 import javax.annotation.Resource;
 import java.math.BigDecimal;
-import java.util.ArrayList;
+import java.math.RoundingMode;
 import java.util.Calendar;
-import java.util.List;
+import java.util.Random;
 
 /**
  * 生成各时间段的K线信息
@@ -23,50 +20,11 @@
  */
 @Component
 @Slf4j
+@ConditionalOnProperty(prefix = "app", name = "exchange-trade", havingValue = "true")
 public class KLineGeneratorJob {
     @Resource
     private CoinProcessorFactory processorFactory;
 
-    @Resource
-	private TradePlateSendWebSocket plateSendWebSocket;
-
-	@Resource
-	private RedisUtils redisUtils;
-
-	@Scheduled(cron = "0/2 * * * * *")
-    public void tradePlate(){
-		redisUtils.set("NEKK_NEW_PRICE",new BigDecimal(Math.random()));
-		Candlestick candlestick = new Candlestick();
-		candlestick.setOpen(new BigDecimal("10.33"));
-		candlestick.setHigh(new BigDecimal("15.23"));
-		candlestick.setVolume(new BigDecimal("12121.34"));
-		candlestick.setLow(new BigDecimal("8.234"));
-		candlestick.setAmount(new BigDecimal("1199"));
-		candlestick.setTimestamp(1599840000);
-		candlestick.setId(1599840000L);
-		candlestick.setCount(100002);
-		candlestick.setClose(new BigDecimal("12.2323"));
-		redisUtils.set("NEKK/USDT",candlestick);
-		// [[10244.21, 0.000855], [10243.7, 0.008777], [10243.59, 0.14], [10243.37, 0.467663]]
-		TradePlateModel tradePlateModel = new TradePlateModel();
-		List<BigDecimal> buy;
-		List<BigDecimal> sell;
-		for(int i=0;i<5;i++){
-			buy = new ArrayList<>(2);
-			buy.add(new BigDecimal(Math.random()*i));
-			buy.add(new BigDecimal(Math.random()*i));
-			tradePlateModel.getBuy().add(buy);
-			sell = new ArrayList<>(2);
-			sell.add(new BigDecimal(Math.random()*i*2));
-			sell.add(new BigDecimal(Math.random()*i*2));
-			tradePlateModel.getSell().add(sell);
-		}
-
-		plateSendWebSocket.sendMessagePlate(JSON.toJSONString(tradePlateModel),null);
-		plateSendWebSocket.sendMessageKline("nekkusdt","1min","{amount: 114419.67835656216,close: 2.7261,count: 782,high: 2.7299,id: 1599632100,low: 2.723,open: 2.7288,vol: 311958.06091543}",null);
-		plateSendWebSocket.sendMessageKline("nekkusdt","5min","{amount: 514419.67835656216,close: 2.7261,count: 782,high: 2.7299,id: 1599632100,low: 2.723,open: 2.7288,vol: 911958.06091543}",null);
-		plateSendWebSocket.sendMessageKline("nekkusdt","15min","{amount: 514419.67835656216,close: 2.7261,count: 782,high: 2.7299,id: 1599632100,low: 2.723,open: 2.7288,vol: 911958.06091543}",null);
-	}
 
     /**
      * 每分钟定时器,处理分钟K线
@@ -75,7 +33,7 @@
     public void handle5minKLine(){
 
         Calendar calendar = Calendar.getInstance();
-        log.debug("分钟K线:{}",calendar.getTime());
+        //log.debug("分钟K线:{}",calendar.getTime());
         //将秒、微秒字段置为0
         calendar.set(Calendar.SECOND,0);
         calendar.set(Calendar.MILLISECOND,0);
@@ -84,9 +42,10 @@
         int hour = calendar.get(Calendar.HOUR_OF_DAY);
         processorFactory.getProcessorMap().forEach((symbol,processor)->{
         	if(!processor.isStopKline()) {
-	            log.debug("生成{}分钟k线:{}",symbol);
+	            //log.debug("生成{}分钟k线:{}",symbol);
 	            //生成1分钟K线
 	            processor.autoGenerate();
+                processor.generateKLine(1, Calendar.MINUTE, time);
 	            //更新24H成交量
 	            processor.update24HVolume(time);
 	            if(minute%5 == 0) {
@@ -125,6 +84,11 @@
 	            long time = calendar.getTimeInMillis();
 	
 	            processor.generateKLine(1, Calendar.HOUR_OF_DAY, time);
+	            // 四小时K线
+				int hour = calendar.get(Calendar.HOUR_OF_DAY);
+				if(hour%4==0){
+					processor.generateKLine(4, Calendar.HOUR_OF_DAY, time);
+				}
         	}
         });
     }
@@ -156,4 +120,5 @@
         	}
         });
     }
+
 }

--
Gitblit v1.9.1