From e2ba762da8b42698d9477f7af93a2d3f8c7be373 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期六, 05 八月 2023 16:44:23 +0800
Subject: [PATCH] 增加存储模块,将minio工具类迁移到存储包 增加minio的通知功能,通过mqtt将通知入库 修复配置文件自定义字段标黄的问题

---
 ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java |   96 +++++++++++++++++++++++++++++++----------------
 1 files changed, 63 insertions(+), 33 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 8674902..1666afa 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,32 +1,23 @@
 package com.ruoyi.rongcloud.service.Impl;
 
-import com.alibaba.fastjson2.JSONObject;
-import com.fasterxml.jackson.databind.util.JSONPObject;
-import com.ruoyi.alarm.stealAlarm.domain.ArdAlarmStealelec;
-import com.ruoyi.common.core.domain.entity.SysUser;
-import com.ruoyi.common.utils.uuid.IdUtils;
-import com.ruoyi.common.utils.uuid.UUID;
-import com.ruoyi.rongcloud.domain.TokenParam;
+import com.ruoyi.common.core.redis.RedisCache;
+import com.ruoyi.common.utils.SecurityUtils;
+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 lombok.extern.slf4j.Slf4j;
-import okhttp3.FormBody;
-import okhttp3.RequestBody;
 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.HashMap;
+import java.util.List;
 import java.util.Map;
-import java.util.Random;
-
-import static org.bouncycastle.asn1.x500.style.RFC4519Style.l;
 
 /**
- * @Description:
+ * @Description: 閫氳瀺涓氬姟鏈嶅姟
  * @ClassName: RongCloudServiceImpl
  * @Author: 鍒樿嫃涔�
  * @Date: 2023骞�07鏈�15鏃�16:49:12
@@ -39,30 +30,69 @@
     @Resource
     RongCloudClient rongCloudClient;
     @Resource
-    ISysConfigService iSysConfigService;
-    @Override
-    public String getToken(String userId,String name) {
+    RedisCache redisCache;
 
-        String token="";
+    /**
+     * 鑾峰彇铻嶄簯token
+     *
+     * @param userId 鐢ㄦ埛id
+     * @param name   鐢ㄦ埛濮撳悕
+     */
+    @Override
+    public String getToken(String userId, String name) {
+
+        String token = "";
         try {
-            String rongyunApiUrl = iSysConfigService.selectConfigByKey("rongyun");
-            String appKey = iSysConfigService.selectConfigByKey("RongCloudAppKey");
-            String appSecret = iSysConfigService.selectConfigByKey("RongCloudAppSecret");
-            TokenParam param = new TokenParam();
+            RongCloudParam param = new RongCloudParam();
             param.setUserId(userId);
             param.setName(name);
-            String Nonce = RandomStringUtils.randomNumeric(18);
-            String Timestamp = String.valueOf(new Date().getTime());
-            String Signature = DigestUtils.sha1Hex(appSecret + Nonce + Timestamp);//App Secret + Nonce + Timestamp
-            String jsonStr = rongCloudClient.getToken(rongyunApiUrl, appKey, Nonce, Timestamp, Signature, param);
-            Map map = JSONObject.parseObject(jsonStr, Map.class);
+            Map map = rongCloudClient.getToken(getRongCloudHead(), param);
             token = (String) map.get("token");
-            log.debug("鐢ㄦ埛"+userId+"鑾峰彇鍒拌瀺浜憈oken:"+token);
-        }
-        catch (Exception ex)
-        {
-            log.error("鑾峰彇token寮傚父:"+ex.getMessage());
+            log.debug("鐢ㄦ埛" + userId + "鑾峰彇鍒拌瀺浜憈oken:" + token);
+        } catch (Exception ex) {
+            log.error("鑾峰彇token寮傚父:" + ex.getMessage());
         }
         return token;
     }
+
+    @Override
+    public Map 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);
+            onlineMap.put(userId, isOnline.get("status"));
+        }
+        return onlineMap;
+    }
+
+    @Override
+    public Boolean checkOnline(String userId) {
+        RongCloudParam param = new RongCloudParam();
+        param.setUserId(userId);
+        Map isOnline = rongCloudClient.checkOnline(getRongCloudHead(), param);
+        if (isOnline.get("status").equals("1")) {
+            return true;
+        } else {
+            return false;
+        }
+    }
+
+    /**
+     * 鑾峰彇铻嶄簯绛惧悕淇℃伅
+     */
+    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