From 53ba4cc2332e4704b26bc0945c93e58be84d654d Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Mon, 27 Oct 2025 17:59:55 +0800
Subject: [PATCH] 股票大宗购买审核

---
 trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java     |   62 +++++-
 trading-order-service/src/main/java/com/yami/trading/service/dz/StockDzService.java                |   12 +
 trading-order-service/src/main/java/com/yami/trading/dao/dz/StockDzMapper.java                     |   16 +
 trading-order-service/src/main/java/com/yami/trading/dao/dz/ExchangeApplyOrderDzMapper.java        |   10 +
 trading-order-bean/src/main/java/com/yami/trading/bean/dz/ExchangeApplyOrderDz.java                |   63 ++++++
 trading-order-service/src/main/resources/mapper/dz/StockDzMapper.xml                               |   43 ++++
 trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminStockDzController.java |   29 ++
 trading-order-bean/src/main/java/com/yami/trading/bean/dz/StockDz.java                             |   13 
 trading-order-bean/src/main/java/com/yami/trading/bean/dz/dto/ExchangeApplyOrderDzDto.java         |   22 ++
 trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java       |  281 ++++++++++++++++++++++++++-
 10 files changed, 511 insertions(+), 40 deletions(-)

diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminStockDzController.java b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminStockDzController.java
index e6a7f3b..6cd1058 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminStockDzController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminStockDzController.java
@@ -1,6 +1,9 @@
 package com.yami.trading.admin.controller.dz;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.yami.trading.bean.dz.StockDz;
+import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.domain.Result;
 import com.yami.trading.service.dz.StockDzService;
 import io.swagger.annotations.Api;
@@ -9,6 +12,7 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
 
 @RestController
 @CrossOrigin
@@ -30,7 +34,7 @@
     public Result getDzListByAdmin(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
                                    @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
                                    @RequestParam(value = "keywords", required = false)String keywords) {
-        return stockDzService.getDzListByAdmin(pageNum, pageSize, keywords);
+        return stockDzService.getDzListByAdmin(pageNum, pageSize, keywords, Constants.US_STOCKS);
     }
 
     /**
@@ -70,4 +74,27 @@
         return stockDzService.updByAdmin(model);
     }
 
+
+    @ApiOperation("大宗交易审核列表")
+    @RequestMapping({"getDzCheckList.do"})
+    @ResponseBody
+    public Result getDzCheckList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
+                                  @RequestParam(value = "pageSize", defaultValue = "15") int pageSize,
+                                  @RequestParam(value = "state", required = false) String state,
+                                  @RequestParam(value = "stockCode", required = false)String stockCode) {
+        return stockDzService.getDzCheckList(pageNum, pageSize, state, stockCode, Constants.US_STOCKS);
+    }
+
+    //大宗审核
+    @RequestMapping({"dzCheck.do"})
+    @ResponseBody
+    public Result check(@RequestParam(value = "id") String id,
+                                @RequestParam(value = "checkType") Integer checkType,
+                                @RequestParam(value = "orderNum") Double orderNum) {
+        if(checkType != 2 && (id == null || checkType == null || orderNum == null)){
+            return Result.failed("参数不能为空");
+        }
+        return stockDzService.dzCheck(id, checkType, orderNum);
+    }
+
 }
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
index fef3575..e5e5dbe 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
@@ -1,13 +1,19 @@
 package com.yami.trading.api.controller.dz;
 
+import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.exception.YamiShopBindException;
+import com.yami.trading.security.common.util.SecurityUtils;
 import com.yami.trading.service.dz.StockDzService;
 import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
 
 @RestController
 @CrossOrigin
@@ -19,6 +25,9 @@
     @Resource
     StockDzService stockDzService;
 
+    private static final ThreadLocal<Boolean> orderCreated = ThreadLocal.withInitial(() -> false);
+    private final Lock lock = new ReentrantLock();
+
     /**
      * 大宗交易 列表
      * @param pageNum
@@ -27,30 +36,63 @@
      * @param keyWords 搜索内容
      * @return
      */
