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