From de6020134bfde3b783291367be467baabe220bf3 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期一, 25 十二月 2023 09:56:35 +0800
Subject: [PATCH] 权限
---
ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java | 181 +++++++++++++++++++++++++++++++++++++++++---
1 files changed, 167 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..11cafea 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,13 @@
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.*;
import com.ruoyi.rongcloud.service.RongCloudService;
import com.ruoyi.utils.forest.RongCloudClient;
import lombok.extern.slf4j.Slf4j;
@@ -11,10 +16,8 @@
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.lang.reflect.Field;
+import java.util.*;
/**
* @Description: 閫氳瀺涓氬姟鏈嶅姟
@@ -31,6 +34,11 @@
RongCloudClient rongCloudClient;
@Resource
RedisCache redisCache;
+ @Resource
+ private ArdRongGroupMapper ardRongGroupMapper;
+ @Resource
+ private ArdRongGroupUserMapper ardRongGroupUserMapper;
+
/**
* 鑾峰彇铻嶄簯token
@@ -46,7 +54,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 +64,160 @@
}
@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);
+ }
+
+ @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);
}
/**
@@ -74,13 +227,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