+    @ApiOperation("大宗交易列表")
     @PostMapping({"getDzList.do"})
     @ResponseBody
     public Result getDzList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
                             @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
                             @RequestParam(value = "orderBy", required = false) String orderBy,
-                            @RequestParam(value = "keyWords", required = false) String keyWords,
-                            HttpServletRequest request) {
-        return stockDzService.getDzList(pageNum, pageSize, orderBy,keyWords , request);
+                            @RequestParam(value = "keyWords", required = false) String keyWords) {
+        return stockDzService.getDzList(pageNum, pageSize, orderBy,keyWords, Constants.US_STOCKS);
     }
+
+
+    /**
+     * 大宗下单
+     */
+    @RequestMapping({"buyStockDz.do"})
+    @ResponseBody
+    public Result buyDz(@RequestParam("dzId") String dzId, @RequestParam("password") String password,@RequestParam("num") double num) {
+        lock.lock();
+        try {
+            if (orderCreated.get()) {
+                throw new YamiShopBindException("当前交易人数过多,请稍后重试");
+            }
+            orderCreated.set(true);
+            String partyId = SecurityUtils.getCurrentUserId();
+            if (partyId == null || partyId.isEmpty()) {
+                throw new YamiShopBindException("请先登录");
+            }
+            return stockDzService.buyDz(dzId, password, num, partyId);
+        } catch (Exception e) {
+            log.error(e.getMessage());
+        }  finally{
+            lock.unlock();
+            orderCreated.set(false);
+        }
+        throw new YamiShopBindException("订单异常,请稍后重试");
+    }
+
+
 
 
     /**
      * 大宗交易订单列表
      * @param pageNum
      * @param pageSize
-     * @param status    状态 //0:待审核  1:成功 2:失败
+     * @param state
      * @return
-     */
-    /*@RequestMapping({"getDzOrderList.do"})
+    */
+    @ApiOperation("大宗交易订单列表")
+    @RequestMapping({"getDzOrderList.do"})
     @ResponseBody
     public Result getDzOrderList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
                                          @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
-                                         @RequestParam(value = "status", required = false) Integer status,
-                                         HttpServletRequest request) {
-        return iUserPositionService.getDzOrderList(pageNum, pageSize, status, request);
-    }*/
+                                         @RequestParam(value = "state", required = false) String state) {
+        String partyId = SecurityUtils.getCurrentUserId();
+        if (partyId == null || partyId.isEmpty()) {
+            throw new YamiShopBindException("请先登录");
+        }
+        return stockDzService.getDzOrderList(pageNum, pageSize, state, partyId, Constants.US_STOCKS);
+    }
 }
