From f059de0b3cfe92ba2980c8ce4c5772637c64e9d2 Mon Sep 17 00:00:00 2001 From: aijinhui <aijinhui> Date: 星期六, 23 十二月 2023 17:03:34 +0800 Subject: [PATCH] 权限 --- ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java | 154 ++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 140 insertions(+), 14 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..e1e767a 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,15 @@ 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.param.RongCloudGroupDisParam; +import com.ruoyi.rongcloud.param.RongCloudGroupParam; +import com.ruoyi.rongcloud.param.RongCloudParam; import com.ruoyi.rongcloud.service.RongCloudService; import com.ruoyi.utils.forest.RongCloudClient; import lombok.extern.slf4j.Slf4j; @@ -11,10 +18,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 +35,11 @@ RongCloudClient rongCloudClient; @Resource RedisCache redisCache; + @Resource + private ArdRongGroupMapper ardRongGroupMapper; + @Resource + private ArdRongGroupUserMapper ardRongGroupUserMapper; + /** * 鑾峰彇铻嶄簯token @@ -46,7 +55,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 +65,132 @@ } @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); + } + + @Override + public AjaxResult groupJoin(RongCloudGroupParam groupParam) { + Map<String, Object> groupMap = rongCloudClient.groupJoin(getRongCloudHead(),groupParam); + Integer code = (Integer) groupMap.get("code"); + if(code.equals(200)){ + if(groupParam.getGroupName()!=null){ + ArdRongGroup ardRongGroup = ardRongGroupMapper.selectById(groupParam.getGroupId()); + ardRongGroup.setGroupName(groupParam.getGroupName()); + ardRongGroupMapper.updateById(ardRongGroup); + } + List<String> userList = groupParam.getUserId(); + for (int i = 0; i < userList.size(); i++) { + ArdRongGroupUser ardRongGroupUser = new ArdRongGroupUser(); + ardRongGroupUser.setId(String.valueOf(UUID.randomUUID())); + ardRongGroupUser.setGroupId(groupParam.getGroupId()); + ardRongGroupUser.setUserId(userList.get(i)); + ardRongGroupUserMapper.insert(ardRongGroupUser); + } + } + 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("userId",groupParam.getUserId()); + return AjaxResult.success(groupMap); + } + + @Override + public AjaxResult groupQuit(RongCloudGroupParam 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); + } + 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)); + } + + @Override + public AjaxResult groupRefresh(RongCloudGroupParam 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); + } + } + groupMap.put("groupId",groupParam.getGroupId()); + groupMap.put("userId",groupParam.getUserId()); + return AjaxResult.success(groupMap); } /** @@ -74,13 +200,13 @@ String appKey = redisCache.getCacheObject("sys_config:RongCloudAppKey"); String appSecret = redisCache.getCacheObject("sys_config:RongCloudAppSecret"); String nonce = RandomStringUtils.randomNumeric(18); - String timestamp = String.valueOf(new Date().getTime()); + String timestamp = String.valueOf(System.currentTimeMillis()); 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