From 8318f10556a4b0e093fbbb4055c5646bcb49e2ba Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Tue, 26 Jan 2021 11:45:40 +0800
Subject: [PATCH] modify
---
src/main/java/com/xcong/excoin/rabbit/pricequeue/WebsocketPriceService.java | 28 ++++++++++++++++++----------
1 files changed, 18 insertions(+), 10 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/rabbit/pricequeue/WebsocketPriceService.java b/src/main/java/com/xcong/excoin/rabbit/pricequeue/WebsocketPriceService.java
index 0d302c2..ed20d89 100644
--- a/src/main/java/com/xcong/excoin/rabbit/pricequeue/WebsocketPriceService.java
+++ b/src/main/java/com/xcong/excoin/rabbit/pricequeue/WebsocketPriceService.java
@@ -1,6 +1,8 @@
package com.xcong.excoin.rabbit.pricequeue;
import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.map.MapUtil;
+import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson.JSONObject;
import com.xcong.excoin.common.contants.AppContants;
import com.xcong.excoin.common.enumerates.CoinTypeEnum;
@@ -289,13 +291,11 @@
if (CollUtil.isNotEmpty(holdOrderEntities)) {
BigDecimal totalProfitOrLess = BigDecimal.ZERO;
- String currentPrice = null;
+ Map<String, Object> priceMap = new HashMap<>();
for (ContractHoldOrderEntity holdOrderEntity : holdOrderEntities) {
- if (symbol.equalsIgnoreCase(holdOrderEntity.getSymbol())) {
- currentPrice = price;
- } else {
- currentPrice = redisUtils.getString(CoinTypeConvert.convertToKey(holdOrderEntity.getSymbol()));
- }
+ String currentPrice = redisUtils.getString(CoinTypeConvert.convertToKey(holdOrderEntity.getSymbol()));
+ priceMap.put(holdOrderEntity.getSymbol(), currentPrice);
+
BigDecimal lotNumber = cacheSettingUtils.getSymbolSku(holdOrderEntity.getSymbol());
BigDecimal profitOrLess = CalculateUtil.calOrderProfitOrLess(holdOrderEntity.getOpeningType(), new BigDecimal(currentPrice), holdOrderEntity.getOpeningPrice(), lotNumber, holdOrderEntity.getSymbolCntSale(), memberEntity.getIsProfit());
totalProfitOrLess = totalProfitOrLess.add(profitOrLess);
@@ -303,15 +303,23 @@
MemberWalletContractEntity wallet = memberWalletContractDao.findWalletContractByMemberIdAndSymbol(memberId, CoinTypeEnum.USDT.name());
BigDecimal sub = wallet.getTotalBalance().add(totalProfitOrLess);
-// log.info("sub : {}, memberId : {}", sub, memberId);
- if (sub.compareTo(BigDecimal.ZERO) <= 0) {
+ BigDecimal target = wallet.getTotalBalance().multiply(BigDecimal.valueOf(0.01));
+// log.info("sub : {}, target : {}", sub, target);
+ if (sub.compareTo(target) <= 0) {
List<OrderModel> list = new ArrayList<>();
OrderModel orderModel = new OrderModel(null, 0, price, symbol, memberId);
list.add(orderModel);
String content = JSONObject.toJSONString(list);
- orderProducer.sendWholeBomb(content);
- contractHoldOrderDao.updateMemberAllHoldOrderClosingStatus(memberId);
+ String key = AppContants.WHOLE_BOMB_PREFIX + memberId;
+ Map<Object, Object> value = redisUtils.hmget(key);
+ if (MapUtil.isEmpty(value)) {
+ log.info("priceMap -- {}", priceMap);
+ orderProducer.sendWholeBomb(content);
+ contractHoldOrderDao.updateMemberAllHoldOrderClosingStatus(memberId);
+
+ redisUtils.hmset(key, priceMap);
+ }
}
}
}
--
Gitblit v1.9.1