From 9b88bdf9ae10df3b175802b555100410f6557d1a Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期一, 24 七月 2023 10:41:49 +0800
Subject: [PATCH] 三一车辆实时报警提交

---
 ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplAlarm.java        |  128 ++++++++++++++++++++++++++++++++++++++++++
 ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml           |    7 ++
 ruoyi-system/src/main/java/com/ruoyi/system/mapper/SysUserMapper.java     |    6 ++
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java    |    6 ++
 ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java         |    5 +
 ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java     |    2 
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java |   10 ++
 7 files changed, 161 insertions(+), 3 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 71d6c11..fb2a8c4 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
@@ -13,6 +13,7 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.sy.domain.ArdSyUser;
+import com.ruoyi.sy.gps31.PushClientImplAlarm;
 import com.ruoyi.sy.gps31.PushClientImplPosition;
 import com.ruoyi.sy.service.IArdSyUserService;
 import com.ruoyi.system.domain.SysConfig;
@@ -95,6 +96,11 @@
             }
         };
         carPositionTimer.scheduleAtFixedRate(carPositionTask,date,3*1000);//鍚敤
+
+        //杞﹁締瀹炴椂浣嶇疆绾跨▼
+        PushClientImplAlarm pushClientImplAlarm = new PushClientImplAlarm(ip,ardSyUserList.get(0).getUserId(),ardSyUserList.get(0).getPassword());
+        Thread pushClientImplAlarmThread = new Thread(pushClientImplAlarm);
+        pushClientImplAlarmThread.start();
     }
 
     /**
diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplAlarm.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplAlarm.java
new file mode 100644
index 0000000..4e20729
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplAlarm.java
@@ -0,0 +1,128 @@
+/**
+ * <p>Description: </p>
+ * <p>Copyright: Copyright (c) 2020</p>
+ * <p>Company: www.31gps.net</p>
+ * @author chencq
+ * @version 1.0
+ */
+package com.ruoyi.sy.gps31;
+
+import com.alibaba.fastjson2.JSON;
+import com.gps31.push.netty.PushClient;
+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;
+
+import java.text.SimpleDateFormat;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * <p>Description: </p>
+ * <p>Copyright: Copyright (c) 2020</p>
+ * <p>Company: www.31gps.net</p>
+ * @author chencq
+ * @version 1.0
+ */
+public class PushClientImplAlarm extends PushClient implements Runnable {
+
+    private static final Log log = LogFactory.getLog(PushClientImplAlarm.class);
+
+    private String ip;
+
+    private String userId;
+
+    private String password;
+
+    public PushClientImplAlarm(String ip, String userId, String password) {
+        this.ip = ip;
+        this.userId = userId;
+        this.password = password;
+    }
+
+    public PushClientImplAlarm() {
+
+    }
+
+    @Override
+    public void messageReceived(TcpClient tcpClient, PushMsg pushMsg)
+            throws Exception {
+        if("8001".equals(pushMsg.getCmd())) {//鐧诲綍搴旂瓟
+            String rspResult = MapUtil.getStrVal(pushMsg.getJsonMap(),"rspResult","1");
+            if("0".equals(rspResult)) {//鐧诲綍鎴愬姛锛屽畾闃呭姩鎬佹秷鎭�
+                Map<String,Object> map = new HashMap<String,Object>();
+                map.put("seq", "1");
+                map.put("action", "add");
+                map.put("msgIds", JSON.toJSONString(getSubCmdSet()));
+                PushMsg subMsg = getInstance("0003",map);
+                sendMsg(subMsg);
+            }
+        }else if("8002".equals(pushMsg.getCmd())){//蹇冭烦搴旂瓟
+
+        }else if("8003".equals(pushMsg.getCmd())){//璁㈤槄鍔ㄦ�佹秷鎭簲绛�
+            String rspResult = MapUtil.getStrVal(pushMsg.getJsonMap(),"rspResult","1");
+            //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","");//鑾峰彇杞︾墝鍙�
+            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)));
+            /**
+             *
+             * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
+             *
+             */
+        }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)));*/
+            String carId = (String)alarmMap.get("carId");
+            Map<String,Object> result = ((ArdSyCarServiceImpl) SpringUtils.getBean("ardSyCarServiceImpl")).getArdSyCarAndDeptByCarId(carId);//鏌ヨ杞﹁締鍙婇儴闂�
+            if(result != null){
+                alarmMap.putAll(result);
+            }
+            Map<Integer,Object> data = new HashMap();
+            data.put(40000, alarmMap);
+            ((ArdSyCarServiceImpl) SpringUtils.getBean("ardSyCarServiceImpl")).sendArdSyCarAlarmByCarId(carId,data);//鏌ヨ杞﹁締鍙婇儴闂�
+        }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)));
+            /**
+             *
+             * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
+             *
+             */
+        }
+    }
+
+    public void sendMassage() {
+        try {
+            PushClientImplPosition client = new PushClientImplPosition();
+            client.setLog(false);//鏄惁鎵撳嵃鏄庢枃
+            client.setHost(this.ip);//鏈嶅姟鍣↖P
+            client.setPort(10100);//鏈嶅姟鍣ㄧ鍙�
+            client.setUserName(this.userId);//绯荤粺鐢ㄦ埛鍚�
+            client.setPwd(this.password);//绯荤粺鐢ㄦ埛瀵嗙爜
+            client.setSubMsgIds("0300");//璁㈤槄鐨勫姩鎬佹秷鎭紝澶氫釜鍔ㄦ�佹秷鎭娇鐢▅杈熷垎锛屽綋鍓嶇ず渚嬫槸璁㈤槄  瀹氫綅娑堟伅(0x0200)鍜屾姤璀︽秷鎭�(0x0300)
+            client.setDesc("娴嬭瘯瀹㈡埛绔�");//瀹㈡埛绔殑鎻忚堪锛�
+            client.start();
+            while(true) {
+                Thread.sleep(1000);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+
+    @Override
+    public void run() {
+        sendMassage();
+    }
+}
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 bb667de..aa2e1b2 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
@@ -143,7 +143,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/service/IArdSyCarService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdSyCarService.java
index ce5df91..3538608 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
@@ -92,6 +92,11 @@
      * 鏍规嵁閮ㄩ棬鍙戦�佽溅杈嗗疄鏃朵綅缃�
      */
     public void sendArdSyCarPosition();
+
+    /**
+     * 鏍规嵁閮ㄩ棬鍙戦�佽溅杈嗗疄鏃舵姤璀�
+     */
+    public void sendArdSyCarAlarmByCarId(String carId, Map<Integer,Object> data);
 //    List<ArdSyCar> getArdSyCarWithRightByCarIdList(List<String> carIdList);
     Results carListById(String id);
 
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 88fd800..7dc8c9e 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
@@ -371,11 +371,17 @@
             SysUser sysUser = userMapper.selectUserById(key);
             String deptId = String.valueOf(sysUser.getDeptId());
             Map<String,Map<String,Object>> map = PositionContainer.getDeptPositionMap().get(deptId);
-            System.out.println("/////////////");
-            System.out.println(PositionContainer.getDeptPositionMap());
             Map<Integer,Object> data = new HashMap();
             data.put(30000, map.values());
             WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(key), JSON.toJSONString(data));
         }
     }
