From 480439a44a66ede602aa57e5446ecdf2a3732923 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期一, 29 一月 2024 20:37:06 +0800
Subject: [PATCH] 车辆追踪session获取修改提交

---
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java |  106 ++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 104 insertions(+), 2 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
index 03de3dd..aebc0a0 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java
@@ -15,7 +15,11 @@
 
 import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.dtflys.forest.annotation.Var;
 import com.github.pagehelper.PageInfo;
+import com.ruoyi.app.application.domain.ArdAppApplication;
+import com.ruoyi.app.application.mapper.ArdAppApplicationMapper;
+import com.ruoyi.app.position.mapper.ArdAppPositionMapper;
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.core.redis.RedisCache;
@@ -24,6 +28,7 @@
 import com.ruoyi.sy.domain.ArdAccessFence;
 import com.ruoyi.sy.param.ArdSyCarParam;
 import com.ruoyi.sy.vo.ArdSyCarVo;
+import com.ruoyi.system.mapper.SysDeptMapper;
 import com.ruoyi.utils.gis.GisUtil;
 import com.ruoyi.utils.gis.Point;
 import com.ruoyi.scheduling.domian.SchedulingParam;
@@ -87,6 +92,12 @@
     RedisCache redisCache;
     @Resource
     private ArdSyCarDayMapper ardSyCarDayMapper;
+
+    @Resource
+    private ArdAppApplicationMapper ardAppApplicationMapper;
+
+    @Resource
+    private SysDeptMapper sysDeptMapper;
 
     @Value("${minio.endpoint}")
     private String minioEndpoint;
@@ -952,7 +963,14 @@
                                 if (position.size() != 0) {
                                     Map<String, Map<String, Object>> data = new HashMap();
                                     data.put("31000", position);
-                                    WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data));
+                                    //WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data));
+                                    String sessionId = "";
+                                    for(String key : ONLINE_USER_SESSIONS.keySet()){
+                                        if(key.startsWith(usersId + "_")){
+                                            sessionId = key;
+                                        }
+                                    }
+                                    WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(sessionId), JSON.toJSONString(data));
                                 }
                             }
                         }
@@ -974,7 +992,14 @@
                                 if (position.size() != 0) {
                                     Map<String, Map<String, Object>> data = new HashMap();
                                     data.put("31000", position);
-                                    WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data));
+                                    //WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(usersId), JSON.toJSONString(data));
+                                    String sessionId = "";
+                                    for(String key : ONLINE_USER_SESSIONS.keySet()){
+                                        if(key.startsWith(usersId + "_")){
+                                            sessionId = key;
+                                        }
+                                    }
+                                    WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(sessionId), JSON.toJSONString(data));
                                 }
                             }
                         }
@@ -1304,4 +1329,81 @@
         return sYClient.getAlarmHPfmCountDetail(syURL,carId,sessionId,startTime,endTime);
     }
 
+    @Override
+    public Map<String, Object> getOnlineSYCarPosition(String soilderId) {
+        Map<String,Object> result = new HashMap();
+        ArdSyUser ardSyUserPara = new ArdSyUser();
+        ardSyUserPara.setSysUserId(soilderId);
+        List<ArdSyUser> ardSyUserList = ardSyUserMapper.selectArdSyUserList(ardSyUserPara);
+        if(ardSyUserList.size() == 0){
+            result.put("code","0");
+            result.put("msg","鐧诲綍鐢ㄦ埛鏈寕鎺ヤ笁涓�杞﹁締璐﹀彿");
+            result.put("SYCarPositionList",new ArrayList());
+            return result;
+        }
+        ArdAppApplication ardAppApplicationPara = new ArdAppApplication();
+        ardAppApplicationPara.setSoilderId(soilderId);
+        ardAppApplicationPara.setApplicationType("SYCar");
+        ardAppApplicationPara.setState("1");
+        List<ArdAppApplication> ardAppApplicationList = ardAppApplicationMapper.selectArdAppApplicationList(ardAppApplicationPara);
+        if(ardAppApplicationList.size() == 0){
+            result.put("code","0");
+            result.put("msg","鐧诲綍鐢ㄦ埛鏈粡鎸囨尌绔悓鎰�");
+            result.put("SYCarPositionList",new ArrayList());
+            return result;
+        }
+        SysUser sysUser = userMapper.selectUserById(soilderId);//鑾峰彇绯荤粺鐢ㄦ埛
+        List<Long> deptIdList = new ArrayList();
+        deptIdList.add(sysUser.getDeptId());
+        deptIdList = getOwnAndChildrenDeptIdList(deptIdList,new ArrayList());//閫掑綊鏌ヨ涓嬪睘閮ㄩ棬涓婚敭
+        List<String> carIdList = ardSyCarMapper.selectArdSyCarByDeptIds(deptIdList);
+        String carIds = "";
+        for(String carId : carIdList){
+            carIds = carIds + carId + ",";
+        }
+        carIds = carIds.substring(0,carIds.length() - 1);
+        String syURL = "";
+        List<SysConfig> sysConfigResult = sysConfigMapper.selectByType("syCarPT");
+        if(sysConfigResult.size() > 0){
+            syURL = sysConfigResult.get(0).getConfigValue();
+        }else{
+            result.put("code","0");
+            result.put("msg","涓変竴杞﹁締url娌℃湁褰曞叆");
+            result.put("SYCarPositionList",new ArrayList());
+            return result;
+        }
+        String passwordMd5 = DigestUtils.md5Hex(ardSyUserList.get(0).getPassword());
+        Map<String,Object> syLoginResult = sYClient.logIn(syURL, passwordMd5, ardSyUserList.get(0).getUserId());
+        String sessionId = (String) syLoginResult.get("sessionId");
+        Map<String,Object> carNearPositionResult = sYClient.getCarNearPositionByCarId(syURL, carIds, ardSyUserList.get(0).getUserId(),sessionId);
+        if(((String)carNearPositionResult.get("rspCode")).equals("1")){
+            result.put("code","1");
+            result.put("msg","涓変竴杞﹁締鏌ヨ鎴愬姛");
+            List<Map<String,Object>> SYCarPositionList = (List<Map<String, Object>>) carNearPositionResult.get("list");
+            //绛涢�夊湪绾�
+            SYCarPositionList = SYCarPositionList.stream().filter(map -> ((String)map.get("stateCn")).startsWith("鍦ㄧ嚎")).collect(Collectors.toList());
+            for(Map<String,Object> sycar : SYCarPositionList){
+                Map<String,Object> map = ardSyCarMapper.getArdSyCarAndDeptByCarId((String)sycar.get("carId"));
+                sycar.putAll(map);
+            }
+            result.put("SYCarPositionList",SYCarPositionList);
+            return result;
+        }else{
+            result.put("code","0");
+            result.put("msg","涓変竴杞﹁締鏌ヨ澶辫触");
+            result.put("SYCarPositionList",new ArrayList());
+            return result;
+        }
+    }
+
+    public List<Long> getOwnAndChildrenDeptIdList(List<Long> deptIdList,List<Long> deptIdListr){
+        deptIdListr.addAll(deptIdList);
+        List<Long> result = sysDeptMapper.getChildrenDeptIdList(deptIdList);
+        if(result.size() != 0){
+            deptIdListr.addAll(result);
+            result = getOwnAndChildrenDeptIdList(result,deptIdListr);
+        }
+        deptIdListr = deptIdListr.stream().distinct().collect(Collectors.toList());
+        return deptIdListr;
+    }
 }

--
Gitblit v1.9.3