From 9ab35c4cbc2bf535ab15305b173d0e6d27ffb3ba Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期五, 15 三月 2024 15:28:07 +0800
Subject: [PATCH] 增加密码验证接口
---
ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java | 177 ++++++++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 140 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 eb3484d..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,16 +1,17 @@
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;
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 +19,7 @@
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
+import java.lang.reflect.Field;
import java.util.*;
/**
@@ -39,6 +41,8 @@
private ArdRongGroupMapper ardRongGroupMapper;
@Resource
private ArdRongGroupUserMapper ardRongGroupUserMapper;
+ @Resource
+ private SysUserMapper sysUserMapper;
/**
@@ -55,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;
@@ -80,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());
@@ -105,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);
@@ -145,38 +150,136 @@
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)){
- List<String> userList = groupParam.getUserId();
- for (int i = 0; i < userList.size(); i++) {
+ 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("user_id",groupParam.getGroupId())
- .eq("group_id",groupParam.getUserId());
+ queryWrapper.eq("group_id",groupParam.getGroupId())
+ .eq("user_id",userId);
ardRongGroupUserMapper.delete(queryWrapper);
}
}
- 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 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);
+ Integer code = (Integer) groupMap.get("code");
+ 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("groupName", groupParam.getGroupName());
+ 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<>();
+ 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