+
+    @Override
+    public void sendArdSyCarAlarmByCarId(String carId, Map<Integer,Object> data) {
+        List<SysUser> result = userMapper.getSysUserByCarId(carId);
+        for(SysUser sysUser : result){
+            WebSocketUtils.sendMessage(ONLINE_USER_SESSIONS.get(sysUser.getUserId()), JSON.toJSONString(data));
+        }
+    }
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/SysUserMapper.java b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/SysUserMapper.java
index bf69eff..0d0b987 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/SysUserMapper.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/SysUserMapper.java
@@ -130,4 +130,10 @@
      * @return 缁撴灉
      */
     public SysUser checkEmailUnique(String email);
+
+    /**
+     * 鏍规嵁杞﹁締涓婚敭鏌ヨ鐩村睘鍙婁笂绾х敤鎴�
+     *
+     */
+    public List<SysUser> getSysUserByCarId(String carId);
 }
diff --git a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
index 08396d0..5f916c9 100644
--- a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
+++ b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml
@@ -283,4 +283,11 @@
         </foreach>
     </delete>
 
+    <select id="getSysUserByCarId" parameterType="java.lang.String" resultMap="SysUserResult">
+        select * from sys_user su where su.dept_id in (
+        select cast(unnest(array_append(string_to_array(sd.ancestors,','),
+        cast(sd.dept_id as text))) as int) from ard_sy_car asy
+        inner join sys_dept sd on asy.dept_id = sd.dept_id
+        where asy.car_id = #{carId})
+    </select>
 </mapper> 
\ No newline at end of file

--
Gitblit v1.9.3