From 00885319fe99d583bf83d1777c5cbcee01dc11e1 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Tue, 12 Aug 2025 18:40:09 +0800
Subject: [PATCH] 8.6二开 对应账户提现、后台充值功能
---
src/main/java/com/nq/service/impl/EchoServices.java | 150 ++++++++++++++++++++++++++++++++++---------------
1 files changed, 104 insertions(+), 46 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/EchoServices.java b/src/main/java/com/nq/service/impl/EchoServices.java
index 3db3492..14faec9 100644
--- a/src/main/java/com/nq/service/impl/EchoServices.java
+++ b/src/main/java/com/nq/service/impl/EchoServices.java
@@ -2,15 +2,22 @@
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.github.pagehelper.PageHelper;
+import com.github.pagehelper.PageInfo;
+import com.nq.common.ResponseCode;
+import com.nq.common.ServerResponse;
import com.nq.dao.EChoMapper;
import com.nq.dao.OrderEchoMapper;
import com.nq.dao.UserAssetsMapper;
+import com.nq.dao.UserPositionMapper;
+import com.nq.enums.EStockAIStatus;
import com.nq.enums.EStockType;
-import com.nq.enums.EUserAssets;
import com.nq.pojo.*;
import com.nq.pojo.reponse.OrderEChoReponse;
import com.nq.service.IEchoServices;
import com.nq.service.IUserService;
+import com.nq.utils.PropertiesUtil;
+import com.nq.vo.subscribe.UserStockSubscribeVo;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@@ -20,6 +27,8 @@
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.List;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
@Slf4j
@Service
@@ -35,10 +44,10 @@
IUserService iUserService;
@Autowired
- private UserAssetsServices serAssetsServices;
+ private UserAssetsMapper userAssetsMapper;
@Autowired
- private UserAssetsMapper userAssetsMapper;
+ private UserPositionMapper userPositionMapper;
@Override
public List<EChoBean> queryList() {
@@ -46,7 +55,20 @@
}
@Override
- public boolean buyECho(String eId, BigDecimal money, HttpServletRequest request) {
+ public ServerResponse queryListPage(int pageNum, int pageSize) {
+ try {
+ PageHelper.startPage(pageNum, pageSize);
+ List<EChoBean> eChoBeans = eChoMapper.selectList(null);
+ PageInfo<EChoBean> pageInfo = new PageInfo<>(eChoBeans);
+ return ServerResponse.createBySuccess(pageInfo);
+ } catch (Exception ex) {
+ log.error("echoService queryListPage error", ex);
+ }
+ return ServerResponse.createByError();
+ }
+
+ @Override
+ public boolean buyECho(String eId, BigDecimal money, String accectType, HttpServletRequest request) {
User user = this.iUserService.getCurrentRefreshUser(request);
@@ -73,9 +95,10 @@
UserAssets userAssets = userAssetsMapper.selectOne(new LambdaQueryWrapper<UserAssets>()
.eq(UserAssets::getUserId, orderEchoBean.getUserId())
- .eq(UserAssets::getAccectType, "IN")
+ .eq(UserAssets::getAccectType, accectType)
);
userAssets.setAvailableBalance(userAssets.getAvailableBalance().subtract(money));
+ userAssets.setFreezeMoney(userAssets.getFreezeMoney().add(money));
userAssetsMapper.updateById(userAssets);
return orderEchoMapper.insert(orderEchoBean) >= 1;
}
@@ -91,56 +114,91 @@
}
@Override
+ public ServerResponse queryOrderEchoPage(int pageNum, int pageSize, HttpServletRequest request) {
+ try {
+ User user = iUserService.getCurrentRefreshUser(request);
+ if (user == null) {
+ return ServerResponse.createByErrorCodeMsg(ResponseCode.NEED_LOGIN.getCode(),"请先登录");
+ }
+ PageHelper.startPage(pageNum, pageSize);
+ List<OrderEchoOut> orderEchoOutList = orderEchoMapper.queryByUserId(user.getId());
+ PageInfo<OrderEchoOut> pageInfo = new PageInfo<>(orderEchoOutList);
+ return ServerResponse.createBySuccess(pageInfo);
+ } catch (Exception ex) {
+ log.error("echoService queryOrderEchoPage error", ex);
+ }
+ return ServerResponse.createByError();
+ }
+
+ @Override
public List<OrderEChoReponse> queryALLOrderEcho() {
return orderEchoMapper.queryAll();
}
@Override
public void sendMoney() {
- QueryWrapper<OrderEchoBean> queryWrapper = new QueryWrapper<>();
- queryWrapper.eq("state", 1);
- queryWrapper.lt("end_time", System.currentTimeMillis());
- List<OrderEchoBean> list = orderEchoMapper.selectList(queryWrapper);
- log.info("基金定时任务执行数量:{}",list.size());
- for (OrderEchoBean orderEchoBean : list) {
- BigDecimal money = new BigDecimal(orderEchoBean.getMoney()); // 本金
- BigDecimal rate = new BigDecimal(orderEchoBean.getReturnOfRate()); // 收益率
- // 将rate除以100,并向上取整
- rate = rate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
-
- // 本金*收益率*周期/365=收益金额
- BigDecimal incomeAmount = money.multiply(rate);
- BigDecimal aml = incomeAmount.add(money);
- UserAssets userAssets = userAssetsMapper.selectOne(new LambdaQueryWrapper<UserAssets>()
- .eq(UserAssets::getUserId, orderEchoBean.getUserId())
- .eq(UserAssets::getAccectType, "IN")
- );
- if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
- continue;
- }
- BigDecimal subtract = aml.subtract(userAssets.getAmountToBeCovered());
- if(userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
- if(subtract.compareTo(BigDecimal.ZERO) > 0){
- userAssets.setAmountToBeCovered(BigDecimal.ZERO);
- userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
- }else{
- userAssets.setAmountToBeCovered(subtract.negate());
- }
- }else{
- userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(aml));
- }
- userAssetsMapper.updateById(userAssets);
- orderEchoBean.setState("2");
- orderEchoBean.setEarnings(incomeAmount.toString());
- orderEchoMapper.updateById(orderEchoBean);
+ // 创建固定大小的线程池,根据需求调整线程数量
+ ExecutorService executor = Executors.newFixedThreadPool(2);
+ try {
+ executor.submit(() -> sendMoney(EStockType.getDefault().getCode()));
+ } finally {
+ // 关闭线程池
+ executor.shutdown();
}
-
}
- public static void main(String[] args) {
- BigDecimal a = new BigDecimal("20");
- BigDecimal b = new BigDecimal("-100");
- System.out.println(a.add(b));
+ private void sendMoney(String stockType) {
+ try {
+ QueryWrapper<OrderEchoBean> queryWrapper = new QueryWrapper<>();
+ queryWrapper.eq("state", 1);
+ queryWrapper.lt("end_time", System.currentTimeMillis());
+ List<OrderEchoBean> list = orderEchoMapper.selectList(queryWrapper);
+ log.info("基金定时任务执行数量:{}", list.size());
+ for (OrderEchoBean orderEchoBean : list) {
+ try {
+ BigDecimal money = new BigDecimal(orderEchoBean.getMoney()); // 本金
+ BigDecimal rate = new BigDecimal(orderEchoBean.getReturnOfRate()); // 收益率
+ // 将rate除以100,并向上取整
+ rate = rate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
+
+ // 本金*收益率*周期/365=收益金额
+ BigDecimal incomeAmount = money.multiply(rate);
+ BigDecimal aml = incomeAmount.add(money);
+ UserAssets userAssets = userAssetsMapper.selectOne(new LambdaQueryWrapper<UserAssets>()
+ .eq(UserAssets::getUserId, orderEchoBean.getUserId())
+ .eq(UserAssets::getAccectType, stockType)
+ );
+ if (userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0) {
+ continue;
+ }
+ BigDecimal subtract = aml.subtract(userAssets.getAmountToBeCovered());
+ if (userAssets.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0) {
+ if (subtract.compareTo(BigDecimal.ZERO) > 0) {
+ userAssets.setAmountToBeCovered(BigDecimal.ZERO);
+ userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(subtract));
+ } else {
+ userAssets.setAmountToBeCovered(subtract.negate());
+ }
+ } else {
+ userAssets.setAvailableBalance(userAssets.getAvailableBalance().add(aml));
+ }
+ UserPosition userPosition = userPositionMapper.selectOne(new LambdaQueryWrapper<UserPosition>().gt(UserPosition::getAmountToBeCovered, BigDecimal.ZERO).eq(UserPosition::getUserId,userAssets.getUserId()));
+ if(null != userPosition){
+ userPosition.setAmountToBeCovered(userAssets.getAmountToBeCovered());
+ userPositionMapper.updateById(userPosition);
+ }
+ userAssets.setFreezeMoney(userAssets.getFreezeMoney().subtract(money));
+ userAssetsMapper.updateById(userAssets);
+ orderEchoBean.setState("2");
+ orderEchoBean.setEarnings(incomeAmount.toString());
+ orderEchoMapper.updateById(orderEchoBean);
+ } catch (Exception e) {
+ log.error("基金定时任务---失败: " + orderEchoBean.getId(), e);
+ }
+ }
+ } catch (Exception ex) {
+ log.error("基金定时任务---失败: ", ex);
+ }
}
@Override
--
Gitblit v1.9.3