From 39135376545d5523f13960d922ac89071ea3e864 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 24 Apr 2024 17:57:46 +0800
Subject: [PATCH] 强制平仓

---
 src/main/java/com/nq/service/impl/UserServiceImpl.java |   44 +++++++++++++++++++++++++++++++++-----------
 1 files changed, 33 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/nq/service/impl/UserServiceImpl.java b/src/main/java/com/nq/service/impl/UserServiceImpl.java
index a3533c6..bd33072 100644
--- a/src/main/java/com/nq/service/impl/UserServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/UserServiceImpl.java
@@ -117,7 +117,8 @@
     @Autowired
     ISiteMessageService iSiteMessageService;
 
-
+    @Autowired
+    private ApplyLeverMapper applyLeverMapper;
 
 
 
@@ -192,9 +193,7 @@
             if (user.getIsLogin().intValue() == 1) {
                 return ServerResponse.createByErrorMsg("登录失败。账户锁定",request);
             }
-            userAssetsServices.assetsByTypeAndUserId(EStockType.MAS.getCode(),user.getId());
-            userAssetsServices.assetsByTypeAndUserId(EStockType.US.getCode(),user.getId());
-            userAssetsServices.assetsByTypeAndUserId(EStockType.HK.getCode(),user.getId());
+            userAssetsServices.assetsByTypeAndUserId(EStockType.IN.getCode(),user.getId());
             this.iSiteLoginLogService.saveLog(user, request);
             return ServerResponse.createBySuccess(user);
         }
@@ -287,9 +286,30 @@
         String userJson = RedisShardedPoolUtils.get(loginToken);
         User user = (User) JsonUtil.string2Obj(userJson, User.class);
         User dbuser = this.userMapper.selectById(user.getId());
+
         SiteSetting siteSetting = iSiteSettingService.getSiteSetting();
         UserInfoVO userInfoVO = assembleUserInfoVO(dbuser, siteSetting);
+        ApplyLever applyLever = applyLeverMapper.selectOne(new LambdaQueryWrapper<ApplyLever>()
+                .eq(ApplyLever::getUserId, user.getId())
+                .eq(ApplyLever::getState, 1)
+                .orderByDesc(ApplyLever::getCreateTime)
+                .last(" limit 1"));
+        if(null == applyLever || applyLever.getLever().equals("1")){
+            userInfoVO.setSiteLever("1");
+        }else{
+            userInfoVO.setSiteLever(leverSplit(applyLever.getLever()));
+        }
         return ServerResponse.createBySuccess(userInfoVO);
+    }
+
+    public String leverSplit(String lever){
+        String levers = "1/2/5/10";
+        String[] parts = levers.split("/");
+        int index = Arrays.asList(parts).indexOf(lever);
+        if (index != -1) {
+            return String.join("/", Arrays.copyOfRange(parts, 0, index + 1));
+        }
+        return null;
     }
 
 
@@ -485,7 +505,7 @@
             rUserAssets.setCumulativeProfitAndLoss(hProfitAndLose.toString());
             rUserAssets.setHandlingCharge(hMoney.toString());
             rUserAssets.setProfitAndLoss(profitAndLose.toString());
-
+            rUserAssets.setIsZf(userAssets.getIsZf());
             BigDecimal rate = rateServices.currencyRate(
                     EStockType.getEStockTypeByCode(userAssets.getAccectType()),EStockType.US);
 
@@ -702,22 +722,20 @@
     }
 
 
+    @Transactional
     public ServerResponse addSimulatedAccount(Integer agentId, String phone, String pwd, String amt, Integer accountType, HttpServletRequest request) {
         if (StringUtils.isBlank(phone) || StringUtils.isBlank(pwd)) {
             return ServerResponse.createByErrorMsg("The parameter cannot be null");
         }
 
-
-        User dbUser = this.userMapper.findByPhone(phone);
+        QueryWrapper queryWrapper = new QueryWrapper();
+        queryWrapper.eq("phone",phone);
+        User dbUser = userMapper.selectOne(queryWrapper);
         if (dbUser != null) {
             return ServerResponse.createByErrorMsg("The phone number is registered");
         }
 
 
-        if ((new BigDecimal(amt)).compareTo(new BigDecimal("200000")) == 1) {
-            return ServerResponse.createByErrorMsg("The phone number is registered");
-        }
-        amt = "0";   //代理后台添加用户时金额默认为0
         User user = new User();
         user.setAccountType(accountType);
         user.setPhone(phone);
@@ -725,6 +743,7 @@
         user.setIsLogin(Integer.valueOf(0));
         user.setIsActive(Integer.valueOf(0));
         user.setRegTime(new Date());
+
 
         if (accountType.intValue() == 1) {
             user.setNickName("模拟用户");
@@ -738,6 +757,9 @@
         }
 
         int insertCount = this.userMapper.insert(user);
+         dbUser = userMapper.selectOne(queryWrapper);
+        userAssetsServices.getAvailableBalance(EStockType.IN.getCode(),dbUser.getId() );
+        userAssetsServices.availablebalanceChange(EStockType.IN.getCode(),dbUser.getId(),EUserAssets.TOP_UP,new BigDecimal(amt),"","");
         if (insertCount > 0) {
             return ServerResponse.createBySuccessMsg("Success");
         }

--
Gitblit v1.9.3