From c0b9a0978838536d21eeb4ab3ae5f29fa0d5dcc9 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 05 Jun 2024 15:36:46 +0800
Subject: [PATCH] 1

---
 src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java |   91 ++++++++++++++++++---------------------------
 1 files changed, 37 insertions(+), 54 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
index cb37e3b..1beba76 100644
--- a/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserStockSubscribeServiceImpl.java
@@ -1,13 +1,14 @@
 package com.nq.service.impl;
 
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.github.pagehelper.PageHelper;
 import com.github.pagehelper.PageInfo;
 import com.nq.common.ServerResponse;
-import com.nq.dao.StockSubscribeMapper;
-import com.nq.dao.UserMapper;
-import com.nq.dao.UserStockSubscribeMapper;
+import com.nq.dao.*;
+import com.nq.enums.EStockType;
+import com.nq.enums.EUserAssets;
 import com.nq.pojo.*;
 import com.nq.service.*;
 import com.nq.utils.timeutil.DateTimeUtil;
@@ -44,7 +45,8 @@
 
     @Resource
     UserMapper userMapper;
-
+    @Resource
+    AgentUserMapper agentUserMapper;
     @Autowired
     ISiteMessageService iSiteMessageService;
     @Autowired
@@ -59,6 +61,10 @@
     ISiteSettingService iSiteSettingService;
     @Autowired
     TradingHourServiceImpl tradingHourService;
