From ab127c54b099f9f8974b351f5ee5244614fece49 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 01 Oct 2024 19:54:06 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/service/impl/UserPositionServiceImpl.java |  144 +++++++++++++++++++++++++----------------------
 1 files changed, 76 insertions(+), 68 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index e8d6776..37e8285 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -339,6 +339,10 @@
         if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
             return ServerResponse.createByErrorMsg("请先缴清待补资金", request);
         }
+        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", userPosition.getStockCode()));
+        if(null == stock){
+            return ServerResponse.createByErrorMsg("股票不存在,平仓失败", request);
+        }
         Boolean b = tradingHourService.timeCheck(userPosition.getStockCode());
         if (!b) {
             return ServerResponse.createByErrorMsg("订单失败,不在交易时间之内", request);
@@ -365,7 +369,6 @@
         if (1 == userPosition.getIsLock().intValue()) {
             return ServerResponse.createByErrorMsg("this order is closed " + userPosition.getLockMsg());
         }
-        Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", userPosition.getStockCode()));
         if (!priceServices.isLimitDownSell(stock.getStockCode())) {
             return ServerResponse.createByErrorMsg("股票跌停,无法平仓", request);
         }
@@ -1223,7 +1226,7 @@
      * @Date: 2022/10/26
      */
     @Override
-    public ServerResponse newStockToPosition(Integer id) {
+    public ServerResponse newStockToPosition(Integer id,BigDecimal amountToBeCovered) {
         UserStockSubscribe userStockSubscribe = userStockSubscribeMapper.load(id);
         if (userStockSubscribe == null) {
             return ServerResponse.createByErrorMsg("无该申购记录");
@@ -1232,98 +1235,103 @@
         if (userStockSubscribe == null) {
             return ServerResponse.createByErrorMsg("该新股不存在");
         }
-        if (userStockSubscribe.getStatus() == 4 || userStockSubscribe.getStatus() == 3 && stockSubscribe.getType() == 2) {
-            Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockCode, userStockSubscribe.getNewCode()));
-            if(null == stock){
-                return ServerResponse.createByErrorMsg("该新股不存在");
-            }
-            UserPosition userPosition = new UserPosition();
-            userPosition.setPositionType(1);
-            userPosition.setPositionSn(KeyUtils.getUniqueKey());
-            userPosition.setUserId(userStockSubscribe.getUserId());
-            userPosition.setNickName(userStockSubscribe.getRealName());
-            userPosition.setAgentId(userStockSubscribe.getAgentId());
+
+        Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockCode, userStockSubscribe.getNewCode()));
+
+        UserPosition userPosition = new UserPosition();
+
+        if(null == stock){
+            userPosition.setStockCode(stockSubscribe.getCode());
+            userPosition.setStockSpell(stockSubscribe.getName());
+        }else{
             userPosition.setStockCode(stock.getStockCode());
             userPosition.setStockSpell(stock.getStockSpell());
-            userPosition.setStockName(userStockSubscribe.getNewName());
-            StringBuffer gid = new StringBuffer();
-            gid.append(stockSubscribe.getStockType()!=null?stockSubscribe.getStockType():"");
-            gid.append(userStockSubscribe.getNewCode()!=null?userStockSubscribe.getNewCode():"stock code invaild");
-            userPosition.setStockGid(gid.toString());
-            userPosition.setBuyOrderId(GeneratePosition.getPositionId());
-            userPosition.setBuyOrderTime(new Date());
-            userPosition.setBuyOrderPrice(userStockSubscribe.getBuyPrice());
-            userPosition.setOrderDirection("买涨");
+        }
 
-            userPosition.setOrderNum(userStockSubscribe.getApplyNumber());
+        userPosition.setPositionType(1);
+        userPosition.setPositionSn(KeyUtils.getUniqueKey());
+        userPosition.setUserId(userStockSubscribe.getUserId());
+        userPosition.setNickName(userStockSubscribe.getRealName());
+        userPosition.setAgentId(userStockSubscribe.getAgentId());
+
+        userPosition.setStockName(userStockSubscribe.getNewName());
+        StringBuffer gid = new StringBuffer();
+        gid.append(stockSubscribe.getStockType()!=null?stockSubscribe.getStockType():"");
+        gid.append(userStockSubscribe.getNewCode()!=null?userStockSubscribe.getNewCode():"stock code invaild");
+        userPosition.setStockGid(gid.toString());
+        userPosition.setBuyOrderId(GeneratePosition.getPositionId());
+        userPosition.setBuyOrderTime(new Date());
+        userPosition.setBuyOrderPrice(userStockSubscribe.getBuyPrice());
+        userPosition.setOrderDirection("买涨");
+
+        userPosition.setOrderNum(userStockSubscribe.getApplyNumber()*stockSubscribe.getLever().intValue());
 
 
-            userPosition.setIsLock(Integer.valueOf(0));
+        userPosition.setIsLock(Integer.valueOf(0));
 
 
-            userPosition.setOrderLever(1);
+        userPosition.setOrderLever(1);
 
 
-            //递延费特殊处理
-            //            BigDecimal stayFee = userPosition.getOrderTotalPrice().multiply(siteSetting.getStayFee());
-            BigDecimal stayFee = new BigDecimal(0);
-            BigDecimal allStayFee = stayFee.multiply(new BigDecimal(1));
-            userPosition.setOrderStayFee(allStayFee);
-            userPosition.setOrderStayDays(1);
-            userPosition.setOrderTotalPrice(userStockSubscribe.getBond());
+        //递延费特殊处理
+        //            BigDecimal stayFee = userPosition.getOrderTotalPrice().multiply(siteSetting.getStayFee());
+        BigDecimal stayFee = new BigDecimal(0);
+        BigDecimal allStayFee = stayFee.multiply(new BigDecimal(1));
+        userPosition.setOrderStayFee(allStayFee);
+        userPosition.setOrderStayDays(1);
+        userPosition.setOrderTotalPrice(userStockSubscribe.getBond());
 
-            //            BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
-            BigDecimal buy_fee_amt = new BigDecimal(0);
-            log.info("用户购买手续费(配资后总资金 * 百分比) = {}", buy_fee_amt);
-            userPosition.setOrderFee(buy_fee_amt);
+        //            BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
+        BigDecimal buy_fee_amt = new BigDecimal(0);
+        log.info("用户购买手续费(配资后总资金 * 百分比) = {}", buy_fee_amt);
+        userPosition.setOrderFee(buy_fee_amt);
 
 
-            //            BigDecimal buy_yhs_amt = buy_amt.multiply(siteSetting.getDutyFee()).setScale(2, 4);
-            BigDecimal buy_yhs_amt = new BigDecimal(0);
-            log.info("用户购买印花税(配资后总资金 * 百分比) = {}", buy_yhs_amt);
-            userPosition.setOrderSpread(buy_yhs_amt);
+        //            BigDecimal buy_yhs_amt = buy_amt.multiply(siteSetting.getDutyFee()).setScale(2, 4);
+        BigDecimal buy_yhs_amt = new BigDecimal(0);
+        log.info("用户购买印花税(配资后总资金 * 百分比) = {}", buy_yhs_amt);
+        userPosition.setOrderSpread(buy_yhs_amt);
 
-            BigDecimal spread_rate_amt = new BigDecimal(0);
-            userPosition.setSpreadRatePrice(spread_rate_amt);
+        BigDecimal spread_rate_amt = new BigDecimal(0);
+        userPosition.setSpreadRatePrice(spread_rate_amt);
 
 
-            BigDecimal profit_and_lose = new BigDecimal("0");
-            userPosition.setProfitAndLose(profit_and_lose);
+        BigDecimal profit_and_lose = new BigDecimal("0");
+        userPosition.setProfitAndLose(profit_and_lose);
 
 
-            BigDecimal all_profit_and_lose = profit_and_lose.subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);
-            userPosition.setAllProfitAndLose(all_profit_and_lose);
+        BigDecimal all_profit_and_lose = profit_and_lose.subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);
+        userPosition.setAllProfitAndLose(all_profit_and_lose);
 
 
-            userPosition.setOrderStayDays(Integer.valueOf(0));
-            userPosition.setOrderStayFee(new BigDecimal("0"));
-
-            int ret = 0;
-            ret = this.userPositionMapper.insert(userPosition);
-            UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId(stock.getStockType(), userPosition.getUserId());
-            if(null == userAssets){
-                return ServerResponse.createByErrorMsg("新股转持仓失败");
-            }
+        userPosition.setOrderStayDays(Integer.valueOf(0));
+        userPosition.setOrderStayFee(new BigDecimal("0"));
+        userPosition.setAmountToBeCovered(amountToBeCovered);
+        userPosition.setNewId(stockSubscribe.getNewlistId());
+        int ret = 0;
+        ret = this.userPositionMapper.insert(userPosition);
+        UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId("IN", userPosition.getUserId());
+        if(null == userAssets){
+            return ServerResponse.createByErrorMsg("新股转持仓失败");
+        }
 //            userAssets.setFreezeMoney(userAssets.getFreezeMoney().add(userPosition.getOrderTotalPrice()));
 //            userAssets.setFreezeMoney(userAssets.getFreezeMoney()!=null?userAssets.getFreezeMoney().setScale(2,BigDecimal.ROUND_UP):null);
