From 33e0699b011ddb83f77a1d7134d8f1d32e276516 Mon Sep 17 00:00:00 2001 From: aijinhui <aijinhui> Date: 星期五, 22 十二月 2023 10:02:51 +0800 Subject: [PATCH] 群组 --- ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java | 103 ++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 81 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..53cf4f2 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,106 @@ package com.ruoyi.rongcloud.service.Impl; -import com.ruoyi.common.core.domain.entity.SysUser; -import com.ruoyi.rongcloud.domain.TokenParam; +import com.ruoyi.common.core.redis.RedisCache; +import com.ruoyi.common.utils.SecurityUtils; +import com.ruoyi.rongcloud.domain.RongCloudGroupDisParam; +import com.ruoyi.rongcloud.domain.RongCloudGroupParam; +import com.ruoyi.rongcloud.domain.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; + + /** + * 鑾峰彇铻嶄簯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 Map<String, Object> groupCreate(RongCloudGroupParam group) { + group.setGroupId(String.valueOf(UUID.randomUUID())); + Map<String, Object> groupMap = rongCloudClient.groupCreate(getRongCloudHead(),group); + return groupMap; + } + + @Override + public Map<String, Object> groupDismiss(RongCloudGroupDisParam groupDis) { + Map<String, Object> groupMap = rongCloudClient.groupDismiss(getRongCloudHead(),groupDis); + return 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(new Date().getTime()); + 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