From 929c5384397b981d427c83e1e4c13ed62b0bda10 Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期四, 17 八月 2023 15:09:39 +0800
Subject: [PATCH] 修改一件调度获取在线用户

---
 ard-work/src/main/java/com/ruoyi/rongcloud/service/Impl/RongCloudServiceImpl.java |   93 +++++++++++++++++++++++++++++++++-------------
 1 files changed, 67 insertions(+), 26 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 4016925..104ad6e 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,53 +1,94 @@
 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.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 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.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
- * @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 jsonStr = rongCloudClient.getToken(rongyunApiUrl,appKey, Nonce, Timestamp, Signature, param);
-        Map map = JSONObject.parseObject(jsonStr, Map.class);
-        String token = (String)map.get("token");
+    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");
+    }
+
+    /**
+     * 鑾峰彇铻嶄簯绛惧悕淇℃伅
+     */
+    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