From 2f254e6cb24cab39e452a166f2abefe55e0f6895 Mon Sep 17 00:00:00 2001 From: aijinhui <aijinhui> Date: 星期二, 26 十二月 2023 11:31:03 +0800 Subject: [PATCH] 融云 --- ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java | 152 ++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 115 insertions(+), 37 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 e1e767a..5c1022e 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 @@ -2,15 +2,15 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ruoyi.common.core.domain.AjaxResult; +import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.core.redis.RedisCache; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.rongcloud.mapper.ArdRongGroupMapper; import com.ruoyi.rongcloud.mapper.ArdRongGroupUserMapper; import com.ruoyi.rongcloud.domain.*; -import com.ruoyi.rongcloud.param.RongCloudGroupDisParam; -import com.ruoyi.rongcloud.param.RongCloudGroupParam; -import com.ruoyi.rongcloud.param.RongCloudParam; +import com.ruoyi.rongcloud.param.*; import com.ruoyi.rongcloud.service.RongCloudService; +import com.ruoyi.system.mapper.SysUserMapper; import com.ruoyi.utils.forest.RongCloudClient; import lombok.extern.slf4j.Slf4j; import org.apache.commons.codec.digest.DigestUtils; @@ -18,6 +18,7 @@ import org.springframework.stereotype.Service; import javax.annotation.Resource; +import java.lang.reflect.Field; import java.util.*; /** @@ -39,6 +40,8 @@ private ArdRongGroupMapper ardRongGroupMapper; @Resource private ArdRongGroupUserMapper ardRongGroupUserMapper; + @Resource + private SysUserMapper sysUserMapper; /** @@ -55,7 +58,7 @@ 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) { @@ -65,12 +68,12 @@ } @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; @@ -80,16 +83,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()); @@ -105,33 +108,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); @@ -145,54 +148,129 @@ 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)){ + if (code.equals(200)) { ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupParam.getGroupId()); ardRongGroup.setGroupName(groupParam.getGroupName()); ardRongGroupMapper.updateById(ardRongGroup); } - 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) { - return AjaxResult.success(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"); + for (int i = 0; i < list.size(); i++) { + String id = list.get(i).get("id"); + SysUser sysUser = sysUserMapper.selectUserById(id); + sysUsers.add(sysUser); + } + } + return AjaxResult.success(sysUsers); } @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)){ + 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()); + queryWrapper.eq("user_id", groupParam.getGroupId()) + .eq("group_id", groupParam.getUserId()); ardRongGroupUserMapper.delete(queryWrapper); } } - groupMap.put("groupId",groupParam.getGroupId()); - groupMap.put("userId",groupParam.getUserId()); + groupMap.put("groupId", groupParam.getGroupId()); + groupMap.put("userId", groupParam.getUserId()); return AjaxResult.success(groupMap); } + @Override + public AjaxResult userGroupQuery(RongCloudGroupUserParam userParam) { + return AjaxResult.success(rongCloudClient.userGroupQuery(getRongCloudHead(), userParam)); + } + + @Override + public AjaxResult groupSync(RongCloudGroupSyncParam syncParam) { + RongCloudGroupSyncEndParam endParam = new RongCloudGroupSyncEndParam(); + endParam.setUserId(syncParam.getUserId()); + List<RongCloudGroupSyncTwoParam> twoParams = syncParam.getList(); + for (int i = 0; i < twoParams.size(); 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 + "]"); + ageField.setAccessible(true); // 璁剧疆绉佹湁灞炴�у彲璁块棶 + ageField.set(endParam, groupName); + } catch (Exception e) { + e.printStackTrace(); + } + } + Map<String, Object> groupMap = rongCloudClient.groupSync(getRongCloudHead(), endParam); + return AjaxResult.success(groupMap); + } + + @Override + public AjaxResult groupInfo(String groupId) { + Map<String,Object> map = new HashMap<>(); + ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupId); + 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); + 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); + } + List<SysUser> sysUsers = sysUserMapper.selectList(queryWrapper1); + return AjaxResult.success(sysUsers); + } + /** * 鑾峰彇铻嶄簯绛惧悕淇℃伅 */ -- Gitblit v1.9.3