From b7d0c5e9ddfedc068d2f82fab530e71043a7f4af Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 23 Apr 2024 19:50:14 +0800
Subject: [PATCH] 理财

---
 src/main/java/com/nq/service/impl/UserServiceImpl.java |   42 ++++++++++++++++++++++++++++++++----------
 1 files changed, 32 insertions(+), 10 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..4467d0d 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;
     }
 
 
@@ -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