From aa3706580edc249216c20db6992aaf5b249dd960 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期五, 22 十二月 2023 17:00:58 +0800
Subject: [PATCH] 群组

---
 ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java |   82 ++++++++++++++++++++++++++++++++++------
 1 files changed, 69 insertions(+), 13 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 fa55088..de5e963 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,8 +1,12 @@
 package com.ruoyi.rongcloud.service.Impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.SecurityUtils;
-import com.ruoyi.rongcloud.domain.RongCloudParam;
+import com.ruoyi.rongcloud.mapper.ArdRongGroupMapper;
+import com.ruoyi.rongcloud.mapper.ArdRongGroupUserMapper;
+import com.ruoyi.rongcloud.domain.*;
 import com.ruoyi.rongcloud.service.RongCloudService;
 import com.ruoyi.utils.forest.RongCloudClient;
 import lombok.extern.slf4j.Slf4j;
@@ -11,10 +15,7 @@
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * @Description: 閫氳瀺涓氬姟鏈嶅姟
@@ -31,6 +32,11 @@
     RongCloudClient rongCloudClient;
     @Resource
     RedisCache redisCache;
+    @Resource
+    private ArdRongGroupMapper ardRongGroupMapper;
+    @Resource
+    private ArdRongGroupUserMapper ardRongGroupUserMapper;
+
 
     /**
      * 鑾峰彇铻嶄簯token
@@ -46,7 +52,7 @@
             RongCloudParam param = new RongCloudParam();
             param.setUserId(userId);
             param.setName(name);
-            Map map = rongCloudClient.getToken(getRongCloudHead(), param);
+            Map<String,Object>  map = rongCloudClient.getToken(getRongCloudHead(), param);
             token = (String) map.get("token");
             log.debug("鐢ㄦ埛" + userId + "鑾峰彇鍒拌瀺浜憈oken:" + token);
         } catch (Exception ex) {
@@ -56,15 +62,65 @@
     }
 
     @Override
-    public Map checkOnline(List<String> userIds) {
+    public Map<String,Object>  checkOnline(List<String> userIds) {
         Map<String, Object> onlineMap = new HashMap<>();
         for (String userId : userIds) {
             RongCloudParam param = new RongCloudParam();
             param.setUserId(userId);
-            Map isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
+            Map<String,Object>  isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
             onlineMap.put(userId, isOnline.get("status"));
         }
         return onlineMap;
+    }
+
+    @Override
+    public Boolean checkOnline(String userId) {
+        RongCloudParam param = new RongCloudParam();
+        param.setUserId(userId);
+        Map<String,Object>  isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
+        return isOnline.get("status").equals("1");
+    }
+
+    @Override
+    public AjaxResult groupCreate(RongCloudGroupParam group) {
+        group.setGroupId(String.valueOf(UUID.randomUUID()));
+        Map<String, Object> groupMap =  rongCloudClient.groupCreate(getRongCloudHead(),group);
+        Integer code = (Integer) groupMap.get("code");
+        if(code.equals(200)){
+            ArdRongGroup ardRongGroup = new ArdRongGroup();
+            ardRongGroup.setGroupId(group.getGroupId());
+            ardRongGroup.setGroupName(group.getGroupName());
+            ardRongGroup.setCreateName(SecurityUtils.getUserId());
+            ardRongGroup.setCreateTime(new Date());
+            ardRongGroupMapper.insert(ardRongGroup);
+            List<String> userList = group.getUserId();
+            for (int i = 0; i < userList.size(); i++) {
+                ArdRongGroupUser ardRongGroupUser = new ArdRongGroupUser();
+                ardRongGroupUser.setId(String.valueOf(UUID.randomUUID()));
+                ardRongGroupUser.setGroupId(group.getGroupId());
+                ardRongGroupUser.setUserId(userList.get(i));
+                ardRongGroupUserMapper.insert(ardRongGroupUser);
+            }
+        }
+        groupMap.put("userId",group.getUserId());
+        groupMap.put("groupId",group.getGroupId());
+        groupMap.put("group",group.getGroupName());
+        return AjaxResult.success(groupMap);
+    }
+
+    @Override
+    public AjaxResult groupDismiss(RongCloudGroupDisParam groupDis) {
+        Map<String, Object> groupMap =  rongCloudClient.groupDismiss(getRongCloudHead(),groupDis);
+        Integer code = (Integer) groupMap.get("code");
+        if(code.equals(200)){
+            ardRongGroupMapper.deleteById(groupDis.getGroupId());
+            QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
+            queryWrapper.eq("group_id",groupDis.getGroupId());
+            ardRongGroupUserMapper.delete(queryWrapper);
+        }
+        groupMap.put("groupId",groupDis.getGroupId());
+        groupMap.put("userId",groupDis.getUserId());
+        return AjaxResult.success(groupMap);
     }
 
     /**
@@ -76,11 +132,11 @@
         String nonce = RandomStringUtils.randomNumeric(18);
         String timestamp = String.valueOf(new Date().getTime());
         String signature = DigestUtils.sha1Hex(appSecret + nonce + timestamp);//App Secret + Nonce + T
-        Map<String, Object> headerMap=new HashMap<>();
-        headerMap.put("App-Key",appKey);
-        headerMap.put("Nonce",nonce);
-        headerMap.put("Timestamp",timestamp);
-        headerMap.put("Signature",signature);
+        Map<String, Object> headerMap = new HashMap<>();
+        headerMap.put("App-Key", appKey);
+        headerMap.put("Nonce", nonce);
+        headerMap.put("Timestamp", timestamp);
+        headerMap.put("Signature", signature);
         return headerMap;
     }
 }

--
Gitblit v1.9.3