diff --git a/trading-order-bean/src/main/java/com/yami/trading/bean/dz/ExchangeApplyOrderDz.java b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/ExchangeApplyOrderDz.java
new file mode 100644
index 0000000..6d617c5
--- /dev/null
+++ b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/ExchangeApplyOrderDz.java
@@ -0,0 +1,63 @@
+package com.yami.trading.bean.dz;
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.yami.trading.common.domain.UUIDEntity;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.util.Date;
+
+@Data
+@TableName("t_exchange_apply_order_dz")
+public class ExchangeApplyOrderDz extends UUIDEntity {
+    private static final long serialVersionUID = -7263336511778693149L;
+    public final static String STATE_SUBMITTED = "submitted";
+    public final static String STATE_SUCCEED = "succeed";
+    public final static String STATE_FAILED = "failed";
+    public final static String OFFSET_OPEN = "open";
+    public final static String OFFSET_CLOSE = "close";
+    public final static String ORDER_PRICE_TYPE_LIMIT = "limit";
+    public final static String ORDER_PRICE_TYPE_OPPONENT = "opponent";
+
+    @ApiModelProperty("userId")
+    private String partyId;
+
+    @ApiModelProperty("关联dzid")
+    private String dzId;
+
+    @ApiModelProperty("订单号")
+    private String orderNo;
+
+    @ApiModelProperty("股票代码")
+    private String symbol;
+
+    @ApiModelProperty("币种数量")
+    private double symbolValue;
+
+    @ApiModelProperty("委托数量")
+    private Double volume;
+
+    @ApiModelProperty("手续费")
+    private double fee;
+
+    @ApiModelProperty("交易价格")
+    private Double price;
+
+    @ApiModelProperty("状态.submitted 已提交,succeed 成功, failed 失败")
+    private String state = "submitted";
+
+    private Date createTime;
+
+    /**
+     * 创建日期
+     */
+    @TableField(fill = FieldFill.INSERT)
+    private Long createTimeTs;
+
+    /**
+     * 更新日期
+     */
+    @TableField(fill = FieldFill.INSERT_UPDATE)
+    private Long updateTimeTs;
+}
diff --git a/trading-order-bean/src/main/java/com/yami/trading/bean/dz/StockDz.java b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/StockDz.java
index 0e4914b..0279839 100644
--- a/trading-order-bean/src/main/java/com/yami/trading/bean/dz/StockDz.java
+++ b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/StockDz.java
@@ -14,13 +14,14 @@
 @Data
 public class StockDz extends UUIDEntity {
 
+    private static final long serialVersionUID = 1L;
+
     private String stockName;
 
     private String stockCode;
 
+    //美股US_STOCKS  ETF indices
     private String stockType;
-
-    private String stockGid;
 
     private String stockSpell;
 
@@ -30,11 +31,6 @@
     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     private Date addTime;
 
-    /*点差费率*/
-    private BigDecimal spreadRate;
-
-    // 涨幅比例
-    private BigDecimal increaseRatio;
     //最小购买数量
     private Integer stockNum;
     @TableField(updateStrategy = FieldStrategy.IGNORED)
@@ -43,7 +39,6 @@
     private Date startTime;
     @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     private Date endTime;
-    private BigDecimal discount;
 
     /**
      * 周期
@@ -54,7 +49,7 @@
      * 大宗审核开关(0:关闭  1:打开)
      */
     private Integer switchType = 0;
-    private static final long serialVersionUID = 1L;
+
     //价格
     private BigDecimal nowPrice;
 
diff --git a/trading-order-bean/src/main/java/com/yami/trading/bean/dz/dto/ExchangeApplyOrderDzDto.java b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/dto/ExchangeApplyOrderDzDto.java
new file mode 100644
index 0000000..5a7f0bb
--- /dev/null
+++ b/trading-order-bean/src/main/java/com/yami/trading/bean/dz/dto/ExchangeApplyOrderDzDto.java
@@ -0,0 +1,22 @@
+package com.yami.trading.bean.dz.dto;
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.yami.trading.bean.dz.ExchangeApplyOrderDz;
+import com.yami.trading.common.domain.UUIDEntity;
+import io.swagger.annotations.ApiModelProperty;
+import io.swagger.annotations.ApiOperation;
+import lombok.Data;
+
+import java.util.Date;
+
+@Data
+public class ExchangeApplyOrderDzDto extends ExchangeApplyOrderDz {
+
+    @ApiModelProperty("用户名")
+    private String userName;
+
+    @ApiModelProperty("UID")
+    private String userCode;
+
+}
diff --git a/trading-order-service/src/main/java/com/yami/trading/dao/dz/ExchangeApplyOrderDzMapper.java b/trading-order-service/src/main/java/com/yami/trading/dao/dz/ExchangeApplyOrderDzMapper.java
new file mode 100644
index 0000000..1956f4d
--- /dev/null
+++ b/trading-order-service/src/main/java/com/yami/trading/dao/dz/ExchangeApplyOrderDzMapper.java
@@ -0,0 +1,10 @@
+package com.yami.trading.dao.dz;
+
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.yami.trading.bean.dz.ExchangeApplyOrderDz;
+
+
+public interface ExchangeApplyOrderDzMapper extends BaseMapper<ExchangeApplyOrderDz> {
+
+}
diff --git a/trading-order-service/src/main/java/com/yami/trading/dao/dz/StockDzMapper.java b/trading-order-service/src/main/java/com/yami/trading/dao/dz/StockDzMapper.java
index 668e84b..d22415d 100644
--- a/trading-order-service/src/main/java/com/yami/trading/dao/dz/StockDzMapper.java
+++ b/trading-order-service/src/main/java/com/yami/trading/dao/dz/StockDzMapper.java
@@ -12,9 +12,21 @@
     Page findStockTypeDz(Page page,
                          @Param("orderBy") String orderBy,
                          @Param("keyWords") String keyWords ,
-                         @Param("formatDate") String formatDate);
+                         @Param("formatDate") String formatDate,
+                         @Param("stockType") String stockType);
 
     Page getDzListByAdmin(Page page,
-                         @Param("keyWords") String keyWords);
+                          @Param("keyWords") String keyWords,
+                          @Param("stockType") String stockType);
+
+    Page getDzOrderList(Page page,
+                          @Param("state") String state,
+                          @Param("userId") String userId,
+                          @Param("stockType") String stockType);
+
+    Page getDzCheckList(Page page,
+                        @Param("state") String state,
+                        @Param("stockCode") String stockCode,
+                        @Param("stockType") String stockType);
 
 }
