From 2785d374a827a732ae74e8ef520369cfcb76eaf6 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Sun, 21 Sep 2025 18:08:02 +0800
Subject: [PATCH] 1

---
 ruoyi-admin/src/main/java/com/ruoyi/im/ImApiController.java |  130 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 118 insertions(+), 12 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/im/ImApiController.java b/ruoyi-admin/src/main/java/com/ruoyi/im/ImApiController.java
index 6fb0d5a..f67cb2b 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/im/ImApiController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/im/ImApiController.java
@@ -1,17 +1,24 @@
 package com.ruoyi.im;
 
 import cn.hutool.core.util.ObjectUtil;
+import com.alibaba.fastjson2.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.page.TableDataInfo;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.im.comm.Result;
 import com.ruoyi.im.config.IpUtils;
 import com.ruoyi.im.dto.UpdateUserBusinessDto;
 import com.ruoyi.im.service.ImApiServcie;
 import com.ruoyi.im.dto.RegisterDto;
-import com.ruoyi.system.domain.GroupWelcomeConfig;
-import com.ruoyi.system.domain.IpBlacklist;
-import com.ruoyi.system.domain.UserAccount;
+import com.ruoyi.im.service.InsuranceProductService;
+import com.ruoyi.im.service.MedicalInsuranceAccountService;
+import com.ruoyi.im.util.SymmetricCryptoUtil;
+import com.ruoyi.im.util.ValidatorUtil;
+import com.ruoyi.system.domain.*;
+import com.ruoyi.system.domain.out.UserOut;
+import com.ruoyi.system.domain.vo.UserAccountUpdateVo;
 import com.ruoyi.system.service.GroupWelcomeConfigService;
 import com.ruoyi.system.service.ISysUserService;
 import com.ruoyi.system.service.IpBlacklistService;
@@ -34,9 +41,7 @@
 import java.nio.file.Paths;
 import java.nio.file.attribute.PosixFilePermission;
 import java.nio.file.attribute.PosixFilePermissions;
-import java.util.Map;
-import java.util.Set;
-import java.util.UUID;
+import java.util.*;
 
 @RestController
 @RequestMapping("/im/api")
@@ -51,7 +56,14 @@
 
     @Autowired
     UserAccountService userAccountService;
+    @Autowired
+    GroupWelcomeConfigService groupWelcomeConfigService;
 
+    @Autowired
+    InsuranceProductService insuranceProductService;
+
+    @Autowired
+    MedicalInsuranceAccountService medicalInsuranceAccountService;
 
 
     @Value("${file.upload-dir}")
@@ -62,15 +74,66 @@
 
 
     /**
-     * 获取参数配置列表
+     * 注册
      */
     @PostMapping("/register")
     public Result register(@Validated RegisterDto dto){
         try {
+            // 验证手机号
+            boolean isPhoneValid = ValidatorUtil.isValidPhone(dto.getAccount());
+            if(!isPhoneValid){
+                return Result.error("手机号格式不正确");
+            }
             return imApiServcie.register(dto);
-        }catch (Exception e){
-            log.error("注册报错:",e);
-            return Result.error("注册失败,请稍后再试!");
+        } catch (RuntimeException e) {
+            // 从异常消息中解析Result对象
+            return JSON.parseObject(e.getMessage(), Result.class);
+        }
+    }
+
+    /**
+     * 获取二维码链接和邀请码
+     */
+    @GetMapping("/getUserCodeAndUrl")
+    public Result getUserCodeAndUrl(@RequestParam("account") String account){
+        try {
+            GroupWelcomeConfig groupWelcomeConfig = groupWelcomeConfigService.getOne(new LambdaQueryWrapper<>(GroupWelcomeConfig.class)
+                    .eq(GroupWelcomeConfig::getConfigurationName, "IM-BASICS").last(" limit 1"));
+            UserAccount userAccount = userAccountService.getOne(new LambdaQueryWrapper<UserAccount>().eq(UserAccount::getAccount, account));
+            Map<String,String> map = new HashMap<>();
+            map.put("url",ObjectUtil.isNotEmpty(groupWelcomeConfig.getCodeUrl()) ? groupWelcomeConfig.getCodeUrl() : "");
+            map.put("code",userAccount.getInvitationCode());
+            return Result.success(map);
+        } catch (RuntimeException e) {
+            // 从异常消息中解析Result对象
+            return JSON.parseObject(e.getMessage(), Result.class);
+        }
+    }
+
+    /**
+     * 修改用户信息只有数据库
+     * @return
+     */
+    @PostMapping("/updateUser")
+    public Result updateUser(UserAccountUpdateVo vo){
+        try {
+            UserAccount userAccount = userAccountService.getOne(new LambdaQueryWrapper<UserAccount>().eq(UserAccount::getAccount,vo.getAccountId()));
+
+            if (StringUtils.isNotBlank(vo.getNickname())) {
+                userAccount.setNickname(vo.getNickname());
+            }
+
+            if (StringUtils.isNotBlank(vo.getSignature())) {
+                userAccount.setSignature(vo.getSignature());
+            }
+
+            userAccount.setUpdateTime(new Date());
+            userAccountService.updateById(userAccount);
+            return Result.success();
+        } catch (RuntimeException e) {
+            e.printStackTrace();
+            log.error("修改用户数据库信息失败");
+            return Result.error("修改失败!");
         }
     }
 
