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 | 209 ++++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 187 insertions(+), 22 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 07176a1..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,47 +1,212 @@
package com.ruoyi.rongcloud.service.Impl;
-import com.ruoyi.common.core.domain.entity.SysUser;
-import com.ruoyi.rongcloud.domain.TokenParam;
+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.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.system.mapper.SysConfigMapper;
-import com.ruoyi.system.service.ISysConfigService;
import com.ruoyi.utils.forest.RongCloudClient;
-import okhttp3.FormBody;
-import okhttp3.RequestBody;
+import lombok.extern.slf4j.Slf4j;
import org.apache.commons.codec.digest.DigestUtils;
+import org.apache.commons.lang3.RandomStringUtils;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
-import java.util.Date;
+import java.util.*;
/**
- * @Description:
+ * @Description: 閫氳瀺涓氬姟鏈嶅姟
* @ClassName: RongCloudServiceImpl
* @Author: 鍒樿嫃涔�
* @Date: 2023骞�07鏈�15鏃�16:49:12
* @Version: 1.0
**/
@Service
+@Slf4j(topic = "rongCloud")
public class RongCloudServiceImpl implements RongCloudService {
@Resource
RongCloudClient rongCloudClient;
@Resource
- ISysConfigService iSysConfigService;
+ RedisCache redisCache;
+ @Resource
+ private ArdRongGroupMapper ardRongGroupMapper;
+ @Resource
+ private ArdRongGroupUserMapper ardRongGroupUserMapper;
+
+
+ /**
+ * 鑾峰彇铻嶄簯token
+ *
+ * @param userId 鐢ㄦ埛id
+ * @param name 鐢ㄦ埛濮撳悕
+ */
@Override
- public String getToken(String userId,String name) {
-// String appKey="6tnym11s1h717";
-// String appSecret="IwcGk2flZr";
- String rongyunApiUrl = iSysConfigService.selectConfigByKey("rongyun");
- String appKey = iSysConfigService.selectConfigByKey("RongCloudAppKey");
- String appSecret = iSysConfigService.selectConfigByKey("RongCloudAppSecret");
- TokenParam param=new TokenParam();
- param.setUserId(userId);
- param.setName(name);
- String Nonce = String.valueOf(Math.random()).split("\\.")[1];
- String Timestamp = String.valueOf(new Date().getTime());
- String Signature = DigestUtils.sha1Hex(appSecret + Nonce + Timestamp);//App Secret + Nonce + Timestamp
- String token = rongCloudClient.getToken(rongyunApiUrl,appKey, Nonce, Timestamp, Signature, param);
+ public String getToken(String userId, String name) {
+
+ String token = "";
+ try {
+ RongCloudParam param = new RongCloudParam();
+ param.setUserId(userId);
+ param.setName(name);
+ 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());
+ }
return token;
}
+
+ @Override
+ 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);
+ 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);
+ }
+
+ /**
+ * 鑾峰彇铻嶄簯绛惧悕淇℃伅
+ */
+ public Map<String, Object> getRongCloudHead() {
+ String appKey = redisCache.getCacheObject("sys_config:RongCloudAppKey");
+ String appSecret = redisCache.getCacheObject("sys_config:RongCloudAppSecret");
+ String nonce = RandomStringUtils.randomNumeric(18);
+ 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);
+ return headerMap;
+ }
}
--
Gitblit v1.9.3