diff --git a/trading-order-service/src/main/java/com/yami/trading/service/dz/StockDzService.java b/trading-order-service/src/main/java/com/yami/trading/service/dz/StockDzService.java
index a3290ad..e128ca9 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/dz/StockDzService.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/dz/StockDzService.java
@@ -9,14 +9,22 @@
 public interface StockDzService extends IService<StockDz> {
 
 
-    Result getDzList(int pageNum, int pageSize, String orderBy, String keyWords, HttpServletRequest request);
+    Result getDzList(int pageNum, int pageSize, String orderBy, String keyWords, String stockType);
 
     Result addByAdmin(String stockCode, String stockNum, String password, String startTime, String endTime, String discount,Integer period,String nowPrice,Integer switchType);
 
-    Result getDzListByAdmin(int pageNum, int pageSize, String keywords);
+    Result getDzListByAdmin(int pageNum, int pageSize, String keywords, String stockType);
 
     Result updByAdmin(StockDz model);
 
     Result deleteByAdmin(String id);
 
+    Result getDzOrderList(int pageNum, int pageSize, String state, String userId, String stockType);
+
+    Result getDzCheckList(int pageNum, int pageSize, String state, String stockCode, String stockType);
+
+    Result buyDz(String dzId, String password, double num, String partyId);
+
+    Result dzCheck(String id, Integer checkType, double num);
+
 }
diff --git a/trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java b/trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java
index f217a6d..f57759a 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java
@@ -7,18 +7,37 @@
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.yami.trading.bean.dz.ExchangeApplyOrderDz;
 import com.yami.trading.bean.dz.StockDz;
+import com.yami.trading.bean.item.domain.Item;
+import com.yami.trading.bean.model.MoneyLog;
+import com.yami.trading.bean.model.User;
+import com.yami.trading.bean.model.Wallet;
+import com.yami.trading.bean.syspara.domain.Syspara;
+import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.exception.YamiShopBindException;
+import com.yami.trading.common.util.Arith;
+import com.yami.trading.common.util.RandomUtil;
+import com.yami.trading.dao.dz.ExchangeApplyOrderDzMapper;
 import com.yami.trading.dao.dz.StockDzMapper;
+import com.yami.trading.service.MoneyLogService;
+import com.yami.trading.service.WalletService;
 import com.yami.trading.service.dz.StockDzService;
+import com.yami.trading.service.item.ItemService;
+import com.yami.trading.service.syspara.SysparaService;
+import com.yami.trading.service.user.UserService;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 import java.math.BigDecimal;
+import java.util.Arrays;
 import java.util.Date;
-import java.util.List;
+import java.util.Objects;
 
 @Service
 @Slf4j
@@ -27,12 +46,30 @@
     @Resource
     private StockDzMapper stockDzMapper;
 
