From 4046f94a57f0c10e9509a49ad0d37d701aeb8186 Mon Sep 17 00:00:00 2001
From: jack <zengjieli93@163.com>
Date: Tue, 02 Apr 2024 23:47:51 +0800
Subject: [PATCH] 修复自选bug 和 增加流水日志
---
src/main/java/com/nq/service/impl/UserPositionServiceImpl.java | 492 +++++++++++-------------------------------------------
1 files changed, 102 insertions(+), 390 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
index d07d1cd..8560221 100644
--- a/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserPositionServiceImpl.java
@@ -1,9 +1,8 @@
package com.nq.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.google.gson.Gson;
import com.nq.dao.*;
-import com.nq.enums.EStockType;
+import com.nq.enums.EUserAssets;
import com.nq.pojo.*;
import com.nq.service.*;
import com.github.pagehelper.PageHelper;
@@ -11,14 +10,13 @@
import com.google.common.collect.Lists;
import com.nq.common.ServerResponse;
import com.nq.utils.*;
-import com.nq.utils.redis.RedisShardedPoolUtils;
import com.nq.utils.stock.BuyAndSellUtils;
import com.nq.utils.stock.GeneratePosition;
import com.nq.utils.stock.GetStayDays;
import com.nq.utils.stock.pinyin.GetPyByChinese;
import com.nq.utils.stock.sina.StockApi;
+import com.nq.utils.timeutil.DateTimeUtil;
import com.nq.vo.agent.AgentIncomeVO;
-import com.nq.vo.foreigncurrency.ExchangeVO;
import com.nq.vo.position.AdminPositionVO;
import com.nq.vo.position.AgentPositionVO;
import com.nq.vo.position.PositionProfitVO;
@@ -33,6 +31,7 @@
import java.math.BigDecimal;
import java.sql.Timestamp;
import java.util.*;
+import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.lang3.StringUtils;
@@ -44,11 +43,14 @@
private static final Logger log = LoggerFactory.getLogger(UserPositionServiceImpl.class);
- @Autowired
+ @Resource
UserPositionMapper userPositionMapper;
@Autowired
IUserService iUserService;
+
+ @Autowired
+ IUserAssetsServices userAssetsServices;
@Autowired
ISiteSettingService iSiteSettingService;
@@ -59,16 +61,16 @@
@Autowired
IStockService iStockService;
- @Autowired
+ @Resource
UserMapper userMapper;
- @Autowired
+ @Resource
UserCashDetailMapper userCashDetailMapper;
@Autowired
IAgentUserService iAgentUserService;
- @Autowired
+ @Resource
AgentUserMapper agentUserMapper;
- @Autowired
+ @Resource
SiteTaskLogMapper siteTaskLogMapper;
@Autowired
StockMapper stockMapper;
@@ -83,9 +85,9 @@
FundsApplyMapper fundsApplyMapper;
@Autowired
UserStockSubscribeMapper userStockSubscribeMapper;
- @Autowired
+ @Resource
StockSubscribeMapper stockSubscribeMapper;
- @Autowired
+ @Resource
UserIndexPositionMapper userIndexPositionMapper;
@Autowired
@@ -94,17 +96,18 @@
IStockCoinService iStockCoinService;
@Autowired
CurrencyUtils currencyUtils;
- @Autowired
+ @Resource
StockDzMapper stockDzMapper;
+
+ @Autowired
+ IUserAssetsServices iUserAssetsServices;
+
+ @Autowired
+ TradingHourServiceImpl tradingHourService;
@Transactional
public ServerResponse buy(Integer stockId, Integer buyNum, Integer buyType, Integer lever, BigDecimal profitTarget, BigDecimal stopTarget, HttpServletRequest request) throws Exception {
- // 判断周末不能买
- Date today = new Date();
- Calendar c = Calendar.getInstance();
- c.setTime(today);
- /*实名认证开关开启*/
SiteProduct siteProduct = iSiteProductService.getProductSetting();
User user = this.iUserService.getCurrentRefreshUser(request);
@@ -112,11 +115,11 @@
return ServerResponse.createByErrorMsg("Order failed, please first real name authentication");
}
- log.info("用户 {} 下单,股票id = {} ,数量 = {} , 方向 = {} , 杠杆 = {}", user
- .getId(), stockId, buyNum, buyType, lever);
+
if (siteProduct.getRealNameDisplay() && user.getIsLock().intValue() == 1) {
return ServerResponse.createByErrorMsg("Order failed, account has been locked");
}
+
SiteSetting siteSetting = this.iSiteSettingService.getSiteSetting();
if (siteSetting == null) {
log.error("下单出错,网站设置表不存在");
@@ -124,111 +127,38 @@
}
Stock stock = stockMapper.selectByPrimaryKey(stockId);
- log.info("当前股票信息 {}", new Gson().toJson(stock));
if (stock == null) {
return ServerResponse.createByErrorMsg("Order failed, stock code error");
}
-
- BigDecimal userEnableAmt;
- if (stock.getStockType().equals(EStockType.US.getCode())) {
- userEnableAmt = user.getEnableIndexAmt();
- } else {
- userEnableAmt = user.getEnableAmt();
- }
- if (Objects.equals(stock.getStockType(), EStockType.US.getCode())) {
- if (buyNum < siteSetting.getDzMinByCount()) {
- return ServerResponse.createByErrorMsg("Minimum purchase for bulk commodities " + siteSetting.getDzMinByCount());
- }
-
- String am_begin = siteSetting.getTransAmBeginUs();
- String am_end = siteSetting.getTransAmEndUs();
- String pm_begin = siteSetting.getTransPmBeginUs();
- String pm_end = siteSetting.getTransPmEndUs();
- boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
- boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
- log.info("是否在上午交易时间 = {} 是否在下午交易时间 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
- if (!am_flag && !pm_flag) {
- return ServerResponse.createByErrorMsg("Order failed, not in the stock trading session");
- }
- } else {
- String am_begin = siteSetting.getTransAmBegin();
- String am_end = siteSetting.getTransAmEnd();
- String pm_begin = siteSetting.getTransPmBegin();
- String pm_end = siteSetting.getTransPmEnd();
- boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
- boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
- log.info("是否在上午交易时间 = {} 是否在下午交易时间 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
-
- if (!am_flag && !pm_flag) {
- return ServerResponse.createByErrorMsg("Order failed, out of trading hours");
- }
- if (siteProduct.getHolidayDisplay()) {
- return ServerResponse.createByErrorMsg("No trading on weekends or holidays!");
- }
+ //判断股票是否在可交易时间段
+ Boolean b = tradingHourService.timeCheck();
+ if (!b) {
+ return ServerResponse.createByErrorMsg("Order failed, not in the stock trading session");
}
- if (stock.getIsLock().intValue() != 0) {
+ if (stock.getIsLock() != 0) {
return ServerResponse.createByErrorMsg("Order failed, shares cannot be traded at present");
}
- List dbPosition = findPositionByStockCodeAndTimes(siteSetting.getBuySameTimes().intValue(), stock
- .getStockCode(), user.getId());
- if (dbPosition.size() >= siteSetting.getBuySameNums().intValue()) {
- return ServerResponse.createByErrorMsg("Frequent trading," + siteSetting.getBuySameTimes() + "Hold no more than one stock within a minute" + siteSetting
- .getBuySameNums() + "article");
- }
-
- Integer transNum = findPositionNumByTimes(siteSetting.getBuyNumTimes().intValue(), user.getId());
- if (transNum.intValue() / 100 >= siteSetting.getBuyNumLots().intValue()) {
- return ServerResponse.createByErrorMsg("Frequent trading," + siteSetting
- .getBuyNumTimes() + "Hold no more than one stock within a minute" + siteSetting.getBuyNumLots() + "hand");
- }
-
- if (buyNum.intValue() < siteSetting.getBuyMinNum().intValue()) {
- return ServerResponse.createByErrorMsg("Order failed, purchase quantity is less than" + siteSetting
- .getBuyMinNum() + "股");
- }
- if (buyNum.intValue() > siteSetting.getBuyMaxNum().intValue()) {
- return ServerResponse.createByErrorMsg("Order failed, purchase quantity is greater than于" + siteSetting
- .getBuyMaxNum() + "stocks");
- }
BigDecimal now_price;
- StockListVO stockListVO = new StockListVO();
- StockCoin stockCoin = new StockCoin();
//股票类型 现价 数据源的处理
- stockListVO = StockApi.getStockRealTime(stock);
+ StockListVO stockListVO = StockApi.getStockRealTime(stock);
now_price = new BigDecimal(stockListVO.getNowPrice());
-
if (now_price.compareTo(new BigDecimal("0")) == 0) {
return ServerResponse.createByErrorMsg("Quote 0, please try again later");
}
+ BigDecimal buy_amt = now_price.multiply(new BigDecimal(buyNum));
- BigDecimal buy_amt = now_price.multiply(new BigDecimal(buyNum.intValue()));
- BigDecimal buy_amt_autual = buy_amt.divide(new BigDecimal(lever.intValue()), 2, 4);
- int compareInt = buy_amt_autual.compareTo(new BigDecimal(siteSetting.getBuyMinAmt().intValue()));
- if (compareInt == -1) {
- return ServerResponse.createByErrorMsg("Order failed, purchase amount is less than" + siteSetting
- .getBuyMinAmt());
- }
- BigDecimal max_buy_amt = userEnableAmt.multiply(siteSetting.getBuyMaxAmtPercent());
- int compareCwInt = buy_amt_autual.compareTo(max_buy_amt);
- if (compareCwInt == 1) {
- return ServerResponse.createByErrorMsg("Order failed, cannot exceed available funds." + siteSetting
- .getBuyMaxAmtPercent().multiply(new BigDecimal("100")) + "%");
- }
- int compareUserAmtInt = userEnableAmt.compareTo(buy_amt_autual);
- log.info("用户可用金额 = {} 实际购买金额 = {}", userEnableAmt, buy_amt_autual);
- log.info("比较 用户金额 和 实际 购买金额 = {}", Integer.valueOf(compareUserAmtInt));
- if (compareUserAmtInt == -1) {
- return ServerResponse.createByErrorMsg("下单失败,融资可用金额小于" + buy_amt_autual + "元");
+ UserAssets userAssets = iUserAssetsServices.assetsByTypeAndUserId(stock.getStockType(),user.getId());
+ if(userAssets.getAvailableBalance().compareTo(buy_amt)<0){
+ return ServerResponse.createByErrorMsg("Order failed,Insufficient balance");
+
}
- if (user.getUserIndexAmt().compareTo(new BigDecimal("0")) == -1) {
- return ServerResponse.createByErrorMsg("Failure, index total funds less than");
- }
+
UserPosition userPosition = new UserPosition();
if (profitTarget != null && profitTarget.compareTo(new BigDecimal("0")) > 0) {
@@ -259,31 +189,19 @@
userPosition.setIsLock(Integer.valueOf(0));
userPosition.setOrderLever(lever);
userPosition.setOrderTotalPrice(buy_amt);
- //递延费特殊处理
-// BigDecimal stayFee = userPosition.getOrderTotalPrice().multiply(siteSetting.getStayFee());
-// BigDecimal allStayFee = stayFee.multiply(new BigDecimal(1));
BigDecimal allStayFee = BigDecimal.valueOf(0);
userPosition.setOrderStayFee(allStayFee);
userPosition.setOrderStayDays(1);
BigDecimal buy_fee_amt = BigDecimal.valueOf(0);
-// BigDecimal buy_fee_amt = buy_amt.multiply(siteSetting.getBuyFee()).setScale(2, 4);
log.info("用户购买手续费(配资后总资金 * 百分比) = {}", buy_fee_amt);
userPosition.setOrderFee(buy_fee_amt);
BigDecimal buy_yhs_amt = BigDecimal.valueOf(0);
-// BigDecimal buy_yhs_amt = buy_amt.multiply(siteSetting.getDutyFee()).setScale(2, 4);
log.info("用户购买印花税(配资后总资金 * 百分比) = {}", buy_yhs_amt);
userPosition.setOrderSpread(buy_yhs_amt);
-// SiteSpread siteSpread = iSiteSpreadService.findSpreadRateOne(new BigDecimal(stock_crease), buy_amt, stock.getStockCode(), now_price);
BigDecimal spread_rate_amt = new BigDecimal("0");
-// if (siteSpread != null) {
-// spread_rate_amt = buy_amt.multiply(siteSpread.getSpreadRate()).setScale(2, 4);
-// log.info("用户购买点差费(配资后总资金 * 百分比{}) = {}", siteSpread.getSpreadRate(), spread_rate_amt);
-// } else {
-// log.info("用户购买点差费(配资后总资金 * 百分比{}) = {}", "设置异常", spread_rate_amt);
-// }
userPosition.setSpreadRatePrice(spread_rate_amt);
BigDecimal profit_and_lose = new BigDecimal("0");
@@ -292,40 +210,8 @@
userPosition.setAllProfitAndLose(all_profit_and_lose);
userPosition.setOrderStayDays(Integer.valueOf(0));
userPosition.setOrderStayFee(new BigDecimal("0"));
- int insertPositionCount = 0;
this.userPositionMapper.insert(userPosition);
- insertPositionCount = userPosition.getId();
- if (insertPositionCount > 0) {
- if (stock.getStockType().equals(EStockType.US.getCode())) {
- BigDecimal reckon_enable = userEnableAmt.subtract(buy_amt_autual);
- user.setUserIndexAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
- if (updateUserCount > 0) {
- log.info("【用户交易下单】修改用户金额成功");
- } else {
- log.error("用户交易下单】修改用户金额出错");
- throw new Exception("用户交易下单】修改用户金额出错");
- }
- } else {
- BigDecimal reckon_enable = userEnableAmt.subtract(buy_amt_autual);
- user.setEnableAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
- if (updateUserCount > 0) {
- log.info("【用户交易下单】修改用户金额成功");
- } else {
- log.error("用户交易下单】修改用户金额出错");
- throw new Exception("用户交易下单】修改用户金额出错");
- }
- }
-
- //核算代理收入-入仓手续费
-// iAgentAgencyFeeService.AgencyFeeIncome(1, userPosition.getPositionSn());
- log.info("【用户交易下单】保存持仓记录成功");
- } else {
- log.error("用户交易下单】保存持仓记录出错");
- throw new Exception("用户交易下单】保存持仓记录出错");
- }
-
+ iUserAssetsServices.availablebalanceChange(stock.getStockType(),user.getId(), EUserAssets.BUY,buy_amt.negate(),"","");
return ServerResponse.createBySuccessMsg("Order successful");
}
@@ -373,9 +259,9 @@
}
- public ServerResponse sell(String positionSn, int doType) throws Exception {
- log.info("【用户交易平仓】 positionSn = {} , dotype = {}", positionSn, Integer.valueOf(doType));
+ @Transactional
+ public ServerResponse sell(String positionSn, int doType) throws Exception {
SiteSetting siteSetting = this.iSiteSettingService.getSiteSetting();
if (siteSetting == null) {
log.error("平仓出错,网站设置表不存在");
@@ -384,29 +270,34 @@
SiteProduct siteProduct = iSiteProductService.getProductSetting();
UserPosition userPosition = this.userPositionMapper.findPositionBySn(positionSn);
if (doType != 0) {
- if (userPosition.getStockGid().contains(EStockType.US.getCode())) {
- String am_begin = siteSetting.getTransAmBeginUs();
- String am_end = siteSetting.getTransAmEndUs();
- String pm_begin = siteSetting.getTransPmBeginUs();
- String pm_end = siteSetting.getTransPmEndUs();
- boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
- boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
- if (!am_flag && !pm_flag) {
- return ServerResponse.createByErrorMsg("平仓失败,不在交易时段内");
- }
- } else {
- String am_begin = siteSetting.getTransAmBegin();
- String am_end = siteSetting.getTransAmEnd();
- String pm_begin = siteSetting.getTransPmBegin();
- String pm_end = siteSetting.getTransPmEnd();
- boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
- boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
- if (!am_flag && !pm_flag) {
- return ServerResponse.createByErrorMsg("Order failed,Out of trading hours");
- }
- }
- if (siteProduct.getHolidayDisplay()) {
- return ServerResponse.createByErrorMsg("No trading on weekends or holidays!");
+// if (userPosition.getStockGid().contains(EStockType.US.getCode())) {
+// String am_begin = siteSetting.getTransAmBeginUs();
+// String am_end = siteSetting.getTransAmEndUs();
+// String pm_begin = siteSetting.getTransPmBeginUs();
+// String pm_end = siteSetting.getTransPmEndUs();
+// boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
+// boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
+// if (!am_flag && !pm_flag) {
+// return ServerResponse.createByErrorMsg("平仓失败,不在交易时段内");
+// }
+// } else {
+// String am_begin = siteSetting.getTransAmBegin();
+// String am_end = siteSetting.getTransAmEnd();
+// String pm_begin = siteSetting.getTransPmBegin();
+// String pm_end = siteSetting.getTransPmEnd();
+// boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
+// boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
+// if (!am_flag && !pm_flag) {
+// return ServerResponse.createByErrorMsg("Order failed,Out of trading hours");
+// }
+// }
+// if (siteProduct.getHolidayDisplay()) {
+// return ServerResponse.createByErrorMsg("No trading on weekends or holidays!");
+// }
+ //判断股票是否在可交易时间段
+ Boolean b = tradingHourService.timeCheck();
+ if (!b) {
+ return ServerResponse.createByErrorMsg("Order failed, not in the stock trading session");
}
}
@@ -416,7 +307,7 @@
return ServerResponse.createByErrorMsg("Closing failed, order does not exist");
}
- User user = this.userMapper.selectByPrimaryKey(userPosition.getUserId());
+ User user = this.userMapper.selectById(userPosition.getUserId());
if (user == null) {
return ServerResponse.createByErrorMsg("Closed position failed, user does not exist");
}
@@ -436,20 +327,11 @@
if (1 == userPosition.getIsLock().intValue()) {
return ServerResponse.createByErrorMsg("this order is closed " + userPosition.getLockMsg());
}
-//
-// if (!DateTimeUtil.isCanSell(userPosition.getBuyOrderTime(), siteSetting.getCantSellTimes().intValue())) {
-// return ServerResponse.createByErrorMsg(siteSetting.getCantSellTimes() + "分钟内不能平仓");
-// }
-
-// if (DateTimeUtil.sameDate(DateTimeUtil.getCurrentDate(),userPosition.getBuyOrderTime())) {
-// return ServerResponse.createByErrorMsg("当天入仓的股票需要隔天才能出仓");
-// }
BigDecimal now_price;
- StockListVO stockListVO = new StockListVO();
Stock stock = stockMapper.selectOne(new QueryWrapper<Stock>().eq("stock_code", userPosition.getStockCode()));
//股票卖出的 价格 数据源
- stockListVO = StockApi.getStockRealTime(stock);
+ StockListVO stockListVO = StockApi.getStockRealTime(stock);
now_price = new BigDecimal(stockListVO.getNowPrice());
if (stockListVO.getNowPrice() == null) {
return ServerResponse.createByErrorMsg("Failed to close position, failed to obtain stock information");
@@ -458,138 +340,39 @@
log.error("股票 = {} 收到报价 = {}", userPosition.getStockName(), now_price);
return ServerResponse.createByErrorMsg("Quote 0, closing failed, please try again later");
}
- double stock_crease = stockListVO.getHcrate().doubleValue();
- BigDecimal zsPrice = new BigDecimal(stockListVO.getPreclose_px());
-
- BigDecimal ztPrice = zsPrice.multiply(new BigDecimal("0.1")).add(zsPrice);
- ztPrice = ztPrice.setScale(2, 4);
- BigDecimal chaPrice = ztPrice.subtract(zsPrice);
-
- Integer buy_num = userPosition.getOrderNum();
-
- BigDecimal all_buy_amt = userPosition.getOrderTotalPrice();
- //BigDecimal all_sell_amt = now_price.multiply(new BigDecimal(buy_num.intValue())).divide(new BigDecimal(userPosition.getOrderLever())).setScale(2,4);
- BigDecimal all_sell_amt = now_price.multiply(new BigDecimal(buy_num.intValue()));
-
- BigDecimal profitLoss = new BigDecimal("0");
- if ("买涨".equals(userPosition.getOrderDirection())) {
- log.info("买卖方向:{}", "涨");
-
- profitLoss = all_sell_amt.subtract(all_buy_amt);
- } else {
- log.info("买卖方向:{}", "跌");
- profitLoss = all_buy_amt.subtract(all_sell_amt);
- }
- log.info("买入总金额 = {} , 卖出总金额 = {} , 盈亏 = {}", new Object[]{all_buy_amt, all_sell_amt, profitLoss});
-
-
- BigDecimal userAllAmt;
- BigDecimal userEnableAmt;
- if (EStockType.US.getCode().equals(userPosition.getStockGid())) {
- userAllAmt = user.getUserIndexAmt();
- userEnableAmt = user.getEnableIndexAmt();
- log.info("美股账号原本资金 = {} , 可用 = {}", userAllAmt, userEnableAmt);
- } else {
- userAllAmt = user.getUserAmt();
- userEnableAmt = user.getEnableAmt();
- log.info("印度账户用户原本总资金 = {} , 可用 = {}", userAllAmt, userEnableAmt);
- }
-
-
- BigDecimal buy_fee_amt = BigDecimal.ZERO;
- BigDecimal orderSpread = BigDecimal.ZERO;
- BigDecimal orderStayFee = BigDecimal.ZERO;
- BigDecimal spreadRatePrice = BigDecimal.ZERO;
- BigDecimal sell_fee_amt = BigDecimal.ZERO;
-// BigDecimal buy_fee_amt = userPosition.getOrderFee();
-// log.info("买入手续费 = {}", buy_fee_amt);
-//
-// BigDecimal orderSpread = userPosition.getOrderSpread();
-// log.info("印花税 = {}", orderSpread);
-//
-// BigDecimal orderStayFee = userPosition.getOrderStayFee();
-// log.info("递延费 = {}", orderStayFee);
-//
-// BigDecimal spreadRatePrice = userPosition.getSpreadRatePrice();
-// log.info("点差费 = {}", spreadRatePrice);
-//
-// BigDecimal sell_fee_amt = all_sell_amt.multiply(siteSetting.getSellFee()).setScale(2, 4);
-// log.info("卖出手续费 = {}", sell_fee_amt);
-
- //总手续费= 买入手续费+卖出手续费+印花税+递延费+点差费
- BigDecimal all_fee_amt = buy_fee_amt.add(sell_fee_amt).add(orderSpread).add(orderStayFee).add(spreadRatePrice);
- log.info("总的手续费费用 = {}", all_fee_amt);
userPosition.setSellOrderId(GeneratePosition.getPositionId());
userPosition.setSellOrderPrice(now_price);
userPosition.setSellOrderTime(new Date());
+ userPositionMapper.updateById(userPosition);
+ userAssetsServices.availablebalanceChange(stock.getStockType(),userPosition.getUserId(),EUserAssets.CLOSE_POSITION_RETURN_SECURITY_DEPOSIT,
+ userPosition.getOrderTotalPrice(),"","");
+ userAssetsServices.availablebalanceChange(stock.getStockType(),userPosition.getUserId(),EUserAssets.CLOSE_POSITION,
+ userPosition.getProfitAndLose() ,"","");
+ return ServerResponse.createBySuccessMsg("Closed position successfully!");
+ }
- BigDecimal order_fee_all = buy_fee_amt.add(sell_fee_amt);
- userPosition.setOrderFee(order_fee_all);
-
- userPosition.setProfitAndLose(profitLoss);
-
- BigDecimal all_profit = profitLoss.subtract(all_fee_amt);
- userPosition.setAllProfitAndLose(all_profit);
-
- int updatePositionCount = this.userPositionMapper.updateByPrimaryKeySelective(userPosition);
- if (updatePositionCount > 0) {
- log.info("【用户平仓】修改浮动盈亏记录成功");
- } else {
- log.error("用户平仓】修改浮动盈亏记录出错");
- throw new Exception("用户平仓】修改浮动盈亏记录出错");
+ @Transactional
+ @Override
+ public ServerResponse allSell(HttpServletRequest request,String stockType) throws Exception{
+ //判断股票是否在可交易时间段
+ Boolean b = tradingHourService.timeCheck();
+ if (!b) {
+ return ServerResponse.createByErrorMsg("Order failed, not in the stock trading session");
}
-
- BigDecimal freez_amt = all_buy_amt.divide(new BigDecimal(userPosition.getOrderLever().intValue()), 2, 4);
- //BigDecimal freez_amt = all_buy_amt;
-
- BigDecimal reckon_all = userAllAmt.add(all_profit);
- //修改用户可用余额=当前可用余额+总盈亏+买入总金额+追加保证金
- BigDecimal reckon_enable = userEnableAmt.add(all_profit).add(freez_amt).add(userPosition.getMarginAdd());
-
-
- if (EStockType.US.getCode().equals(userPosition.getStockGid())) {
- user.setUserIndexAmt(reckon_all);
- user.setEnableIndexAmt(reckon_enable);
- log.info("美股用户平仓后的总资金 = {} , 可用资金 = {}", reckon_all, reckon_enable);
- } else {
- user.setUserAmt(reckon_all);
- user.setEnableAmt(reckon_enable);
- log.info("印度股用户平仓后的总资金 = {} , 可用资金 = {}", reckon_all, reckon_enable);
+ User user = iUserService.getCurrentUser(request);
+ if(user == null){
+ return ServerResponse.createByErrorMsg("Please login");
}
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
- if (updateUserCount > 0) {
- log.info("【用户平仓】修改用户金额成功");
- } else {
- log.error("用户平仓】修改用户金额出错");
- throw new Exception("用户平仓】修改用户金额出错");
+ QueryWrapper<UserPosition> queryWrapper = new QueryWrapper<>();
+ queryWrapper.eq("user_id",user.getId());
+ queryWrapper.eq("stock_gid",stockType);
+ queryWrapper.isNull("sell_order_id");
+
+ List<UserPosition> userPositionList = userPositionMapper.selectList(queryWrapper);
+ for (int i = 0; i < userPositionList.size(); i++) {
+ sell(userPositionList.get(i).getPositionSn(),0);
}
-
- UserCashDetail ucd = new UserCashDetail();
- ucd.setPositionId(userPosition.getId());
- ucd.setAgentId(user.getAgentId());
- ucd.setAgentName(user.getAgentName());
- ucd.setUserId(user.getId());
- ucd.setUserName(user.getRealName());
- ucd.setDeType("总盈亏");
- ucd.setDeAmt(all_profit);
- ucd.setDeSummary("卖出股票," + userPosition.getStockCode() + "/" + userPosition.getStockName() + ",占用本金:" + freez_amt + ",总手续费:" + all_fee_amt + ",递延费:" + orderStayFee + ",印花税:" + orderSpread + ",盈亏:" + profitLoss + ",总盈亏:" + all_profit);
-
- ucd.setAddTime(new Date());
- ucd.setIsRead(Integer.valueOf(0));
-
- int insertSxfCount = this.userCashDetailMapper.insert(ucd);
- if (insertSxfCount > 0) {
- //核算代理收入-平仓手续费
- iAgentAgencyFeeService.AgencyFeeIncome(2, userPosition.getPositionSn());
- //核算代理收入-分红
- iAgentAgencyFeeService.AgencyFeeIncome(4, userPosition.getPositionSn());
- log.info("【用户平仓】保存明细记录成功");
- } else {
- log.error("用户平仓】保存明细记录出错");
- throw new Exception("用户平仓】保存明细记录出错");
- }
-
return ServerResponse.createBySuccessMsg("Closed position successfully!");
}
@@ -604,16 +387,6 @@
}
if (doType != 0) {
- /*String am_begin = siteSetting.getTransAmBegin();
- String am_end = siteSetting.getTransAmEnd();
- String pm_begin = siteSetting.getTransPmBegin();
- String pm_end = siteSetting.getTransPmEnd();
- boolean am_flag = BuyAndSellUtils.isTransTime(am_begin, am_end);
- boolean pm_flag = BuyAndSellUtils.isTransTime(pm_begin, pm_end);
- log.info("是否在上午交易时间 = {} 是否在下午交易时间 = {}", Boolean.valueOf(am_flag), Boolean.valueOf(pm_flag));
- if (!am_flag && !pm_flag) {
- return ServerResponse.createByErrorMsg("追加失败,不在交易时段内");
- }*/
}
UserPosition userPosition = this.userPositionMapper.findPositionBySn(positionSn);
@@ -621,7 +394,7 @@
return ServerResponse.createByErrorMsg("追加失败,订单不存在");
}
- User user = this.userMapper.selectByPrimaryKey(userPosition.getUserId());
+ User user = this.userMapper.selectById(userPosition.getUserId());
/*实名认证开关开启*/
SiteProduct siteProduct = iSiteProductService.getProductSetting();
if (!siteProduct.getStockMarginDisplay()) {
@@ -640,8 +413,8 @@
return ServerResponse.createByErrorMsg("追加失败 " + userPosition.getLockMsg());
}
- BigDecimal user_all_amt = user.getUserAmt();
- BigDecimal user_enable_amt = user.getEnableAmt();
+ BigDecimal user_all_amt = BigDecimal.ZERO;
+ BigDecimal user_enable_amt = BigDecimal.ZERO;
int compareUserAmtInt = user_enable_amt.compareTo(marginAdd);
log.info("用户可用金额 = {} 追加金额 = {}", user_enable_amt, marginAdd);
log.info("比较 用户金额 和 实际 购买金额 = {}", Integer.valueOf(compareUserAmtInt));
@@ -664,8 +437,7 @@
BigDecimal reckon_enable = user_enable_amt.subtract(marginAdd);
log.info("用户追加保证金后的总资金 = {} , 可用资金 = {}", user_all_amt, reckon_enable);
- user.setEnableAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
+ int updateUserCount = this.userMapper.updateById(user);
if (updateUserCount > 0) {
log.info("【用户平仓】修改用户金额成功");
} else {
@@ -1000,7 +772,7 @@
}
- User user = this.userMapper.selectByPrimaryKey(userId);
+ User user = this.userMapper.selectById(userId);
if (user == null) {
log.info("用户不存在");
return ServerResponse.createByErrorMsg("用户不存在");
@@ -1030,26 +802,9 @@
}
- BigDecimal user_enable_amt = user.getEnableAmt();
BigDecimal buy_amt = (new BigDecimal(buyPrice)).multiply(new BigDecimal(buyNum.intValue()));
BigDecimal buy_amt_autual = buy_amt.divide(new BigDecimal(lever.intValue()), 2, 4);
-
-
- int compareUserAmtInt = user_enable_amt.compareTo(buy_amt_autual);
- log.info("用户可用金额 = {} 实际购买金额 = {}", user_enable_amt, buy_amt_autual);
- log.info("比较 用户金额 和 实际 购买金额 = {}", Integer.valueOf(compareUserAmtInt));
- if (compareUserAmtInt == -1) {
- log.info("下单失败,用户可用金额小于" + buy_amt_autual + "元");
- return ServerResponse.createByErrorMsg("下单失败,用户可用金额小于" + buy_amt_autual + "元");
-
- }
-
- if (user.getUserIndexAmt().compareTo(new BigDecimal("0")) == -1) {
- log.info("失败,指数总资金小于0");
- return ServerResponse.createByErrorMsg("失败,指数总资金小于0");
-
- }
UserPosition userPosition = new UserPosition();
@@ -1147,9 +902,7 @@
} else {
log.error("【创建持仓】保存记录出错");
}
- BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual);
- user.setEnableAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
+ int updateUserCount = this.userMapper.updateById(user);
if (updateUserCount > 0) {
log.info("【用户交易下单】修改用户金额成功");
} else {
@@ -1588,8 +1341,7 @@
userStockSubscribe.setStatus(5);
userStockSubscribeMapper.update1(userStockSubscribe);
if (userStockSubscribe.getType() == 1 || userStockSubscribe.getType() == 2) {
- User user = userMapper.selectByPrimaryKey(userStockSubscribe.getUserId());
- user.setDjzj(user.getDjzj().subtract(userStockSubscribe.getBond()));
+ User user = userMapper.selectById(userStockSubscribe.getUserId());
ret = userMapper.updateByPrimaryKey(user);
}
if (ret > 0) {
@@ -1625,7 +1377,6 @@
if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
return ServerResponse.createByErrorMsg("下单失败,请先实名认证");
}
- BigDecimal user_enable_amt = user.getEnableAmt();
log.info("用户 {} 下单,股票id = {} ,数量 = {} , 方向 = {} , 杠杆 = {}", new Object[]{user
.getId(), stockCode, buyNum, buyType, lever});
@@ -1639,15 +1390,11 @@
log.error("下单出错,网站设置表不存在");
return ServerResponse.createByErrorMsg("下单失败,系统设置错误");
}
-// if (siteSetting.getVipQcMaxAmt().compareTo(user_enable_amt) > 0) {
-// return ServerResponse.createByErrorMsg("下单失败,可用余额小于"+siteSetting.getVipQcMaxAmt());
-// }
- Stock stock = null;
ServerResponse stock_res = this.iStockService.findStockByCode(stockCode);
if (!stock_res.isSuccess()) {
return ServerResponse.createByErrorMsg("下单失败,股票代码错误");
}
- stock = (Stock) stock_res.getData();
+ Stock stock = (Stock) stock_res.getData();
String am_begin = siteSetting.getTransAmBegin();
String am_end = siteSetting.getTransAmEnd();
@@ -1808,21 +1555,6 @@
}
- BigDecimal max_buy_amt = user_enable_amt.multiply(siteSetting.getBuyMaxAmtPercent());
- int compareCwInt = buy_amt_autual.compareTo(max_buy_amt);
- if (compareCwInt == 1) {
- return ServerResponse.createByErrorMsg("下单失败,不能超过可用资金的" + siteSetting
- .getBuyMaxAmtPercent().multiply(new BigDecimal("100")) + "%");
- }
-
-
- int compareUserAmtInt = user_enable_amt.compareTo(buy_amt_autual);
- log.info("用户可用金额 = {} 实际购买金额 = {}", user_enable_amt, buy_amt_autual);
- log.info("比较 用户金额 和 实际 购买金额 = {}", Integer.valueOf(compareUserAmtInt));
- if (compareUserAmtInt == -1) {
- return ServerResponse.createByErrorMsg("下单失败,可用金额小于" + buy_amt_autual + "元");
- }
-
// if (user.getUserIndexAmt().compareTo(new BigDecimal("0")) == -1) {
// return ServerResponse.createByErrorMsg("失败,指数总资金小于0");
// }
@@ -1913,9 +1645,7 @@
//修改用户可用余额= 当前余额-下单金额-买入手续费-印花税-点差费
//BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual).subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);
//修改用户可用余额= 当前余额-下单总金额
- BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual);
- user.setEnableAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
+ int updateUserCount = this.userMapper.updateById(user);
if (updateUserCount > 0) {
log.info("【用户交易下单】修改用户金额成功");
} else {
@@ -1951,7 +1681,6 @@
if (siteProduct.getRealNameDisplay() && (StringUtils.isBlank(user.getRealName()) || StringUtils.isBlank(user.getIdCard()))) {
return ServerResponse.createByErrorMsg("Order failed, please first real name authentication");
}
- BigDecimal user_enable_amt = user.getEnableAmt();
log.info("用户 {} 下单,股票code = {} ,数量 = {}", new Object[]{user
.getId(), stockCode, num});
if (siteProduct.getRealNameDisplay() && user.getIsLock().intValue() == 1) {
@@ -2062,21 +1791,6 @@
}
- BigDecimal max_buy_amt = user_enable_amt.multiply(siteSetting.getBuyMaxAmtPercent());
- int compareCwInt = buy_amt_autual.compareTo(max_buy_amt);
- if (compareCwInt == 1) {
- return ServerResponse.createByErrorMsg("Order failed, purchase amount is less than" + siteSetting
- .getBuyMaxAmtPercent().multiply(new BigDecimal("100")) + "%");
- }
-
-
- int compareUserAmtInt = user_enable_amt.compareTo(buy_amt_autual);
- log.info("用户可用金额 = {} 实际购买金额 = {}", user_enable_amt, buy_amt_autual);
- log.info("比较 用户金额 和 实际 购买金额 = {}", Integer.valueOf(compareUserAmtInt));
- if (compareUserAmtInt == -1) {
- return ServerResponse.createByErrorMsg("Order failed, the amount of financing available is less than" + buy_amt_autual);
- }
-
UserPosition userPosition = new UserPosition();
userPosition.setPositionType(3);
userPosition.setPositionSn(KeyUtils.getUniqueKey());
@@ -2145,9 +1859,7 @@
//修改用户可用余额= 当前余额-下单金额-买入手续费-印花税-点差费
//BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual).subtract(buy_fee_amt).subtract(buy_yhs_amt).subtract(spread_rate_amt);
//修改用户可用余额= 当前余额-下单总金额
- BigDecimal reckon_enable = user_enable_amt.subtract(buy_amt_autual);
- user.setEnableAmt(reckon_enable);
- int updateUserCount = this.userMapper.updateByPrimaryKeySelective(user);
+ int updateUserCount = this.userMapper.updateById(user);
if (updateUserCount > 0) {
log.info("【用户交易下单】修改用户金额成功");
} else {
--
Gitblit v1.9.3