From 536f29e37573dd82efd22bb13a9769af09f31b2b Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Thu, 21 Aug 2025 20:03:45 +0800
Subject: [PATCH] 1

---
 ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/ImApiServcieImpl.java |   72 +++++++++++++++++++++++++++++++++---
 1 files changed, 66 insertions(+), 6 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/ImApiServcieImpl.java b/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/ImApiServcieImpl.java
index f252b5e..5e4bb33 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/ImApiServcieImpl.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/im/service/impl/ImApiServcieImpl.java
@@ -1,5 +1,7 @@
 package com.ruoyi.im.service.impl;
 
+import cn.hutool.core.util.ObjectUtil;
+import com.alibaba.fastjson2.JSON;
 import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.fasterxml.jackson.databind.ObjectMapper;
@@ -7,19 +9,23 @@
 import com.netease.nim.server.sdk.core.YunxinApiHttpClient;
 import com.netease.nim.server.sdk.core.YunxinApiResponse;
 import com.netease.nim.server.sdk.core.exception.YunxinSdkException;
+import com.netease.nim.server.sdk.core.http.HttpMethod;
+import com.netease.nim.server.sdk.im.v2.friend.FriendV2UrlContext;
+import com.netease.nim.server.sdk.im.v2.team.TeamV2UrlContext;
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.im.comm.Result;
-import com.ruoyi.im.config.AppAuthConfig;
-import com.ruoyi.im.config.DynamicRequestBodyBuilder;
-import com.ruoyi.im.config.NeteaseResponse;
-import com.ruoyi.im.config.UpdateUserInfoRequest;
+import com.ruoyi.im.config.*;
 import com.ruoyi.im.dto.UpdateUserBusinessDto;
+import com.ruoyi.im.service.NeteaseTeamService;
+import com.ruoyi.system.domain.GroupWelcomeConfig;
+import com.ruoyi.system.domain.NeteaseTeam;
 import com.ruoyi.system.domain.UserAccount;
 import com.ruoyi.im.service.ImApiServcie;
 import com.ruoyi.im.dto.RegisterDto;
 import com.ruoyi.system.domain.vo.UserAccountUpdateVo;
+import com.ruoyi.system.service.GroupWelcomeConfigService;
 import com.ruoyi.system.service.UserAccountService;
 import com.ruoyi.im.util.SymmetricCryptoUtil;
 import lombok.extern.slf4j.Slf4j;
@@ -58,7 +64,10 @@
 public class ImApiServcieImpl implements ImApiServcie {
     @Autowired
     private UserAccountService userAccountService;
-
+    @Autowired
+    GroupWelcomeConfigService groupWelcomeConfigService;
+    @Autowired
+    NeteaseTeamService neteaseTeamService;
 
     @Autowired
     private JdbcTemplate jdbcTemplate;
@@ -83,6 +92,7 @@
     private static final String ENCRYPTED_PASSWORD = SymmetricCryptoUtil.encryptPassword(DEFAULT_PASSWORD); // 密码加密一次,多次使用
 
     private static final String YUNXIN_CREATE_PATH = "/user/create.action";
+    private static final String FRIENDS_PATH = "/im/v2.1/friends";
 
     @Value("${netease.im.api-head-portrait-url}")
     private String headPortraitUrl;
@@ -135,6 +145,19 @@
             int code = json.getIntValue("code");
 
             if (code == 200) {
+                GroupWelcomeConfig groupWelcomeConfig = groupWelcomeConfigService.getOne(new LambdaQueryWrapper<>(GroupWelcomeConfig.class)
+                        .eq(GroupWelcomeConfig::getConfigurationName, "IM-BASICS").last(" limit 1"));
+                if(ObjectUtil.isNotEmpty(groupWelcomeConfig)){
+                    //添加默认好友
+                    addFriends(userAccount.getAccount(),groupWelcomeConfig.getUserAccid());
+                    //加入默认群聊
+                    List<String> accountList = new ArrayList<>();
+                    accountList.add(userAccount.getAccount());
+                    AddTeamMembersRequest request = new AddTeamMembersRequest();
+                    request.setInviteAccountIds(accountList);
+                    request.setOperatorId(groupWelcomeConfig.getUserAccid());
+                    neteaseTeamService.inviteTeamMembers(request);
+                }
                 return Result.success("注册成功");
             } else if (code == 414) {
                 // 手动触发回滚(事务注解会自动处理)
@@ -146,7 +169,6 @@
                 log.error("云信注册失败,响应: {}, traceId: {}", data, response.getTraceId());
                 return Result.error("注册失败,错误码: " + code);
             }
-
         } catch (YunxinSdkException e) {
             // 云信调用异常时回滚事务
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
@@ -548,4 +570,42 @@
         return Result.success("所有云信账号注册成功");
     }
 
+
+    public void addFriends(String accountId,String userAccid){
+        try {
+
+            Map<String, String> queryParams = null;
+            Map<String, Object> map = new HashMap<>();
+            map.put("account_id",accountId);
+            map.put("friend_account_id",userAccid);
+            JSONObject jsonBody = JSONObject.parseObject(JSONObject.toJSONString(map));
+
+
+            YunxinApiResponse apiResponse = yunxinClient.executeV2Api(
+                    HttpMethod.POST,
+                    FRIENDS_PATH,
+                    FRIENDS_PATH,
+                    queryParams,
+                    jsonBody.toJSONString()
+            );
+            // 检查所有响应结果
+            String data = apiResponse.getData();
+            JSONObject json = JSONObject.parseObject(data);
+            int code = json.getIntValue("code");
+            if (code != 200) {
+                log.error("云信账号注册添加默认好友失败");
+            }
+        } catch (YunxinSdkException e) {
+            // 云信调用异常时回滚事务
+            e.printStackTrace();
+            log.error("网易云信创建用户加群服务调用异常 traceId:");
+        } catch (Exception e) {
+            // 其他异常同样回滚
+            e.printStackTrace();
+            log.error("创建用户加群过程发生未知异常", e);
+        }
+    }
+
+
+
 }
\ No newline at end of file

--
Gitblit v1.9.3