From c17dc5484bde25d032bf58d114a4f1598a301f31 Mon Sep 17 00:00:00 2001
From: liusuyi <1951119284@qq.com>
Date: 星期三, 08 五月 2024 10:29:52 +0800
Subject: [PATCH] 增加用户预览位置接口

---
 ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java |  149 ++++++++++++++++++++++++++++++++-----------------
 1 files changed, 98 insertions(+), 51 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 525c632..fe2595e 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,6 +1,7 @@
 package com.ruoyi.rongcloud.service.Impl;
 
 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.SysUser;
 import com.ruoyi.common.core.redis.RedisCache;
@@ -58,22 +59,23 @@
             RongCloudParam param = new RongCloudParam();
             param.setUserId(userId);
             param.setName(name);
-            Map<String,Object>  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) {
-            log.error("鑾峰彇token寮傚父:" + ex.getMessage());
+        }catch(ForestRuntimeException ex)
+        {
+            log.error("鑾峰彇铻嶄簯token寮傚父:" + ex.getMessage());
         }
         return token;
     }
 
     @Override
-    public Map<String,Object>  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<String,Object>  isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
+            Map<String, Object> isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
             onlineMap.put(userId, isOnline.get("status"));
         }
         return onlineMap;
@@ -83,16 +85,16 @@
     public Boolean checkOnline(String userId) {
         RongCloudParam param = new RongCloudParam();
         param.setUserId(userId);
-        Map<String,Object>  isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
+        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);
+        Map<String, Object> groupMap = rongCloudClient.groupCreate(getRongCloudHead(), group);
         Integer code = (Integer) groupMap.get("code");
-        if(code.equals(200)){
+        if (code.equals(200)) {
             ArdRongGroup ardRongGroup = new ArdRongGroup();
             ardRongGroup.setGroupId(group.getGroupId());
             ardRongGroup.setGroupName(group.getGroupName());
@@ -108,33 +110,33 @@
                 ardRongGroupUserMapper.insert(ardRongGroupUser);
             }
         }
-        groupMap.put("userId",group.getUserId());
-        groupMap.put("groupId",group.getGroupId());
-        groupMap.put("group",group.getGroupName());
+        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);
+        Map<String, Object> groupMap = rongCloudClient.groupDismiss(getRongCloudHead(), groupDis);
         Integer code = (Integer) groupMap.get("code");