-            userAssetsMapper.updateById(userAssets);
+        userAssetsMapper.updateById(userAssets);
+        if (ret > 0) {
+            userStockSubscribe.setStatus(5);
+            userStockSubscribeMapper.update1(userStockSubscribe);
+            if (userStockSubscribe.getType() == 1 || userStockSubscribe.getType() == 2) {
+                User user = userMapper.selectById(userStockSubscribe.getUserId());
+                ret = userMapper.updateById(user);
+            }
             if (ret > 0) {
-                userStockSubscribe.setStatus(5);
-                userStockSubscribeMapper.update1(userStockSubscribe);
-                if (userStockSubscribe.getType() == 1 || userStockSubscribe.getType() == 2) {
-                    User user = userMapper.selectById(userStockSubscribe.getUserId());
-                    ret = userMapper.updateById(user);
-                }
-                if (ret > 0) {
-                    return ServerResponse.createBySuccessMsg("新股转持仓成功");
-                } else {
-                    return ServerResponse.createByErrorMsg("新股转持仓失败");
-                }
+                return ServerResponse.createBySuccessMsg("新股转持仓成功");
             } else {
                 return ServerResponse.createByErrorMsg("新股转持仓失败");
             }
+        } else {
+            return ServerResponse.createByErrorMsg("新股转持仓失败");
         }
-        return ServerResponse.createByErrorMsg("新股转持仓失败");
     }
 
     /**

--
Gitblit v1.9.3