From 82f8f0065a27acf9f7e1558b04fa75ce68a7fa50 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期二, 26 三月 2024 17:05:30 +0800
Subject: [PATCH] 31

---
 ard-work/src/main/java/com/ruoyi/sy/controller/ArdSyCarController.java |   92 +++++++++++++++++++++++++++++++++-------------
 1 files changed, 66 insertions(+), 26 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 314679f..feaa81f 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,7 +1,6 @@
 package com.ruoyi.sy.controller;
 
 import java.io.UnsupportedEncodingException;
-import java.net.URLEncoder;
 import java.text.SimpleDateFormat;
 import java.util.*;
 import javax.annotation.PostConstruct;
@@ -9,9 +8,13 @@
 import javax.servlet.http.HttpServletResponse;
 
 import com.alibaba.fastjson2.JSON;
+import com.github.pagehelper.PageHelper;
+import com.github.pagehelper.PageInfo;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
+import com.ruoyi.sy.param.ArdSyCarParam;
+import com.ruoyi.sy.vo.ArdSyCarVo;
 import com.ruoyi.sy.domain.ArdSyUser;
 import com.ruoyi.sy.gps31.PositionContainer;
 import com.ruoyi.sy.gps31.PushClientImplAlarm;
@@ -26,6 +29,7 @@
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.apache.commons.codec.digest.DigestUtils;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
@@ -36,12 +40,11 @@
 import com.ruoyi.sy.domain.ArdSyCar;
 import com.ruoyi.sy.service.IArdSyCarService;
 import com.ruoyi.common.utils.poi.ExcelUtil;
-import com.ruoyi.common.core.page.TableDataInfo;
 import org.springframework.web.multipart.MultipartFile;
 
 /**
  * 涓変竴杞﹁締Controller
- * 
+ *
  * @author ard
  * @date 2023-06-26
  */
@@ -73,17 +76,20 @@
 
     private ArdSyCarController ardSyCarController;
 
