From 2a83dc06a43087f7ca6bebd5440530b2b3c16b85 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期六, 22 七月 2023 15:30:52 +0800
Subject: [PATCH] 三一车辆消息打印取消提交

---
 ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml                  |    8 ++
 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java            |    7 ++
 ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java          |   19 ++++++
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java    |   18 ++++-
 ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java         |   10 +++
 ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java     |   47 +++++++++++++--
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java |   32 ++++++++++
 7 files changed, 131 insertions(+), 10 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
index 27d8afc..fdd4998 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java
@@ -1,9 +1,6 @@
 package com.ruoyi.sy.controller;
 
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import javax.annotation.PostConstruct;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
@@ -18,6 +15,8 @@
 import com.ruoyi.sy.service.SysParaService;
 import com.ruoyi.system.domain.SysConfig;
 import com.ruoyi.system.service.ISysConfigService;
+import com.ruoyi.system.service.ISysDeptService;
+import com.ruoyi.system.service.ISysUserService;
 import com.ruoyi.utils.httpclient.SYCarClient;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
@@ -36,6 +35,8 @@
 import org.springframework.web.context.request.RequestContextHolder;
 import org.springframework.web.context.request.ServletRequestAttributes;
 import org.springframework.web.multipart.MultipartFile;
+
+import static com.ruoyi.common.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS;
 
 /**
  * 涓変竴杞﹁締Controller
@@ -85,6 +86,15 @@
         PushClientImplPosition pushClientImplPosition = new PushClientImplPosition(ip,ardSyUserList.get(0).getUserId(),ardSyUserList.get(0).getPassword());
         Thread pushClientImplPositionThread = new Thread(pushClientImplPosition);
         pushClientImplPositionThread.start();
+
+        Date date = new Date();
+        Timer carPositionTimer = new Timer();//瀹氭椂鎺ㄩ�佸疄鏃朵綅缃�
+        TimerTask carPositionTask =new TimerTask(){
+            public void run(){
+                ardSyCarService.sendArdSyCarPosition();
+            }
+        };
+        carPositionTimer.scheduleAtFixedRate(carPositionTask,date,3*1000);//鍚敤
     }
 
     /**
diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java
new file mode 100644
index 0000000..ac30783
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PositionContainer.java
@@ -0,0 +1,19 @@
+package com.ruoyi.sy.gps31;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+public class PositionContainer {
+
+    private static Map<String, Map<String,Map<String,Object>>> deptPositionMap = new HashMap();//渚濋儴闂ㄥ瓨鏀惧疄鏂借溅杈嗕綅缃�:deptId锛宑arId锛岃溅杈嗕綅缃�
+
+    public static Map<String, Map<String, Map<String,Object>>> getDeptPositionMap() {
+        return deptPositionMap;
+    }
+
+    public static void setDeptPositionMap(Map<String, Map<String, Map<String,Object>>> deptPositionMap) {
+        PositionContainer.deptPositionMap = deptPositionMap;
+    }
+
+}
diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
index 00765d5..480922a 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java
@@ -12,6 +12,8 @@
 import com.gps31.push.netty.PushMsg;
 import com.gps31.push.netty.client.TcpClient;
 import com.gps31.push.util.MapUtil;
+import com.ruoyi.common.utils.spring.SpringUtils;
+import com.ruoyi.sy.service.impl.ArdSyCarServiceImpl;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
 
@@ -64,13 +66,46 @@
 
         }else if("8003".equals(pushMsg.getCmd())){//璁㈤槄鍔ㄦ�佹秷鎭簲绛�
             String rspResult = MapUtil.getStrVal(pushMsg.getJsonMap(),"rspResult","1");
-            log.error(String.format("    璁㈤槄搴旂瓟:%s", "0".equals(rspResult)?"鎴愬姛":"澶辫触"));
+            //log.error(String.format("    璁㈤槄搴旂瓟:%s", "0".equals(rspResult)?"鎴愬姛":"澶辫触"));
         }else if("0200".equals(pushMsg.getCmd())) {//瀹氫綅淇℃伅
             Map<String,Object> gpsMap = pushMsg.getJsonMap();
-            String carName = MapUtil.getStrVal(gpsMap, "carName","");//鑾峰彇杞︾墝鍙�
+            /*String carName = MapUtil.getStrVal(gpsMap, "carName","");//鑾峰彇杞︾墝鍙�
             SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
             System.out.println(sdf.format(new Date()));
-            log.error(String.format("   ---->鏀跺埌瀹氫綅鏁版嵁:%s",JSON.toJSONString(gpsMap)));
+            log.error(String.format("   ---->鏀跺埌瀹氫綅鏁版嵁:%s",JSON.toJSONString(gpsMap)));*/
+            String carId = (String)gpsMap.get("carId");
+            Map<String,Object> result = ((ArdSyCarServiceImpl)SpringUtils.getBean("ardSyCarServiceImpl")).getArdSyCarAndDeptByCarId(carId);//鏌ヨ杞﹁締鍙婇儴闂�
+            gpsMap.putAll(result);
+            String ancestors = (String) gpsMap.get("ancestors");//鑾峰彇鐖剁骇閮ㄩ棬
+            String[] ancestorsArray = ancestors.split(",");
+            if(ancestorsArray.length == 1){//鏈�楂樼骇閮ㄩ棬
+                String deptId = String.valueOf(gpsMap.get("deptId"));
+                Map<String,Map<String,Object>> deptMap = PositionContainer.getDeptPositionMap().get(deptId);
+                if(deptMap == null){
+                    deptMap = new HashMap();
+                }
+                deptMap.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲�
+                PositionContainer.getDeptPositionMap().put(deptId,deptMap);
+            }else{
+                //鍔犲叆鏈儴闂ㄥ鍣�
+                String deptId = String.valueOf(gpsMap.get("deptId"));
+                Map<String,Map<String,Object>> deptMap = PositionContainer.getDeptPositionMap().get(deptId);
+                if(deptMap == null){
+                    deptMap = new HashMap();
+                }
+                deptMap.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲�
+                PositionContainer.getDeptPositionMap().put(deptId,deptMap);
+                //鍔犲叆鐖剁骇閮ㄩ棬瀹瑰櫒
+                for(int i = 1;i <= ancestorsArray.length - 1;i++){
+                    String deptIdp = String.valueOf(gpsMap.get(ancestorsArray[i]));
+                    Map<String,Map<String,Object>> deptMapp = PositionContainer.getDeptPositionMap().get(deptIdp);
+                    if(deptMapp == null){
+                        deptMapp = new HashMap();
+                    }
+                    deptMapp.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲�
+                    PositionContainer.getDeptPositionMap().put(deptIdp,deptMap);
+                }
+            }
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -79,7 +114,7 @@
         }else if("0300".equals(pushMsg.getCmd())) {//鎶ヨ娑堟伅
             Map<String,Object> alarmMap = pushMsg.getJsonMap();
             String carName = MapUtil.getStrVal(alarmMap, "carName","");//鑾峰彇杞︾墝鍙�
-            log.error(String.format("   ---->鏀跺埌鎶ヨ鏁版嵁:%s",JSON.toJSONString(alarmMap)));
+            //log.error(String.format("   ---->鏀跺埌鎶ヨ鏁版嵁:%s",JSON.toJSONString(alarmMap)));
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -88,7 +123,7 @@
         }else if("0401".equals(pushMsg.getCmd())) {//閫忎紶娑堟伅
             Map<String,Object> dataMap = pushMsg.getJsonMap();
             String carName = MapUtil.getStrVal(dataMap, "carName","");//鑾峰彇杞︾墝鍙�
-            log.error(String.format("   ---->鏀跺埌閫忎紶鏁版嵁:%s",JSON.toJSONString(dataMap)));
+            //log.error(String.format("   ---->鏀跺埌閫忎紶鏁版嵁:%s",JSON.toJSONString(dataMap)));
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -100,7 +135,7 @@
     public void sendMassage() {
         try {
             PushClientImplPosition client = new PushClientImplPosition();
-            client.setLog(true);//鏄惁鎵撳嵃鏄庢枃
+            client.setLog(false);//鏄惁鎵撳嵃鏄庢枃
             client.setHost(this.ip);//鏈嶅姟鍣↖P
             client.setPort(10100);//鏈嶅姟鍣ㄧ鍙�
             client.setUserName(this.userId);//绯荤粺鐢ㄦ埛鍚�
diff --git a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
index 1eb7c7d..b30bb6f 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdSyCarMapper.java
@@ -1,6 +1,8 @@
 package com.ruoyi.sy.mapper;
 
 import java.util.List;
+import java.util.Map;
+
 import com.ruoyi.sy.domain.ArdSyCar;
 
 /**
@@ -73,4 +75,9 @@
      * @return
      */
     List<ArdSyCar> carListById(String id);
+
+    /**
+     * 鏍规嵁杞﹁締id鏌ヨ涓変竴杞﹁締鍙婂搴旈儴闂�
+     */
+    public Map<String, Object> getArdSyCarAndDeptByCarId(String carId);
 }
diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
index bd2ac07..498cb5b 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
@@ -83,4 +83,14 @@
     public String uploadCarPicture(String id, MultipartFile carPicture);
 
     List<ArdSyCar> carListById(String id);
+
+    /**
+     * 鏍规嵁杞﹁締id鏌ヨ涓変竴杞﹁締鍙婂搴旈儴闂�
+     */
+    public Map<String,Object> getArdSyCarAndDeptByCarId(String carId);
+
+    /**
+     * 鏍规嵁閮ㄩ棬鍙戦�佽溅杈嗗疄鏃朵綅缃�
+     */
+    public void sendArdSyCarPosition();
 }
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 b14beaa..1021f23 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
@@ -8,13 +8,18 @@
 import java.util.function.Predicate;
 import java.util.stream.Collectors;
 
+import com.alibaba.fastjson.JSON;
+import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.utils.uuid.IdUtils;
+import com.ruoyi.common.websocket.util.WebSocketUtils;
 import com.ruoyi.device.hiksdk.config.MinioClientSingleton;
 import com.ruoyi.device.hiksdk.util.minio.MinioUtils;
 import com.ruoyi.sy.domain.ArdSyUser;
+import com.ruoyi.sy.gps31.PositionContainer;
 import com.ruoyi.sy.mapper.ArdSyUserMapper;
 import com.ruoyi.system.domain.SysConfig;
 import com.ruoyi.system.mapper.SysConfigMapper;
+import com.ruoyi.system.mapper.SysUserMapper;
 import com.ruoyi.utils.httpclient.SYCarClient;
 import io.minio.GetPresignedObjectUrlArgs;
 import io.minio.ListObjectsArgs;
@@ -29,6 +34,8 @@
 import org.springframework.web.multipart.MultipartFile;
 
 import javax.annotation.Resource;
+
+import static com.ruoyi.common.websocket.util.WebSocketUtils.ONLINE_USER_SESSIONS;
 
 /**
  * 涓変竴杞﹁締Service涓氬姟灞傚鐞�
@@ -46,6 +53,9 @@
 
     @Resource
     private ArdSyUserMapper ardSyUserMapper;
+
+    @Resource
+    private SysUserMapper userMapper;
 
 
     /**
@@ -324,8 +334,30 @@
         }
     }
 
+
     @Override
     public List<ArdSyCar> carListById(String id) {
         return ardSyCarMapper.carListById(id);
     }
+
+    @Override
+    public Map<String, Object> getArdSyCarAndDeptByCarId(String carId) {
+        Map<String, Object> result = ardSyCarMapper.getArdSyCarAndDeptByCarId(carId);
+        return result;
+    }
+
+    @Override
+    public void sendArdSyCarPosition() {
+        for(String key : ONLINE_USER_SESSIONS.keySet()){
+            SysUser sysUser = userMapper.selectUserById(key);
+            String deptId = String.valueOf(sysUser.getDeptId());
+            Map<String,Map<String,Object>> map = PositionContainer.getDeptPositionMap().get(deptId);
+            List<Map<String,Object>> positionList = (List<Map<String, Object>>) map.values();
+            if(positionList.size() != 0){
+                Map<Integer,Object> data = new HashMap();
+                data.put(30000,positionList);
+                WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(key), JSON.toJSONString(positionList));
+            }
+        }
+    }
 }
diff --git a/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml b/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
index 35d3c4b..04da96d 100644
--- a/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
+++ b/ard-work/src/main/resources/mapper/sy/ArdSyCarMapper.xml
@@ -105,4 +105,12 @@
     <select id="carListById" parameterType="String" resultMap="ArdSyCarResult">
         select * from ard_sy_car where id = #{id}
     </select>
+    <select id="getArdSyCarAndDeptByCarId" parameterType="String" resultType="java.util.Map">
+        select asc0.id,asc0.car_id as "carId",coalesce(asc0.car_model,'') as "carModel",
+        coalesce(asc0.car_type,'') as "carType",coalesce(asc0.car_brand,'') as "carBrand",
+        asc0.dept_id as "deptId",asc0.car_picture as "carPicture",sd.ancestors,
+        sd.dept_name as "deptName" from ard_sy_car asc0
+        inner join sys_dept sd on asc0.dept_id = sd.dept_id
+        where asc0.car_id = #{carId}
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.3