From 677c87ad5b0057a09381cfe023e857229aa770dd Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 04 Sep 2024 16:48:40 +0800
Subject: [PATCH] 1

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

diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index 607a4f6..c536946 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -135,7 +135,7 @@
 
 
     @Transactional
-    public ServerResponse buy(Integer stockId, Integer buyNum, Integer buyType, Integer lever, BigDecimal profitTarget, BigDecimal stopTarget,String password, HttpServletRequest request,Integer userId) {
+    public ServerResponse buy(Integer stockId, Integer buyNum, Integer buyType, Integer lever, BigDecimal profitTarget, BigDecimal stopTarget, HttpServletRequest request,Integer userId) {
 
         SiteProduct siteProduct = iSiteProductService.getProductSetting();
 
@@ -192,26 +192,26 @@
         if (nowPrice.compareTo(new BigDecimal("0")) == 0) {
             return ServerResponse.createByErrorMsg("报价0,请稍后再试", request);
         }
-        //vip抢筹
-        SiteSetting siteSetting = iSiteSettingService.getSiteSetting();
-        StockRealTimeBean stockRealTimeBean = RedisKeyUtil.getCacheRealTimeStock(stock);
-        BigDecimal pcp = new BigDecimal(stockRealTimeBean.getPcp());
-        SiteVipRob siteVipRob = iSiteVipRobService.getByStockCode(stock.getStockCode());
-        // 检查VIP抢筹功能是否开启且用户符合条件
-        if (null != siteVipRob && siteVipRob.getStatus() == 1 && pcp.compareTo(siteVipRob.getStockChg()) >= 0) {
-            // 检查密码是否为空
-            if (StringUtils.isBlank(password)) {
-                return ServerResponse.createByErrorMsg("VIP抢筹秘钥错误", request);
-            }
-            // 检查交易数量是否达到最低要求
-            if (buyNum < siteVipRob.getLowestTrade()) {
-                return ServerResponse.createByErrorMsg("VIP抢筹秘最低交易数量为" + siteVipRob.getLowestTrade(), request);
-            }
-            // 检查VIP密码是否正确
-            if (!siteSetting.getVipPassword().equals(password)) {
-                return ServerResponse.createByErrorMsg("VIP抢筹秘钥错误", request);
-            }
-        }
+//        //vip抢筹
+//        SiteSetting siteSetting = iSiteSettingService.getSiteSetting();
+//        StockRealTimeBean stockRealTimeBean = RedisKeyUtil.getCacheRealTimeStock(stock);
+//        BigDecimal pcp = new BigDecimal(stockRealTimeBean.getPcp());
+//        SiteVipRob siteVipRob = iSiteVipRobService.getByStockCode(stock.getStockCode());
+//        // 检查VIP抢筹功能是否开启且用户符合条件
+//        if (null != siteVipRob && siteVipRob.getStatus() == 1 && pcp.compareTo(siteVipRob.getStockChg()) >= 0) {
+//            // 检查密码是否为空
+//            if (StringUtils.isBlank(password)) {
+//                return ServerResponse.createByErrorMsg("VIP抢筹秘钥错误", request);
+//            }
+//            // 检查交易数量是否达到最低要求
+//            if (buyNum < siteVipRob.getLowestTrade()) {
+//                return ServerResponse.createByErrorMsg("VIP抢筹秘最低交易数量为" + siteVipRob.getLowestTrade(), request);
+//            }
+//            // 检查VIP密码是否正确
+//            if (!siteSetting.getVipPassword().equals(password)) {
+//                return ServerResponse.createByErrorMsg("VIP抢筹秘钥错误", request);
+//            }
+//        }
         BigDecimal buyAmt = nowPrice.multiply(new BigDecimal(buyNum)).divide(new BigDecimal(lever));
         BigDecimal orderFree = siteSettingBuyFee.multiply(buyAmt);
 
@@ -1682,7 +1682,7 @@
 
         userPosition.setOrderSpread(BigDecimal.ZERO);
         userPositionMapper.insert(userPosition);
-        userAssetsServices.availablebalanceChange(EStockType.IN.getCode(), user.getId(), EUserAssets.BUY, buyAmt.negate(),"","");
+        userAssetsServices.availablebalanceChange(stockDz.getStockType(), user.getId(), EUserAssets.BUY, buyAmt.negate(),"","");
         return ServerResponse.createBySuccess("购买成功", request);
     }
 
@@ -1738,10 +1738,14 @@
         BigDecimal pcp = new BigDecimal(stockRealTimeBean.getPcp());
         //涨停板配置
         //组装需要查询的key
-        String[] keysArray = new String[]{"limit_up_point","limit_up_is_buy"};
+        String[] keysArray = new String[]{EConfigKey.LIMIT_UP_INTERVAL.getCode(),EConfigKey.LIMIT_UP_IS_BUY.getCode()};
         List<String> keysList = Arrays.asList(keysArray);
         Map<String, StockConfig> stockConfigs = stockConfigServices.queryByKeys(keysList);
-        if(null != stockConfigs && "1".equals(stockConfigs.get("limit_up_is_buy").getCValue()) && pcp.compareTo(new BigDecimal(stockConfigs.get("limit_up_is_buy").getCValue())) >= 0){
+        if(null != stockConfigs && "1".equals(stockConfigs.get(EConfigKey.LIMIT_UP_IS_BUY.getCode()).getCValue())){
+            //判断区间
+            if(!isInAnyInterval(pcp, stockConfigs.get(EConfigKey.LIMIT_UP_INTERVAL.getCode()).getCValue())){
+                return 0;
+            }
             //插入购买申请
             UserPurchaseApplication purchaseApplication = new UserPurchaseApplication();
             purchaseApplication.setStockCode(stock.getStockCode());
@@ -1770,6 +1774,30 @@
         return 0;
     }
 
+    public boolean isInAnyInterval(BigDecimal pcp, String intervals) {
+        if(intervals.indexOf(",")>0){
+            String[] intervalArray = intervals.split(",");
+            for (String interval : intervalArray) {
+                if (isInSingleInterval(pcp, interval.trim())) {
+                    return true;
+                }
+            }
+        }else {
+            if (isInSingleInterval(pcp, intervals.trim())) {
+                return true;
+            }
+        }
+        return false;
+    }
+
+    public boolean isInSingleInterval(BigDecimal pcp, String interval) {
+        String[] parts = interval.split("-");
+        BigDecimal start = new BigDecimal(parts[0].trim());
+        BigDecimal end = new BigDecimal(parts[1].trim());
+
+        return pcp.compareTo(start) >= 0 && pcp.compareTo(end) <= 0;
+    }
+
     private Result getResult(UserPosition position) {
         // 检查订单是否存在
         if (position == null) {

--
Gitblit v1.9.3