+    @Value("${syCar.enabled}")
+    private Boolean syCarEnabled;
+
     @PostConstruct
     public void init(){
         ardSyCarController = this;
         ardSyCarController.sysConfigService = this.sysConfigService;
         ardSyCarController.iArdSyUserService = this.iArdSyUserService;
-
         SysConfig config = new SysConfig();
         config.setConfigKey("syCarPT");
         List<SysConfig> sysConfigResult = sysConfigService.selectConfigList(config);
         String syURL = "";
-        if(sysConfigResult.size() == 0){
+        //if(sysConfigResult.size() == 0){
+        if(!syCarEnabled){//涓変竴杞﹁締鍔犲叆寮�鍏�
             return;
         }else{
             syURL = sysConfigResult.get(0).getConfigValue();
@@ -107,9 +113,8 @@
                 ardSyCarService.sendArdSyCarPosition();
             }
         };
-        carPositionTimer.scheduleAtFixedRate(carPositionTask,date,3*1000);//鍚敤
-
-        //杞﹁締瀹炴椂浣嶇疆绾跨▼
+        //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();
@@ -120,11 +125,13 @@
      */
     @PreAuthorize("@ss.hasPermi('sy:syCar:list')")
     @GetMapping("/list")
-    public TableDataInfo list(ArdSyCar ardSyCar)
+    @ApiOperation("鏌ヨ涓変竴杞﹁締鍒楄〃")
+    public AjaxResult list(ArdSyCarParam ardSyCarParam)
     {
-        startPage();
-        List<ArdSyCar> list = ardSyCarService.selectArdSyCarList(ardSyCar);
-        return getDataTable(list);
+        PageHelper.startPage(ardSyCarParam.getPageNum(),ardSyCarParam.getPageSize());
+        String userId = SecurityUtils.getUserId();
+        Map<String,Object> result = ardSyCarService.getArdSyCarAll(userId);
+        return ardSyCarService.ardSyCarList(ardSyCarParam,result);
     }
 
     /**
@@ -181,7 +188,7 @@
      */
     @PreAuthorize("@ss.hasPermi('sy:syCar:remove')")
     @Log(title = "涓変竴杞﹁締", businessType = BusinessType.DELETE)
-	@DeleteMapping("/{ids}")
+    @DeleteMapping("/{ids}")
     @ApiOperation("鍒犻櫎涓変竴杞﹁締")
     public AjaxResult remove(@PathVariable String[] ids)
     {
@@ -216,7 +223,7 @@
     /**
      * 鑾峰彇鏈寕鎺ユ潈闄愮殑涓変竴杞﹁締
      */
-    @PreAuthorize("@ss.hasPermi('sy:syCar:getArdSyCarNoRight')")
+//    @PreAuthorize("@ss.hasPermi('sy:syCar:getArdSyCarNoRight')")
     @PostMapping("/getArdSyCarNoRight")
     @ApiOperation("鑾峰彇鏈寕鎺ユ潈闄愮殑涓変竴杞﹁締")
     public Map<String,Object> getArdSyCarNoRight(){
@@ -234,7 +241,7 @@
     /**
      * 鑾峰彇鍏ㄩ儴鐨勪笁涓�杞﹁締
      */
-    @PreAuthorize("@ss.hasPermi('sy:syCar:getArdSyCarAll')")
+//    @PreAuthorize("@ss.hasPermi('sy:syCar:getArdSyCarAll')")
     @PostMapping("/getArdSyCarAll")
     @ApiOperation("鑾峰彇鍏ㄩ儴鐨勪笁涓�杞﹁締")
     public Map<String,Object> getArdSyCarAll(){
@@ -252,7 +259,7 @@
     /**
      * 鑾峰彇鍏ㄩ儴杞﹁締妯″瀷
      */
-    @PreAuthorize("@ss.hasPermi('sy:syCar:getAllCarModel')")
+//    @PreAuthorize("@ss.hasPermi('sy:syCar:getAllCarModel')")
     @PostMapping("/getAllCarModel")
     @ApiOperation("鑾峰彇鍏ㄩ儴杞﹁締妯″瀷")
     public Map<String,Object> getAllCarModel(){
@@ -286,7 +293,11 @@
         String usersId = SecurityUtils.getUserId();
         ArdSyUser ardSyUser = iArdSyUserService.userById(usersId);
         String syURL = sysConfigService.getSYURL();
-        return ardSyCarService.allListByUser(ardSyUser,syURL,usersId);
+        //鏍规嵁userId鏌ヨ閮ㄩ棬Id
+        SysUser sysUser = sysUserService.selectUserById(usersId);
+        //鏍规嵁褰撳墠deptId鎴栬�呭綋鍓嶅強鎵�灞炰笅绾х殑鎵�鏈塪eptId
+        List<Long> deptList = sysDeptService.deptIdBySub(sysUser.getDeptId());
+        return ardSyCarService.allListByUser(ardSyUser,syURL,usersId,deptList);
     }
 
     @PreAuthorize("@ss.hasPermi('sy:syCar:carList')")
@@ -315,7 +326,7 @@
         }
     }
 
-    @PreAuthorize("@ss.hasPermi('sy:syCar:carListById')")
+    //    @PreAuthorize("@ss.hasPermi('sy:syCar:carListById')")
     @PostMapping("/carListById/{id}")
     @ApiOperation("鏍规嵁杞﹁締ID鑾峰彇杞﹁締鍒楄〃")
     public Results carListById(@PathVariable String id){
@@ -343,6 +354,8 @@
             return Results.succeed();
         }else {
             map.put("userId",ardSyUser.getUserId());
+            map.put("password",ardSyUser.getPassword());
+            map.put("passwords",DigestUtils.md5Hex(ardSyUser.getPassword()));
         }
         return Results.succeed(map);
     }
@@ -356,7 +369,7 @@
         SysUser sysUser = sysUserService.selectUserById(usersId);
         Map<String, Map<String,Map<String,Object>>> deptPositionMap = PositionContainer.getDeptPositionMap();
         if(deptPositionMap.isEmpty()){
-            return Results.succeed();
+            return Results.error("31骞冲彴鏃犺溅杈嗕綅缃繑鍥�");
         }else {
 //            return Results.succeed(deptPositionMap.get(sysUser.getDeptId().toString()).get(map.get("carId")));
             return Results.succeed(deptPositionMap.get(sysUser.getDeptId().toString()));
@@ -371,7 +384,7 @@
         ArdSyUser ardSyUser = iArdSyUserService.userById(usersId);
         String carId = map.get("carId");
         String syURL = sysConfigService.getSYURL();
-        return ardSyCarService.getCarGPSBycarId(usersId,carId,syURL,ardSyUser);
+        return Results.succeed(ardSyCarService.getCarGPSBycarId(usersId,carId,syURL,ardSyUser));
     }
 
     @PreAuthorize("@ss.hasPermi('sy:syCar:chaseCarByCarId')")
@@ -402,12 +415,11 @@
         long tenSeconds = 1000L;
         Date beforeTenSeconds = new Date(currentTime.getTime() - tenSeconds);
         String startTime = sdf.format(beforeTenSeconds);
-        System.out.println(startTime);
         String usersId = SecurityUtils.getUserId();
         ArdSyUser ardSyUser = iArdSyUserService.userById(usersId);
         String syURL = sysConfigService.getSYURL();
         String sessionId = ardSyCarService.getSessionId(syURL,ardSyUser);
-        System.out.println(sessionId);
+        System.out.println("sessionId:"+sessionId);
         //鑾峰彇鎽勫儚閫氶亾淇℃伅
         Map<String, Object> result = ardSyCarService.getCarPicture(carId,syURL,sessionId);
         String vs = "";
@@ -415,7 +427,7 @@
             //鎻愬彇閫氶亾淇℃伅
             Map<String,Object> map = ((List<Map<String,Object>>)result.get("list")).get(0);
             Map<String, Object> videos = (Map<String, Object>) JSON.parse((String) map.get("videos"));
-            System.out.println(videos);
+            System.out.println("閫氶亾锛�"+videos);
             vs = (String) videos.get("vs");
         } catch (Exception e) {
             return AjaxResult.error("璇ヨ溅杈嗘病鏈夋憚鍍忛�氶亾鏃犵収鐗囨暟鎹紒");
@@ -428,10 +440,10 @@
         }
         //鎷嶇収
         Map<String,Object> sendCmdMap = ardSyCarService.sendCmd(ardSyUser.getUserId(),syURL,sessionId,carId,channelList);