+    @Resource
+    private UserService userService;
+
+    @Resource
+    private SysparaService sysparaService;
+
+    @Resource
+    private WalletService walletService;
+
+    @Resource
+    private ExchangeApplyOrderDzMapper exchangeApplyOrderDzMapper;
+
+    @Resource
+    private MoneyLogService moneyLogService;
+
+    @Resource
+    private ItemService itemService;
+
     @Override
-    public Result getDzList(int pageNum, int pageSize, String orderBy, String keyWords,  HttpServletRequest request) {
+    public Result getDzList(int pageNum, int pageSize, String orderBy, String keyWords, String stockType) {
         try {
             String formatDate = DateUtil.format(new Date(), DatePattern.NORM_DATETIME_PATTERN);
             Page page = new Page(pageNum, pageSize);
-            stockDzMapper.findStockTypeDz(page,orderBy,keyWords,formatDate);
+            stockDzMapper.findStockTypeDz(page,orderBy,keyWords,formatDate, stockType);
             return Result.succeed(page);
         } catch (Exception e) {
             log.error(e.getMessage());
@@ -52,21 +89,19 @@
             return Result.failed("股票代码已存在");
         }
 
-
+        Item item = itemService.findBySymbol(stockCode);
+        if(item == null){
+            return Result.failed("不存在该股票");
+        }
 
         StockDz stockDz = new StockDz();
-        /*stockDz.setStockName(stock.getStockName());
-        stockDz.setStockCode(stock.getStockCode());
-        stockDz.setStockType(stock.getStockType());
-        stockDz.setStockGid(stock.getStockGid());
-        stockDz.setStockSpell(stock.getStockSpell());
-        stockDz.setIsLock(stock.getIsLock());
-        stockDz.setSpreadRate(stock.getSpreadRate());*/
-
-        stockDz.setStockCode(stockCode);
+        stockDz.setStockName(item.getSymbolFullName());
+        stockDz.setStockCode(item.getSymbol());
+        stockDz.setStockType(item.getType());
+        stockDz.setStockSpell(item.getSymbolData());
+        stockDz.setIsLock(1);
         stockDz.setIsShow(1);
         stockDz.setAddTime(new Date());
-        stockDz.setIncreaseRatio(BigDecimal.ZERO);
         stockDz.setStockNum(Integer.valueOf(stockNum));
         stockDz.setPassword(password);
         stockDz.setStartTime(DateUtil.parseDateTime(startTime));
@@ -82,10 +117,10 @@
     }
 
     @Override
-    public Result getDzListByAdmin(int pageNum, int pageSize, String Keywords) {
+    public Result getDzListByAdmin(int pageNum, int pageSize, String Keywords, String stockType) {
         try {
             Page page = new Page(pageNum, pageSize);
-            stockDzMapper.getDzListByAdmin(page, Keywords);
+            stockDzMapper.getDzListByAdmin(page, Keywords, stockType);
             return Result.succeed(page);
         } catch (Exception e) {
             log.error(e.getMessage());
@@ -101,6 +136,20 @@
         if(count > 0){
             return Result.failed("股票代码已存在");
         }
+
+        Item item = itemService.findBySymbol(model.getStockCode());
+        if(item == null){
+            return Result.failed("不存在该股票");
+        }
+
+        StockDz stockDz = stockDzMapper.selectById(model.getUuid());
+        if(stockDz == null){
+            return Result.failed("不存在该大宗信息");
+        }
+        model.setStockName(item.getSymbolFullName());
+        model.setStockCode(item.getSymbol());
+        model.setStockType(item.getType());
+        model.setStockSpell(item.getSymbolData());
         return stockDzMapper.updateById(model) > 0 ? Result.succeed("修改成功") : Result.failed("修改失败");
     }
 
@@ -113,6 +162,206 @@
         return Result.failed("删除失败");
     }
 
+    @Override
+    public Result getDzOrderList(int pageNum, int pageSize, String state, String userId, String stockType) {
+        try {
+            Page page = new Page(pageNum, pageSize);
+            stockDzMapper.getDzOrderList(page ,state, userId, stockType);
+            return Result.succeed(page);
+        } catch (Exception e) {
+            log.error(e.getMessage());
+        }
+        return Result.failed("获取失败");
+    }
+
+    @Override
+    public Result getDzCheckList(int pageNum, int pageSize, String state, String stockCode, String stockType) {
+        try {
+            Page page = new Page(pageNum, pageSize);
+            stockDzMapper.getDzCheckList(page ,state, stockCode, stockType);
+            return Result.succeed(page);
+        } catch (Exception e) {
+            log.error(e.getMessage());
+        }
+        return Result.failed("获取失败");
+    }
+
+    @Transactional
+    @Override
+    public Result buyDz(String dzId, String password, double num, String partyId) {
+        try {
+            if (num <= 0) {
+                throw new YamiShopBindException("请输入正确的货币数量");
+            }
+            User party = userService.getById(partyId);
+            if (!party.isEnabled()) {
+                throw new YamiShopBindException("用户已禁用");
+            }
+            Syspara syspara = sysparaService.find("stop_user_internet");
+            String stopUserInternet = syspara.getSvalue();
+            if (org.apache.commons.lang3.StringUtils.isNotEmpty(stopUserInternet)) {
+                String[] stopUsers = stopUserInternet.split(",");
+                if (Arrays.asList(stopUsers).contains(party.getUserName())) {
+                    throw new YamiShopBindException("无网络");
+                }
+            }
+
+
+            StockDz stockDz = this.stockDzMapper.selectOne(new QueryWrapper<StockDz>().eq("uuid", dzId));
+            if (stockDz == null) {
+                throw new YamiShopBindException("大宗不存在");
+            }
+            if (StringUtils.isNotEmpty(stockDz.getPassword()) && !Objects.equals(stockDz.getPassword(), password)) {
+                throw new YamiShopBindException("密码错误");
+            }
+            if (stockDz.getIsLock() != null && stockDz.getIsLock() != 0) {
+                throw new YamiShopBindException("股票被锁定,不能购买");
+            }
+
+            if(stockDz.getStartTime().getTime() > new Date().getTime() || stockDz.getEndTime().getTime() < new Date().getTime()){
+                throw new YamiShopBindException("不在内幕交易时间之内");
+            }
+            BigDecimal nowPrice = stockDz.getNowPrice();
+
+            if (nowPrice.compareTo(new BigDecimal("0")) == 0) {
+                throw new YamiShopBindException("股票价格0,请重试");
+            }
+            if (stockDz.getStockNum() > num) {
+                throw new YamiShopBindException("最小购买数据" + stockDz.getStockNum());
+            }
+
+            Wallet wallet = this.walletService.saveWalletByPartyId(partyId);
+            BigDecimal buyAmt = nowPrice.multiply(new BigDecimal(num));
+            //手续费比率
+            Double feeRate = sysparaService.find("exchange_apply_order_dz_buy_fee").getDouble();
+            BigDecimal orderFree = buyAmt.multiply(BigDecimal.valueOf(feeRate));
+            BigDecimal orderAmt = buyAmt.add(orderFree);
+            if (wallet.getMoney().compareTo(orderAmt) < 0) {
+                throw new YamiShopBindException("订单失败,资金不足");
+            }
+
+            BigDecimal amountBefore = wallet.getMoney();
+
+            ExchangeApplyOrderDz order = new ExchangeApplyOrderDz();
+            order.setPartyId(partyId);
+            order.setSymbol(stockDz.getStockCode());
+            order.setSymbolValue(num);
+            order.setVolume(buyAmt.doubleValue());
+            order.setPrice(nowPrice.doubleValue());
+            order.setOrderNo(com.yami.trading.common.util.DateUtil.getToday("yyMMddHHmmss") + RandomUtil.getRandomNum(8));
+            order.setFee(orderFree.doubleValue());
+            order.setCreateTime(new Date());
+
+
+            //判断审核开关
+            if(stockDz.getSwitchType() == 1) {
+                order.setState(ExchangeApplyOrderDz.STATE_SUBMITTED);
+                exchangeApplyOrderDzMapper.insert(order);
+                return Result.succeed("购买成功,等待审核");
+            }
+
+            order.setState(ExchangeApplyOrderDz.STATE_SUCCEED);
+            exchangeApplyOrderDzMapper.insert(order);
+            walletService.update(wallet.getUserId(), Arith.sub(0, orderAmt.doubleValue()));
+
+            //TODO 转持仓
+
+            MoneyLog log = new MoneyLog();
+            log.setCategory(Constants.MONEYLOG_CATEGORY_EXCHANGE);
+            String name = Constants.MONEYLOG_MAP.get(Constants.US_STOCKS);
+            String type2 = Constants.MONEYLOG_MAP_TYPE.get(Constants.US_STOCKS);
+            log.setAmountBefore(amountBefore);
+            log.setAmount(orderAmt.negate());
+            log.setAmountAfter(amountBefore.subtract(orderAmt));
+            log.setLog(name + type2 + "大宗交易买入" + ",订单号[" + order.getOrderNo() + "]");
+            log.setUserId(order.getPartyId());
+            log.setWalletType(Constants.WALLET);
+            log.setSymbol(stockDz.getStockCode());
+            log.setContentType(type2 + Constants.MONEYLOG_CONTENT_OPEN);
+            log.setCreateTime(new Date());
+            log.setUpdateTime(new Date());
+            moneyLogService.save(log);
+            return Result.succeed("购买成功");
+        } catch (Exception e) {
+            log.error(e.getMessage());
+        }
+        return Result.failed("操作失败");
+    }
+
+    @Transactional
+    @Override
+    public Result dzCheck(String id, Integer checkType, double orderNum) {
+        try {
+            ExchangeApplyOrderDz order = exchangeApplyOrderDzMapper.selectById(id);
+            if (order == null) {
+                throw new YamiShopBindException("订单不存在");
+            }
+            if (!order.getState().equals(ExchangeApplyOrderDz.STATE_SUBMITTED)) {
+                throw new YamiShopBindException("订单已审核");
+            }
+            //1.通过  2.拒绝
+            if (checkType == 2) {
+                order.setState(ExchangeApplyOrderDz.STATE_FAILED);
+                exchangeApplyOrderDzMapper.updateById(order);
+                throw new YamiShopBindException("审核成功");
+            }
+            if (orderNum > order.getSymbolValue()) {
+                throw new YamiShopBindException("输入数量大于用户买入数量");
+            }
+
+            StockDz stockDz = this.stockDzMapper.selectOne(new QueryWrapper<StockDz>().eq("id", order.getDzId()));
+            if (stockDz == null) {
+                throw new YamiShopBindException("大宗不存在");
+            }
+
+            BigDecimal nowPrice = stockDz.getNowPrice();
+            if (nowPrice.compareTo(new BigDecimal("0")) == 0) {
+                throw new YamiShopBindException("股票价格0,请重试");
+            }
+
+            Wallet wallet = this.walletService.saveWalletByPartyId(order.getPartyId());
+            BigDecimal buyAmt = nowPrice.multiply(new BigDecimal(orderNum));
+            //手续费比率
+            Double feeRate = sysparaService.find("exchange_apply_order_dz_buy_fee").getDouble();
+            BigDecimal orderFree = buyAmt.multiply(BigDecimal.valueOf(feeRate));
+            BigDecimal orderAmt = buyAmt.add(orderFree);
+            if (wallet.getMoney().compareTo(orderAmt) < 0) {
+                throw new YamiShopBindException("订单失败,资金不足");
+            }
+
+            BigDecimal amountBefore = wallet.getMoney();
+
+            order.setSymbolValue(orderNum);
+            order.setVolume(buyAmt.doubleValue());
+            order.setFee(orderFree.doubleValue());
+            order.setState(ExchangeApplyOrderDz.STATE_SUCCEED);
+            exchangeApplyOrderDzMapper.updateById(order);
+            walletService.update(wallet.getUserId(), Arith.sub(0, orderAmt.doubleValue()));
+
+            //TODO 转持仓
+
+
+            MoneyLog log = new MoneyLog();
+            log.setCategory(Constants.MONEYLOG_CATEGORY_EXCHANGE);
+            String name = Constants.MONEYLOG_MAP.get(Constants.US_STOCKS);
+            String type2 = Constants.MONEYLOG_MAP_TYPE.get(Constants.US_STOCKS);
+            log.setAmountBefore(amountBefore);
+            log.setAmount(orderAmt.negate());
+            log.setAmountAfter(amountBefore.subtract(orderAmt));
+            log.setLog(name + type2 + "大宗交易买入" + ",订单号[" + order.getOrderNo() + "]");
+            log.setUserId(order.getPartyId());
+            log.setWalletType(Constants.WALLET);
+            log.setSymbol(stockDz.getStockCode());
+            log.setContentType(type2 + Constants.MONEYLOG_CONTENT_OPEN);
+            log.setCreateTime(new Date());
+            log.setUpdateTime(new Date());
+            moneyLogService.save(log);
+            return Result.succeed("审核成功,订单已转客户持仓");
+        } catch (Exception e) {
+            log.error(e.getMessage());
+        }
+        return Result.failed("操作失败");
+    }
 
 
 }
diff --git a/trading-order-service/src/main/resources/mapper/dz/StockDzMapper.xml b/trading-order-service/src/main/resources/mapper/dz/StockDzMapper.xml
index 826b2d6..16ffc97 100644
--- a/trading-order-service/src/main/resources/mapper/dz/StockDzMapper.xml
+++ b/trading-order-service/src/main/resources/mapper/dz/StockDzMapper.xml
@@ -10,6 +10,10 @@
 
         WHERE start_time &lt; #{formatDate} AND end_time &gt; #{formatDate}
 
+        <if test="stockType != null and stockType != '' ">
+            AND stock_type = #{stockType}
+        </if>
+
         <if test="keyWords != null and keyWords != '' ">
             AND (stock_spell LIKE #{keyWords} OR stock_name LIKE #{keyWords})
         </if>
@@ -30,10 +34,49 @@
         *
         FROM t_stock_dz
         WHERE 1=1
+        <if test="stockType != null and stockType != '' ">
+            AND stock_type = #{stockType}
+        </if>
         <if test="keyWords != null and keyWords != '' ">
             AND (stock_code LIKE #{keyWords} OR stock_name LIKE #{keyWords})
         </if>
         ORDER BY  add_time DESC
     </select>
 
+    <select id="getDzOrderList" resultType="com.yami.trading.bean.dz.ExchangeApplyOrderDz" parameterType="map">
+        SELECT
+        *
+        FROM t_exchange_apply_order_dz
+        WHERE 1=1
+        <if test="stockType != null and stockType != '' ">
+            AND stock_type = #{stockType}
+        </if>
+        <if test="state != null and state != ''">
+            AND t.state = #{state}
+        </if>
+        <if test="userId != null and userId != '' ">
+            AND party_id = #{userId}
+        </if>
+        ORDER BY  create_time DESC
+    </select>
+
+    <select id="getDzCheckList" resultType="com.yami.trading.bean.dz.dto.ExchangeApplyOrderDzDto" parameterType="map">
+        SELECT
+        t.*,u.user_name,u.user_code,s.stock_type
+        FROM t_exchange_apply_order_dz t
+        LEFT JOIN tz_user u ON t.party_id = u.user_id
+        LEFT JOIN t_stock_dz s ON s.uuid = t.dz_id
+        WHERE 1=1
+        <if test="state != null and state != ''">
+            AND t.state = #{state}
+        </if>
+        <if test="stockCode != null and stockCode != '' ">
+            AND t.symbol = #{stockCode}
+        </if>
+        <if test="stockType != null and stockType != '' ">
+            AND s.stock_type = #{stockType}
+        </if>
+        ORDER BY  t.create_time DESC
+    </select>
+
 </mapper>

--
Gitblit v1.9.3