-        if(code.equals(200)){
+        if (code.equals(200)) {
             ardRongGroupMapper.deleteById(groupDis.getGroupId());
             QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
-            queryWrapper.eq("group_id",groupDis.getGroupId());
+            queryWrapper.eq("group_id", groupDis.getGroupId());
             ardRongGroupUserMapper.delete(queryWrapper);
         }
-        groupMap.put("groupId",groupDis.getGroupId());
-        groupMap.put("userId",groupDis.getUserId());
+        groupMap.put("groupId", groupDis.getGroupId());
+        groupMap.put("userId", groupDis.getUserId());
         return AjaxResult.success(groupMap);
     }
 
     @Override
     public AjaxResult groupJoin(RongCloudGroupParam groupParam) {
-        Map<String, Object> groupMap =  rongCloudClient.groupJoin(getRongCloudHead(),groupParam);
+        Map<String, Object> groupMap = rongCloudClient.groupJoin(getRongCloudHead(), groupParam);
         Integer code = (Integer) groupMap.get("code");
-        if(code.equals(200)){
-            if(groupParam.getGroupName()!=null){
+        if (code.equals(200)) {
+            if (groupParam.getGroupName() != null) {
                 ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupParam.getGroupId());
                 ardRongGroup.setGroupName(groupParam.getGroupName());
                 ardRongGroupMapper.updateById(ardRongGroup);
@@ -148,38 +150,43 @@
                 ardRongGroupUserMapper.insert(ardRongGroupUser);
             }
         }
-        groupMap.put("groupId",groupParam.getGroupId());
-        if(groupParam.getGroupName()!=null){
-            groupMap.put("groupName",groupParam.getGroupId());
-        }else {
+        groupMap.put("groupId", groupParam.getGroupId());
+        if (groupParam.getGroupName() != null) {
+            groupMap.put("groupName", groupParam.getGroupId());
+        } else {
             ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupParam.getGroupId());
-            groupMap.put("groupName",ardRongGroup.getGroupName());
+            groupMap.put("groupName", ardRongGroup.getGroupName());
         }
-        groupMap.put("userId",groupParam.getUserId());
+        groupMap.put("userId", groupParam.getUserId());
         return AjaxResult.success(groupMap);
     }
 
     @Override
     public AjaxResult groupQuit(RongCloudGroupParam groupParam) {
-        Map<String, Object> groupMap =  rongCloudClient.groupQuit(getRongCloudHead(),groupParam);
+        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);
+        if (code.equals(200)) {
+            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());
+        groupMap.put("groupId", groupParam.getGroupId());
+        groupMap.put("groupName", groupParam.getGroupName());
         return AjaxResult.success(groupMap);
     }
 
     @Override
     public AjaxResult groupUserQuery(RongCloudGroupParam groupId) {
-        Map<String, Object> groupMap = rongCloudClient.groupUserQuery(getRongCloudHead(),groupId);
+        Map<String, Object> groupMap = rongCloudClient.groupUserQuery(getRongCloudHead(), groupId);
         Integer code = (Integer) groupMap.get("code");
         List<SysUser> sysUsers = new ArrayList<>();
-        if(code.equals(200)){
-            List<Map<String,String>> list = (List<Map<String, String>>) groupMap.get("users");
+        if (code.equals(200)) {
+            List<Map<String, String>> list = (List<Map<String, String>>) groupMap.get("users");
             for (int i = 0; i < list.size(); i++) {
                 String id = list.get(i).get("id");
                 SysUser sysUser = sysUserMapper.selectUserById(id);
@@ -191,25 +198,25 @@
 
     @Override
     public AjaxResult groupRefresh(RongCloudGroupParam groupParam) {
-        Map<String, Object> groupMap =  rongCloudClient.groupRefresh(getRongCloudHead(),groupParam);
+        Map<String, Object> groupMap = rongCloudClient.groupRefresh(getRongCloudHead(), groupParam);
         Integer code = (Integer) groupMap.get("code");
-        if(code.equals(200)){
-            List<String> userList = groupParam.getUserId();
-            for (int i = 0; i < userList.size(); i++) {
-                QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
-                queryWrapper.eq("user_id",groupParam.getGroupId())
-                        .eq("group_id",groupParam.getUserId());
-                ardRongGroupUserMapper.delete(queryWrapper);
-            }
+        if (code.equals(200)) {
+            String groupId = groupParam.getGroupId();
+            String groupName = groupParam.getGroupName();
+            QueryWrapper<ArdRongGroup> queryWrapper = new QueryWrapper<>();
+            queryWrapper.eq("group_id",groupId);
+            ArdRongGroup ardRongGroup = ardRongGroupMapper.selectOne(queryWrapper);
+            ardRongGroup.setGroupName(groupName);
+            ardRongGroupMapper.updateById(ardRongGroup);
         }
-        groupMap.put("groupId",groupParam.getGroupId());
-        groupMap.put("userId",groupParam.getUserId());
+        groupMap.put("groupId", groupParam.getGroupId());
+        groupMap.put("groupName", groupParam.getGroupName());
         return AjaxResult.success(groupMap);
     }
 
     @Override
     public AjaxResult userGroupQuery(RongCloudGroupUserParam userParam) {
-        return AjaxResult.success(rongCloudClient.userGroupQuery(getRongCloudHead(),userParam));
+        return AjaxResult.success(rongCloudClient.userGroupQuery(getRongCloudHead(), userParam));
     }
 
     @Override
@@ -218,23 +225,63 @@
         endParam.setUserId(syncParam.getUserId());
         List<RongCloudGroupSyncTwoParam> twoParams = syncParam.getList();
         for (int i = 0; i < twoParams.size(); i++) {
-            RongCloudGroupSyncTwoParam syncTwoParam= twoParams.get(i);
+            RongCloudGroupSyncTwoParam syncTwoParam = twoParams.get(i);
             String groupId = syncTwoParam.getGroupId();
             String groupName = syncTwoParam.getGroupName();
             try {
                 Class clazz = endParam.getClass();
                 // 鍔ㄦ�佹坊鍔犲睘鎬�
-                Field ageField = clazz.getDeclaredField("group["+groupId+"]");
+                Field ageField = clazz.getDeclaredField("group[" + groupId + "]");
                 ageField.setAccessible(true); // 璁剧疆绉佹湁灞炴�у彲璁块棶
                 ageField.set(endParam, groupName);
-            }catch (Exception e){
+            } catch (Exception e) {
                 e.printStackTrace();
             }
         }
-        Map<String, Object> groupMap =  rongCloudClient.groupSync(getRongCloudHead(),endParam);
+        Map<String, Object> groupMap = rongCloudClient.groupSync(getRongCloudHead(), endParam);
         return AjaxResult.success(groupMap);
     }
 
+    @Override
+    public AjaxResult groupInfo(String groupId) {
+        Map<String,Object> map = new HashMap<>();
+        QueryWrapper<ArdRongGroup> ardRongGroupQueryWrapper = new QueryWrapper<>();
+        ardRongGroupQueryWrapper.eq("group_id",groupId);
+        ArdRongGroup ardRongGroup = ardRongGroupMapper.selectOne(ardRongGroupQueryWrapper);
+        map.put("group",ardRongGroup);
+        QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("group_id",groupId);
+        List<ArdRongGroupUser> list = ardRongGroupUserMapper.selectList(queryWrapper);
+        List<SysUser> sysUsers = new ArrayList<>();
+        for (int i = 0; i < list.size(); i++) {
+            String userId = list.get(i).getUserId();
+            SysUser sysUser = sysUserMapper.selectUserById(userId);
+            sysUsers.add(sysUser);
+        }
+        map.put("user",sysUsers);
+        return AjaxResult.success(map);
+    }
+
+    @Override
+    public AjaxResult groupUserAll(String groupId) {
+        ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupId);
+        QueryWrapper<ArdRongGroupUser> queryWrapper = new QueryWrapper<>();
+        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++) {
+            userList.add(list.get(i).getUserId());
+        }
+        QueryWrapper<SysUser> queryWrapper1 = new QueryWrapper<>();
+        if(userList.size()>0){
+            queryWrapper1.notIn("user_id",userList).eq("del_flag","0");
+        }else {
+            queryWrapper1.eq("del_flag","0");
+        }
+        List<SysUser> sysUsers = sysUserMapper.selectList(queryWrapper1);
+        return AjaxResult.success(sysUsers);
+    }
+
     /**
      * 鑾峰彇铻嶄簯绛惧悕淇℃伅
      */

--
Gitblit v1.9.3