-        System.out.println(sendCmdMap);
+        System.out.println("鎷嶇収锛�"+sendCmdMap);
         //鑾峰彇鐓х墖
         Map<String,Object> photoMap = ardSyCarService.getPhoto(syURL,carId,sessionId,startTime);
-        System.out.println(photoMap);
+        System.out.println("鑾峰彇鐓х墖锛�"+photoMap);
         return AjaxResult.success(photoMap);
     }
 
@@ -448,7 +460,35 @@
     @GetMapping("getThreeOne")
     @ApiOperation("鑾峰彇涓変竴瑙嗛鍦板潃")
     public AjaxResult getThreeOne() {
-        return AjaxResult.success("鑾峰彇鍦板潃鎴愬姛锛�",sysConfigService.selectConfigByKey("threeOneVideo"));
+        return AjaxResult.success("鑾峰彇鍦板潃鎴愬姛锛�",sysConfigService.getSYVideo());
+    }
+
+    @PreAuthorize("@ss.hasPermi('sy:syCar:getAlarmHPfmCountDetail')")
+    @PostMapping("getAlarmHPfmCountDetail")
+    @ApiOperation("鏍规嵁杞﹁締鍜屾椂闂存鏌ヨ鎶ヨ鍘嗗彶璁板綍璇︽儏")
+    public AjaxResult getAlarmHPfmCountDetail(@RequestBody Map<String,String> map){
+        String usersId = SecurityUtils.getUserId();
+        ArdSyUser ardSyUser = iArdSyUserService.userById(usersId);
+        String carId = map.get("carId");
+        String startTime = map.get("startTime");
+        String endTime = map.get("endTime");
+        String syURL = sysConfigService.getSYURL();
+        String sessionId = ardSyCarService.getSessionId(syURL,ardSyUser);
+        Map<String, Object> mapDetail =  ardSyCarService.getAlarmHPfmCountDetail(sessionId,usersId,carId,startTime,endTime,syURL);
+        return AjaxResult.success(mapDetail);
+    }
+
+    @GetMapping("/getOnlineSYCarPosition")
+    @ApiOperation("鍗曞叺绔煡鐪嬪凡閫氳繃瀹℃壒鐨勫湪绾夸笁涓�杞﹁締浣嶇疆")
+    public AjaxResult getOnlineSYCarPosition() {
+        String soilderId = SecurityUtils.getUserId();
+        try{
+            Map<String,Object> result = ardSyCarService.getOnlineSYCarPosition(soilderId);
+            return AjaxResult.success(result);
+        }catch(Exception e){
+            e.printStackTrace();
+            return AjaxResult.error();
+        }
     }
 
 }

--
Gitblit v1.9.3