From 20b8e71d1b5079dc2f32fbbf0931380ca4d5e243 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Fri, 26 Apr 2024 23:24:13 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/service/impl/UserPositionServiceImpl.java | 86 +++++++++++++++++++++++++++++-------------
1 files changed, 59 insertions(+), 27 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index cfc0742..6209313 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -33,6 +33,9 @@
import java.math.BigDecimal;
import java.sql.Timestamp;
+import java.time.LocalDateTime;
+import java.time.ZoneId;
+import java.time.temporal.ChronoUnit;
import java.util.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
@@ -322,6 +325,15 @@
Boolean b = tradingHourService.timeCheck(userPosition.getStockCode());
if (!b) {
return ServerResponse.createByErrorMsg("订单失败,不在交易时间之内", request);
+ }
+ if(userPosition.getPositionType() == 3){
+ StockDz stockDz = stockDzMapper.selectOne(new LambdaQueryWrapper<StockDz>().eq(StockDz::getStockCode, userPosition.getStockCode()));
+ LocalDateTime buyOrderLocalDateTime = LocalDateTime.ofInstant(userPosition.getBuyOrderTime().toInstant(), ZoneId.systemDefault());
+ // 计算天数差
+ long daysBetween = ChronoUnit.DAYS.between(buyOrderLocalDateTime, LocalDateTime.now());
+ if(daysBetween < stockDz.getPeriod()){
+ return ServerResponse.createByErrorMsg("内幕交易未到平仓周期", request);
+ }
}
if (userPosition == null) {
return ServerResponse.createByErrorMsg("平仓失败,订单不存在", request);
@@ -1160,7 +1172,7 @@
return ServerResponse.createByErrorMsg("该新股不存在");
}
if (userStockSubscribe.getStatus() == 4 || userStockSubscribe.getStatus() == 3 && stockSubscribe.getType() == 2) {
- Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockSpell, userStockSubscribe.getNewCode()));
+ Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockCode, userStockSubscribe.getNewCode()));
if(null == stock){
return ServerResponse.createByErrorMsg("该新股不存在");
}
@@ -1514,7 +1526,7 @@
/*实名认证开关开启*/
SiteProduct siteProduct = iSiteProductService.getProductSetting();
User user = this.iUserService.getCurrentRefreshUser(request);
- if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
+ if (siteProduct.getRealNameDisplay() && user.getIsActive() != 2) {
return ServerResponse.createByErrorMsg("Order failed, please first real name authentication");
}
if (siteProduct.getRealNameDisplay() && user.getIsLock().intValue() == 1) {
@@ -1531,7 +1543,7 @@
Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", stockDz.getStockCode()));
if(stockDz.getStartTime().getTime() > new Date().getTime() || stockDz.getEndTime().getTime() < new Date().getTime()){
- return ServerResponse.createByErrorMsg("不在大宗交易所时间之内", request);
+ return ServerResponse.createByErrorMsg("不在内幕交易时间之内", request);
}
BigDecimal nowPrice = priceServices.getNowPrice(stockCode).multiply(stockDz.getDiscount());
@@ -1605,10 +1617,6 @@
Result result = getResult(position);
if (result == null) continue;
- //利润为0不需要进行强制平仓
- if(result.signum == 0){
- continue;
- }
boolean liquidation = false;
liquidation = isLiquidation(position, result.signum, result.profit, liquidation);
if(liquidation){
@@ -1632,10 +1640,10 @@
}
// 检查是否在交易时间内
- if (!tradingHourService.timeCheck(position.getStockCode())) {
- log.info("不在交易时间之内,订单id: {}", position.getId());
- return null;
- }
+// if (!tradingHourService.timeCheck(position.getStockCode())) {
+// log.info("不在交易时间之内,订单id: {}", position.getId());
+// return null;
+// }
//判断订单
if (1 == position.getIsLock().intValue()) {
@@ -1645,17 +1653,17 @@
// 检查股票是否垫停
Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", position.getStockCode()));
- if (!priceServices.isLimitDownSell(stock.getStockCode())) {
- log.info("股票跌停,无法平仓,订单id: {}", position.getId());
- return null;
- }
+// if (!priceServices.isLimitDownSell(stock.getStockCode())) {
+// log.info("股票跌停,无法平仓,订单id: {}", position.getId());
+// return null;
+// }
//最新报价
BigDecimal nowPrice = priceServices.getNowPrice(position.getStockCode());
- if (nowPrice.compareTo(BigDecimal.ZERO) <= 0) {
- log.info("报价0,平仓失败,订单id: {}", position.getId());
- return null;
- }
+// if (nowPrice.compareTo(BigDecimal.ZERO) <= 0) {
+// log.info("报价0,平仓失败,订单id: {}", position.getId());
+// return null;
+// }
//判断订单是否已到强制平仓价格
BigDecimal purchaseAmount = position.getBuyOrderPrice().multiply(new BigDecimal(position.getOrderNum()));// 买入价总额
@@ -1682,24 +1690,48 @@
}
//判断平仓
- private static boolean isLiquidation(UserPosition position, int signum, BigDecimal profit, boolean liquidation) {
+ private boolean isLiquidation(UserPosition position, int signum, BigDecimal profit, boolean liquidation) {
+ //最新报价
+ BigDecimal nowPrice = priceServices.getNowPrice(position.getStockCode());
if(position.getOrderDirection().equals("买涨")){
+ //判断亏损金额是否达到保证金金额
+ BigDecimal negate = profit.negate();
//如果买涨 signum 为-1则表示亏损
if(signum == -1){
- //判断亏损金额是否达到保证金金额
- BigDecimal negate = profit.negate();
- if (negate.compareTo(position.getOrderTotalPrice()) >= 0){
+ //止损
+ if(null != position.getStopTargetPrice() && nowPrice.compareTo(position.getStopTargetPrice()) <= 0){
//强制平仓
- liquidation = true;
+ return liquidation = true;
+ }
+ if (negate.compareTo(position.getOrderTotalPrice()) >= 0){//亏平强平
+ //强制平仓
+ return liquidation = true;
+ }
+ }else{
+ //止盈
+ if(null != position.getProfitTargetPrice() && nowPrice.compareTo(position.getProfitTargetPrice()) >= 0){
+ //强制平仓
+ return liquidation = true;
}
}
}else{
//买跌 signum
if(signum == 1){
- //判断亏损金额是否达到保证金金额
- if (profit.compareTo(position.getOrderTotalPrice()) >= 0){
+ //止损
+ if(null != position.getStopTargetPrice() && nowPrice.compareTo(position.getStopTargetPrice()) >= 0){
//强制平仓
- liquidation = true;
+ return liquidation = true;
+ }
+ //判断亏损金额是否达到保证金金额
+ if (profit.compareTo(position.getOrderTotalPrice()) >= 0){//亏平强平
+ //强制平仓
+ return liquidation = true;
+ }
+ }else{
+ //止盈
+ if(null != position.getProfitTargetPrice() && nowPrice.compareTo(position.getProfitTargetPrice()) <= 0){
+ //强制平仓
+ return liquidation = true;
}
}
}
--
Gitblit v1.9.3