@@ -78,7 +141,7 @@
      * 获取ip地址并判断是否在黑名单
      */
     @GetMapping("/blacklist")
-    public Result blacklist(HttpServletRequest request,@PathVariable("account") String account){
+    public Result blacklist(HttpServletRequest request,@RequestParam("account") String account){
         try {
             String clientIp = IpUtils.getClientIp(request);
             if(StringUtils.isEmpty(clientIp)){
@@ -93,6 +156,7 @@
                 return Result.error("账号不存在!");
             }
             userAccount.setLoginIp(clientIp);
+            userAccount.setLoginTime(new Date());
             userAccountService.updateById(userAccount);
             return Result.success();
         }catch (Exception e){
@@ -182,6 +246,48 @@
         }
     }
 
+    /**
+     * 产品信息列表
+     */
+    @GetMapping("/list")
+    public Result list() {
+        LambdaQueryWrapper<InsuranceProduct> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(InsuranceProduct::getStatus, "ACTIVE");
+        // 按创建时间倒序排列
+        wrapper.orderByDesc(InsuranceProduct::getCreatedAt);
 
-
+        List<InsuranceProduct> list = insuranceProductService.list(wrapper);
+        return Result.success(list);
+    }
+    /**
+     * 获取用户详情
+     */
+    @GetMapping("/getUserByAccount")
+    public Result getUserByAccount(HttpServletRequest request,@RequestParam("account") String account){
+        try {
+            String clientIp = IpUtils.getClientIp(request);
+            if(StringUtils.isEmpty(clientIp)){
+                return Result.success();
+            }
+            UserAccount userAccount = userAccountService.getOne(new LambdaQueryWrapper<>(UserAccount.class).eq(UserAccount::getCloudMessageAccount, account));
+            if(ObjectUtil.isEmpty(userAccount)){
+                return Result.error("账号不存在!");
+            }
+            UserOut user = new UserOut();
+            MedicalInsuranceAccount insuranceAccount = medicalInsuranceAccountService.getOne(new LambdaQueryWrapper<>(MedicalInsuranceAccount.class)
+                    .eq(MedicalInsuranceAccount::getUserId, userAccount.getId())
+                    .eq(MedicalInsuranceAccount::getAccountStatus, MedicalInsuranceAccount.AccountStatus.ACTIVE)
+            );
+            user.setKycStatus(userAccount.getKycStatus());
+            if(ObjectUtil.isEmpty(insuranceAccount)){
+                return Result.success(user);
+            }
+            user.setAmountClaimed(insuranceAccount.getAmountClaimed());
+            user.setAlreadyReceived(insuranceAccount.getAlreadyReceived());
+            return Result.success(user);
+        }catch (Exception e){
+            log.error("获取失败:",e);
+            return Result.error("获取失败,请稍后再试!");
+        }
+    }
 }

--
Gitblit v1.9.3