From e5c8f327e3735a252610eb167d08ae3773b65184 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期六, 20 一月 2024 15:20:46 +0800
Subject: [PATCH] 查询本部门在线PC端通过websocket判断提交

---
 ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java |   24 ++++++++++++++++++++++++
 1 files changed, 24 insertions(+), 0 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
index 8aead3f..95c1a94 100644
--- a/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/app/position/service/impl/ArdAppPositionServiceImpl.java
@@ -14,6 +14,7 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.scheduling.domian.SchedulingParam;
+import com.ruoyi.system.mapper.SysUserMapper;
 import com.ruoyi.system.service.ISysUserService;
 import com.ruoyi.utils.gis.GisUtil;
 import com.ruoyi.utils.gis.Point;
@@ -24,6 +25,8 @@
 import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.stream.Collectors;
+
+import static com.ruoyi.utils.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS;
 
 
 /**
@@ -45,6 +48,8 @@
     ArdWallMapper ardWallMapper;
     @Resource
     IArdAlarmWallService ardAlarmWallService;
+    @Resource
+    private SysUserMapper sysUserMapper;
 
     Map<String, String> firstAlarmMap = new HashMap<>();//棣栨鎶ヨ缂撳瓨key:鐢ㄦ埛id_鍥存爮id value: 鎶ヨid
     /**
@@ -321,4 +326,23 @@
         }
         return ardAlarmWalls;
     }
+
+    @Override
+    public Map<String, List<SysUser>> getOnlinePCOrCommander(String usersId) {
+        Map<String, List<SysUser>> result = new HashMap();
+        List<SysUser> commanderList = sysUserMapper.getOnlineCommander(usersId);
+        result.put("commander",commanderList);
+        try{
+            List<String> onLinePCIdList = new ArrayList();
+            //onLinePCIdList.addAll(ONLINE_USER_SESSIONS.keySet());
+            for(String id : ONLINE_USER_SESSIONS.keySet()){
+                onLinePCIdList.add(id.split("_")[0]);
+            }
+            List<SysUser> pcList = sysUserMapper.getOnlinePC(usersId,onLinePCIdList);
+            result.put("pc",pcList);
+        }catch(Exception e){
+            result.put("pc",new ArrayList());
+        }
+        return result;
+    }
 }

--
Gitblit v1.9.3