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