From aaad873de7e0e0eaedc1fa86f2e6160462ec692a Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Thu, 20 Nov 2025 14:36:04 +0800
Subject: [PATCH] 大宗开市时间

---
 trading-order-service/src/main/java/com/yami/trading/service/dz/impl/StockDzServiceImpl.java |   40 ++++++++++++++++++++++++++++++----------
 1 files changed, 30 insertions(+), 10 deletions(-)

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 10590c2..98d906f 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
@@ -12,6 +12,7 @@
 import com.yami.trading.bean.dz.ExchangeApplyOrderDz;
 import com.yami.trading.bean.dz.StockDz;
 import com.yami.trading.bean.dz.dto.ExchangeApplyOrderDzDto;
+import com.yami.trading.bean.dz.dto.StockDzDto;
 import com.yami.trading.bean.exchange.ExchangeApplyOrder;
 import com.yami.trading.bean.item.domain.Item;
 import com.yami.trading.bean.model.MoneyLog;
@@ -26,6 +27,7 @@
 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.MarketOpenChecker;
 import com.yami.trading.service.MoneyLogService;
 import com.yami.trading.service.WalletService;
 import com.yami.trading.service.data.DataService;
@@ -81,8 +83,14 @@
     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, stockType);
+            Page<StockDzDto> page = new Page<>(pageNum, pageSize);
+            page = stockDzMapper.findStockTypeDz(page,orderBy,keyWords,formatDate, stockType);
+            page.getRecords().forEach(stockDzDto -> {
+                Realtime realtime = this.dataService.realtime(stockDzDto.getStockCode()).get(0);
+                if (realtime != null) {
+                    stockDzDto.setCurrentPrice(realtime.getClose());
+                }
+            });
             return Result.succeed(page);
         } catch (Exception e) {
             log.error(e.getMessage());
@@ -96,8 +104,10 @@
             return Result.failed("参数不能为空");
         }
 
+        //该类型是否已添加
         Long count = stockDzMapper.selectCount(new LambdaQueryWrapper<StockDz>()
-                .eq(StockDz::getStockCode,stockCode));
+                .eq(StockDz::getStockCode,stockCode)
+                .eq(StockDz::getStockType,stockType));
         if(count > 0){
             return Result.failed("股票代码已存在");
         }
@@ -255,7 +265,7 @@
             }
 
             if(stockDz.getStartTime().getTime() > new Date().getTime() || stockDz.getEndTime().getTime() < new Date().getTime()){
-                throw new YamiShopBindException("不在内幕交易时间之内");
+                return Result.failed("不在内幕交易时间之内");
             }
             BigDecimal nowPrice = stockDz.getNowPrice();
 
@@ -263,8 +273,13 @@
                 throw new YamiShopBindException("股票价格0,请重试");
             }
             if (stockDz.getStockNum() > num) {
-                throw new YamiShopBindException("最小购买数量" + stockDz.getStockNum());
+                return Result.failed("请购买最小数量");
             }
+            boolean isOpen = MarketOpenChecker.isMarketOpenBuyDz(Item.US_STOCKS);
+            if (!isOpen) {
+                return Result.failed("当前股市休市");
+            }
+
 
             Wallet wallet = this.walletService.saveWalletByPartyId(partyId);
             BigDecimal buyAmt = nowPrice.multiply(new BigDecimal(num));
@@ -273,7 +288,7 @@
             BigDecimal orderFree = buyAmt.multiply(BigDecimal.valueOf(feeRate));
             BigDecimal orderAmt = buyAmt.add(orderFree);
             if (wallet.getMoney().compareTo(orderAmt) < 0) {
-                throw new YamiShopBindException("订单失败,资金不足");
+                return Result.failed("余额不足");
             }
 
             BigDecimal amountBefore = wallet.getMoney();
@@ -322,7 +337,7 @@
             return Result.succeed("购买成功");
         } catch (Exception e) {
             log.error(e.getMessage());
-            return Result.failed("操作失败:" + e.getMessage());
+            return Result.failed("失败");
         }
     }
 
@@ -477,8 +492,13 @@
                 Date resultTime = calendar.getTime();
 
                 if(now.getTime() < resultTime.getTime()){
-                    throw new YamiShopBindException("锁仓中");
+                    return Result.failed("未到平仓时间");
                 }
+            }
+
+            boolean isOpen = MarketOpenChecker.isMarketOpenByItemCloseType(Item.US_STOCKS);
+            if (!isOpen) {
+                return Result.failed("当前股市休市");
             }
 
             Wallet wallet = this.walletService.saveWalletByPartyId(order.getPartyId());
@@ -494,7 +514,7 @@
             //结算金额
             double closeAmt = closePrice * num - orderFree.doubleValue();
             if (closeAmt < 0) {
-                throw new YamiShopBindException("手续费资金不足");
+                return Result.failed("余额不足");
             }
 
             //拆分订单
@@ -542,7 +562,7 @@
             return Result.succeed("平仓成功");
         } catch (Exception e) {
             log.error(e.getMessage());
-            return Result.failed(e.getMessage());
+            return Result.failed("失败");
         }
     }
 

--
Gitblit v1.9.3