From 6bddb83b1e7556aa9b2b1d4ce7ed5f4b4c62f2d0 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期五, 17 五月 2024 15:16:49 +0800
Subject: [PATCH] 融云建群修改提交

---
 ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java |   84 ++++++++++++++++++++++++++++++++++++++----
 1 files changed, 76 insertions(+), 8 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java b/ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java
index f41d726..3e52f60 100644
--- a/ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java
@@ -1,7 +1,10 @@
 package com.ruoyi.rongcloud.service.Impl;
 
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.dtflys.forest.exceptions.ForestRuntimeException;
 import com.ruoyi.common.core.domain.AjaxResult;
+import com.ruoyi.common.core.domain.entity.SysConfig;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.SecurityUtils;
@@ -10,14 +13,18 @@
 import com.ruoyi.rongcloud.domain.*;
 import com.ruoyi.rongcloud.param.*;
 import com.ruoyi.rongcloud.service.RongCloudService;
+import com.ruoyi.system.mapper.SysConfigMapper;
 import com.ruoyi.system.mapper.SysUserMapper;
 import com.ruoyi.utils.forest.RongCloudClient;
 import lombok.extern.slf4j.Slf4j;
+import okhttp3.*;
 import org.apache.commons.codec.digest.DigestUtils;
 import org.apache.commons.lang3.RandomStringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
+import java.io.IOException;
 import java.lang.reflect.Field;
 import java.util.*;
 
@@ -42,7 +49,8 @@
     private ArdRongGroupUserMapper ardRongGroupUserMapper;
     @Resource
     private SysUserMapper sysUserMapper;
-
+    @Resource
+    private SysConfigMapper sysConfigMapper;
 
     /**
      * 鑾峰彇铻嶄簯token
@@ -61,8 +69,9 @@
             Map<String, Object> map = rongCloudClient.getToken(getRongCloudHead(), param);
             token = (String) map.get("token");
             log.debug("鐢ㄦ埛" + userId + "鑾峰彇鍒拌瀺浜憈oken:" + token);
-        } catch (Exception ex) {
-            log.error("鑾峰彇token寮傚父:" + ex.getMessage());
+        }catch(ForestRuntimeException ex)
+        {
+            log.error("鑾峰彇铻嶄簯token寮傚父:" + ex.getMessage());
         }
         return token;
     }
@@ -90,7 +99,14 @@
     @Override
     public AjaxResult groupCreate(RongCloudGroupParam group) {
         group.setGroupId(String.valueOf(UUID.randomUUID()));
-        Map<String, Object> groupMap = rongCloudClient.groupCreate(getRongCloudHead(), group);
+        //Map<String, Object> groupMap = rongCloudClient.groupCreate(getRongCloudHead(), group);
+        SysConfig sysConfig = new SysConfig();
+        sysConfig.setConfigKey("rongyun");
+        SysConfig rySysConfig = sysConfigMapper.selectConfig(sysConfig);
+        String url = rySysConfig.getConfigValue() + "/group/create.json";
+        String appKey = redisCache.getCacheObject("sys_config:RongCloudAppKey");
+        String appSecret = redisCache.getCacheObject("sys_config:RongCloudAppSecret");
+        Map<String, Object> groupMap = createGroupChat(url, appSecret, appKey,group.getUserId(),group.getGroupId(),group.getGroupName());
         Integer code = (Integer) groupMap.get("code");
         if (code.equals(200)) {
             ArdRongGroup ardRongGroup = new ArdRongGroup();
@@ -112,6 +128,53 @@
         groupMap.put("groupId", group.getGroupId());
         groupMap.put("group", group.getGroupName());
         return AjaxResult.success(groupMap);
+    }
+
+    public Map<String,Object> createGroupChat(String url,String AppSecret,String AppKey,List<String> usersIdList,String groupId,String groupName){
+        OkHttpClient okHttpClient = new OkHttpClient();
+        FormBody.Builder builder = new FormBody.Builder();
+        for(String usersId : usersIdList){
+            builder.add("userId", usersId);
+        }
+
+        RequestBody formBody = builder.add("groupId", groupId)
+                .add("groupName", groupName).build();
+
+        String Nonce = String.valueOf(Math.random()).split("\\.")[1];
+        String Timestamp = String.valueOf(new Date().getTime());
+        String Signature = DigestUtils.sha1Hex(AppSecret + Nonce + Timestamp);//App Secret + Nonce + T
+        /*System.out.println(Nonce);
+        System.out.println(Timestamp);
+        System.out.println(AppSecret + Nonce + Timestamp);
+        System.out.println(Signature);*/
+
+        Request request = new Request.Builder().url(url).post(formBody)
+                .addHeader("Host","api-cn.ronghub.com")
+                .addHeader("App-Key", AppKey)
+                .addHeader("Nonce", Nonce)
+                .addHeader("Timestamp", Timestamp)
+                .addHeader("Signature", Signature)
+                .addHeader("Content-Type", "application/x-www-form-urlencoded").build();
+
+        Response response = null;
+        try {
+            response = okHttpClient.newCall(request).execute();
+        } catch (IOException e1) {
+            // TODO Auto-generated catch block
+            e1.printStackTrace();
+        }
+
+        ResponseBody responseBody = response.body();
+
+        try {
+            String message = responseBody.string();
+            Map<String,Object> result = (Map<String, Object>) JSON.parse(message);
+            return result;
+        } catch (IOException e) {
+            // TODO Auto-generated catch block
+            e.printStackTrace();
+            return new HashMap();
+        }
     }
 
     @Override
@@ -164,9 +227,14 @@
         Map<String, Object> groupMap = rongCloudClient.groupQuit(getRongCloudHead(), groupParam);
         Integer code = (Integer) groupMap.get("code");
         if (code.equals(200)) {
-            ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupParam.getGroupId());
-            ardRongGroup.setGroupName(groupParam.getGroupName());
-            ardRongGroupMapper.updateById(ardRongGroup);
+            List<String> list = groupParam.getUserId();
+            for (int i = 0; i < list.size(); i++) {
+                String userId = list.get(i);
+                QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
+                queryWrapper.eq("group_id",groupParam.getGroupId())
+                        .eq("user_id",userId);
+                ardRongGroupUserMapper.delete(queryWrapper);
+            }
         }
         groupMap.put("groupId", groupParam.getGroupId());
         groupMap.put("groupName", groupParam.getGroupName());
@@ -259,7 +327,7 @@
     public AjaxResult groupUserAll(String groupId) {
         ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupId);
         QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
-        queryWrapper.eq("group_id",ardRongGroup);
+        queryWrapper.eq("group_id",ardRongGroup.getGroupId());
         List<ArdRongGroupUser> list = ardRongGroupUserMapper.selectList(queryWrapper);
         List<String> userList = new ArrayList<>();
         for (int i = 0; i < list.size(); i++) {

--
Gitblit v1.9.3