From cd969de1f50903ca87deda67bff2d6fcc35b4107 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Sun, 07 Jun 2026 02:42:32 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java | 64 +++++++++++++++-----------------
1 files changed, 30 insertions(+), 34 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
index d7af8ab..f8f8740 100644
--- a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
@@ -13,6 +13,7 @@
import com.nq.service.*;
import com.nq.utils.DateTimeUtil;
import com.nq.utils.KeyUtils;
+import com.nq.utils.UserFundUtil;
import com.nq.utils.PropertiesUtil;
import com.nq.utils.redis.CookieUtils;
import com.nq.utils.redis.JsonUtil;
@@ -98,7 +99,7 @@
String userJson = RedisShardedPoolUtils.get(header);
User user = this.iUserService.getCurrentRefreshUser(request);
if (user == null) {
- return ServerResponse.createBySuccessMsg("請先登錄");
+ return ServerResponse.createBySuccessMsg("请先登录");
}
if (model.getNewCode() != null) {
StockSubscribe stockSubscribe = stockSubscribeMapper.selectOne(new QueryWrapper<StockSubscribe>().eq("code", model.getNewCode()));
@@ -139,14 +140,15 @@
return ServerResponse.createByErrorMsg("申购失败,不在交易时段内");
}
- if (model.getApplyNums() == null || model.getApplyNums() > stockSubscribe.getOrderNumber() * 10000) {
- return ServerResponse.createByErrorMsg("购买数量异常或大于发行数量" + stockSubscribe.getOrderNumber() * 10000);
- }
+// if (model.getApplyNums() == null || model.getApplyNums() > stockSubscribe.getOrderNumber() * 10000) {
+// return ServerResponse.createByErrorMsg("购买数量异常或大于发行数量" + stockSubscribe.getOrderNumber() * 10000);
+// }
if (model.getType() == 2) {
if (user.getEnableAmt().compareTo(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice())) < 0) {
return ServerResponse.createByErrorMsg("用户可用余额不足,申购条件不满足");
}
- user.setEnableAmt(user.getEnableAmt().subtract(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice())));
+ BigDecimal applyAmt = new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice());
+ UserFundUtil.deductEnableAndWithdraw(user, applyAmt);
if (user.getDjzj() != null) {
user.setDjzj(user.getDjzj().add(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice())));
} else {
@@ -165,11 +167,15 @@
model.setPhone(user.getPhone());
model.setBuyPrice(stockSubscribe.getPrice());
- model.setBond(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice()));
+ model.setBond(BigDecimal.ZERO);
+ model.setApplyNums(0);
+
+// model.setBond(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice()));
model.setRealName(Objects.equals(user.getRealName(), "") || user.getRealName() == null ? "模拟用户无实名" : user.getRealName());
model.setAddTime(new Date());
model.setOrderNo(KeyUtils.getUniqueKey());
model.setType(model.getType());
+ model.setDiscountPrice(stockSubscribe.getPrice().multiply(stockSubscribe.getDiscount()).setScale(2, BigDecimal.ROUND_HALF_UP));
}
ret = userStockSubscribeMapper.insert(model);
@@ -210,10 +216,15 @@
// }
if (model.getStatus() == 3 && model.getApplyNumber() != null) {
- if (userStockSubscribe.getApplyNums() < model.getApplyNumber()) {
- return ServerResponse.createByErrorMsg("中签数量超过申购数量");
+// if (userStockSubscribe.getApplyNums() < model.getApplyNumber()) {
+// return ServerResponse.createByErrorMsg("中签数量超过申购数量");
+// }
+ if(null != userStockSubscribe.getDiscountPrice() && userStockSubscribe.getDiscountPrice().compareTo(BigDecimal.ZERO) > 0) {
+ model.setBond(userStockSubscribe.getDiscountPrice().multiply(BigDecimal.valueOf(model.getApplyNumber())));
+ }else {
+ model.setBond(userStockSubscribe.getBuyPrice().multiply(BigDecimal.valueOf(model.getApplyNumber())));
}
- model.setBond(userStockSubscribe.getBuyPrice().multiply(BigDecimal.valueOf(model.getApplyNumber())));
+
ret = userStockSubscribeMapper.update1(model);
} else if (model.getStatus() == 2) {
ret = userStockSubscribeMapper.update1(model);
@@ -241,7 +252,7 @@
Integer refund = refundenum * userStockSubscribe.getBuyPrice().intValue();
// log.info("退还金额"+refund);
user.setEnableAmt(user.getEnableAmt().add(BigDecimal.valueOf(refund)));
- user.setEnaleWithdrawAmt(user.getEnaleWithdrawAmt().add(BigDecimal.valueOf(refund)));
+ user.setEnaleWithdrawAmt((user.getEnaleWithdrawAmt() == null ? BigDecimal.ZERO : user.getEnaleWithdrawAmt()).add(BigDecimal.valueOf(refund)));
user.setDjzj(user.getDjzj().subtract(BigDecimal.valueOf(refund)));
int ret1 = userMapper.updateByPrimaryKey(user);
if (ret1 <= 0) {
@@ -266,7 +277,7 @@
iSiteMessageService.insert(siteMessage);
} else {
User user = userMapper.selectByPrimaryKey(userStockSubscribe.getUserId());
- user.setEnableAmt(user.getEnableAmt().add(userStockSubscribe.getBond()));
+ UserFundUtil.refundEnableAndWithdraw(user, userStockSubscribe.getBond());
user.setDjzj(user.getDjzj().subtract(userStockSubscribe.getBond()));
userMapper.updateByPrimaryKey(user);
SiteMessage siteMessage = new SiteMessage();
@@ -517,14 +528,13 @@
}
// log.info("原可用資金"+user1.getEnableAmt());
BigDecimal enableAmt = user1.getEnableAmt().subtract(userStockSubscribe.getBond());
- BigDecimal enaleWithdrawAmt = user1.getEnaleWithdrawAmt().subtract(userStockSubscribe.getBond());
- if (enaleWithdrawAmt.compareTo(userStockSubscribe.getBond()) < 0) {
- //若可取資金小於保證金,但是可用資金充足,則令當前可取資金為0
+ BigDecimal withdrawAmt = user1.getEnaleWithdrawAmt() == null ? BigDecimal.ZERO : user1.getEnaleWithdrawAmt();
+ BigDecimal bond = userStockSubscribe.getBond();
+ if (withdrawAmt.compareTo(bond) < 0) {
user1.setEnaleWithdrawAmt(BigDecimal.ZERO);
} else {
- user1.setEnaleWithdrawAmt(enaleWithdrawAmt);
+ user1.setEnaleWithdrawAmt(withdrawAmt.subtract(bond));
}
-// log.info("enableAmt" + enableAmt);
user1.setEnableAmt(enableAmt);
// log.info("可用資金" + user1.getEnableAmt()+"保證金"+userStockSubscribe.getBond()+"原djzj"+user1.getDjzj());
if (user1.getDjzj() != null) {
@@ -638,19 +648,7 @@
}
BigDecimal totalNewStockPrice = new BigDecimal(num).multiply(stockSubscribe.getPrice());
- user.setEnableAmt(user.getEnableAmt().subtract(totalNewStockPrice));
- BigDecimal user_enable_withdraw_amt = user.getEnaleWithdrawAmt();
- //修改用戶可取余額=當前可取余額-下單總金額
- int compareUserWithdrawAmtInt = user_enable_withdraw_amt.compareTo(totalNewStockPrice);
- if (compareUserWithdrawAmtInt == -1) {
- //若可取余額小於下單總額,但是可用余額充足,令可取余額為0
- user.setEnaleWithdrawAmt(BigDecimal.ZERO);
- } else {
- user_enable_withdraw_amt = user_enable_withdraw_amt.subtract(totalNewStockPrice);
- user.setEnaleWithdrawAmt(user_enable_withdraw_amt);
- }
-
- // if (user.getDjzj()!=null) {
+ UserFundUtil.deductEnableAndWithdraw(user, totalNewStockPrice);
// user.setDjzj(user.getDjzj().add(new BigDecimal(model.getApplyNums()).multiply(stockSubscribe.getPrice())));
// }else
// {
@@ -746,8 +744,7 @@
if (userStockSubscribe.getStatus() == 1) {
//审核失败退款
if ("2".equals(status)) {
- user.setEnableAmt(user.getEnableAmt().add(userStockSubscribe.getBond()));
- user.setEnaleWithdrawAmt(user.getEnaleWithdrawAmt().add(userStockSubscribe.getBond()));
+ UserFundUtil.refundEnableAndWithdraw(user, userStockSubscribe.getBond());
int ret = userMapper.updateById(user);
if (ret <= 0) {
return ServerResponse.createByErrorMsg("未知原因,审核失败");
@@ -805,7 +802,7 @@
userPosition.setOrderStayDays(1);
- BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
+ BigDecimal buy_fee_amt = com.nq.utils.TradeFeeUtil.calcBuyFee(buy_amt);
log.info("创建模拟持仓 手续费(配资后总资金 * 百分比) = {}", buy_fee_amt);
userPosition.setOrderFee(buy_fee_amt);
@@ -863,8 +860,7 @@
userStockSubscribe.setApplyNumber(Integer.valueOf(num));
this.userStockSubscribeMapper.updateById(userStockSubscribe);
BigDecimal reimburse = new BigDecimal(userStockSubscribe.getApplyNums() - Integer.parseInt(num)).multiply(userStockSubscribe.getBuyPrice());
- user.setEnableAmt(user.getEnableAmt().add(reimburse));
- user.setEnaleWithdrawAmt(user.getEnaleWithdrawAmt().add(reimburse));
+ UserFundUtil.refundEnableAndWithdraw(user, reimburse);
int ret = userMapper.updateById(user);
if (ret <= 0) {
return ServerResponse.createByErrorMsg("未知原因,审核失败");
--
Gitblit v1.9.3