+    @Resource
+    IUserAssetsServices iUserAssetsServices;
+    @Autowired
+    StockMapper stockMapper;
     /**
      * 用户新股申购
      * @param model
@@ -81,14 +87,8 @@
                 if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
                     return ServerResponse.createByErrorMsg("订单失败,请先实名认证",request);
                 }
-//                //判断休息日不能买入
-//                if (siteProduct.getHolidayDisplay()) {
-//                    return ServerResponse.createByErrorMsg("No trading on weekends or holidays!");
-//                }
-                //判断股票是否在可交易时间段
-                Boolean b = tradingHourService.timeCheck();
-                if (b) {
-                    return ServerResponse.createByErrorMsg("订单失败,不在股票交易时段",request);
+                if(new Date().before(stockSubscribe.getSubscribeTime())){
+                    return ServerResponse.createByErrorMsg("未到申购时间",request);
                 }
                 //重复申购限制
                 UserStockSubscribe userStockSubscribe = userStockSubscribeMapper.selectOne(new QueryWrapper<UserStockSubscribe>().eq("new_code", model.getNewCode()).eq("user_id", user.getId()));
@@ -101,9 +101,8 @@
                 if (stockSubscribe == null) {
                     return ServerResponse.createByErrorMsg("新的股票代码不存在",request);
                 }
-                if (model.getApplyNums() == null || model.getApplyNums() > stockSubscribe.getOrderNumber()|| model.getApplyNums() < 500) {
-                    return ServerResponse.createByErrorMsg("最小起订量是500,最大值"
-                            + stockSubscribe.getOrderNumber(),request);
+                if (model.getApplyNums() == null || model.getApplyNums() > stockSubscribe.getOrderNumber() || model.getApplyNums() < stockSubscribe.getMinOrderNumber()) {
+                    return ServerResponse.createByErrorMsg("申购失败,最小申购数量:"+stockSubscribe.getMinOrderNumber()+",最大申购数量:"+stockSubscribe.getOrderNumber(),request);
                 }
                 if (stockSubscribe.getType() == 2) {
                     int u = userMapper.updateById(user);
@@ -183,23 +182,7 @@
 
                     siteMessage.setAddTime(DateTimeUtil.getCurrentDate());
 
-
-                    if (stockSubscribe.getType() == 2){
-                        User user = userMapper.selectById(userStockSubscribe.getUserId());
-                        UserStockSubscribe userStockSubscribe1 = userStockSubscribeMapper.load(model.getId());
-                        int refundenum = userStockSubscribe1.getApplyNums() - model.getApplyNumber();
-//                        log.info("refundenum"+refundenum);
-                        Integer refund =refundenum * stockSubscribe.getPrice().intValue();
-//                        log.info("退还金额"+refund);
-                       int ret1 = userMapper.updateByPrimaryKey(user);
-                       if (ret1 <= 0) {
-                                return ServerResponse.createByErrorMsg("Application failed due to unknown reasons");
-                            }
-                        siteMessage.setContent("【新股申购中签】恭喜您,新股申购中签成功,申购金额:"+ userStockSubscribe.getBond() +"退还"+refund+",请及时关注哦。");
-                    }else {
-
-                        siteMessage.setContent("【新股申购中签】恭喜您,新股申购中签成功,申购金额:" + userStockSubscribe.getBond() + ",请及时关注哦。");
-                    }
+                    siteMessage.setContent("【新股申购中签】恭喜您,新股申购中签成功,申购金额:"+ userStockSubscribe.getBond() );
                     iSiteMessageService.insert(siteMessage);
                 }else
                 if(ret>0 && model.getStatus() == 2) {
@@ -279,7 +262,7 @@
         if(model!=null){
             //所有人发站内信
             if(model.getUserId() == 0){
-                List<User> users = this.userMapper.listByAdmin(null, null, null, null);
+                List<User> users = this.userMapper.listByAdmin(null, null, null, null,null);
                 for(int k=0;k<users.size();k++){
                     User user = users.get(k);
                     SiteMessage siteMessage = new SiteMessage();
@@ -367,39 +350,39 @@
                 return ServerResponse.createByErrorMsg("参数错误",request);
             }
             UserStockSubscribe userStockSubscribe = userStockSubscribeMapper.load(id);
-            log.info("userStockSubscribe:{}",userStockSubscribe);
             if (userStockSubscribe != null && userStockSubscribe.getUserId().equals(user.getId())) {
-                StockSubscribe stockSubscribe = stockSubscribeMapper.selectOne(new QueryWrapper<>(new StockSubscribe()).eq("code", userStockSubscribe.getNewCode()));
-                if(userStockSubscribe.getType()== 2 ){
+                StockSubscribe stockSubscribe = stockSubscribeMapper.selectOne(new QueryWrapper<>(new StockSubscribe())
+                        .eq("code", userStockSubscribe.getNewCode()));
+                if(userStockSubscribe.getStatus()== 2 ){
                     return ServerResponse.createByErrorMsg("未中签,无需支付",request);
                 }
-                //判断时间
-                if (stockSubscribe.getSubscriptionTime().getTime() < System.currentTimeMillis()) {
-                    return ServerResponse.createByErrorMsg("不在认缴时间之内",request);
+                if(null == stockSubscribe){
+                    return  ServerResponse.createByErrorMsg("新股不存在",request);
+                }
+                Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockCode, stockSubscribe.getCode()));
+                if(null == stock){
+                    return  ServerResponse.createByErrorMsg("股票不存在",request);
                 }
                 if (userStockSubscribe.getStatus() == 3) {
                     userStockSubscribe.setSubmitTime(DateTimeUtil.getCurrentDate());
                     userStockSubscribe.setStatus(4);
+                    BigDecimal bigDecimal =  iUserAssetsServices.
+                            getAvailableBalance(stock.getStockType(),
+                                    userStockSubscribe.getUserId());
 
-                    User user1 = userMapper.selectById(userStockSubscribe.getUserId());
-                    ret = userMapper.updateById(user1);
-                }
-                else {
+                    BigDecimal multiply = userStockSubscribe.getBuyPrice().multiply(new BigDecimal(userStockSubscribe.getApplyNumber()));
+                    if(bigDecimal.compareTo(multiply) < 0){
+                        return ServerResponse.createByErrorMsg("余额不足",request);
+                    }
+                    iUserAssetsServices.availablebalanceChange(stock.getStockType(),userStockSubscribe.getUserId(),
+                            EUserAssets.BUY,multiply.negate(),"","");
+                    userStockSubscribeMapper.update1(userStockSubscribe);
+                    return  ServerResponse.createBySuccess();
+                } else {
                     return ServerResponse.createByErrorMsg("不成功的申请者不收取任何费用",request);
                 }
             } else {
                 return ServerResponse.createByErrorMsg("新股认购订单不存在!",request);
-            }
-
-            if (ret > 0) {
-                ret = userStockSubscribeMapper.update1(userStockSubscribe);
-                if (ret > 0) {
-                    return ServerResponse.createBySuccessMsg("成功操作",request);
-                } else {
-                    return ServerResponse.createByErrorMsg("失败操作",request);
-                }
-            }else {
-                return ServerResponse.createByErrorMsg("扣除失败",request);
             }
         }
         return ServerResponse.createByErrorMsg("请先登录",request);

--
Gitblit v1.9.3