From 57c673aa3e83677bcf5d30b4b45d06bae6609db8 Mon Sep 17 00:00:00 2001
From: liusuyi <1951119284@qq.com>
Date: 星期四, 08 八月 2024 16:14:40 +0800
Subject: [PATCH] 优化:获取会话

---
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdSyCarServiceImpl.java |  202 ++++++++++++++++++++++++++++++-------------------
 1 files changed, 123 insertions(+), 79 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 a6cf4d0..7a32f66 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
@@ -26,6 +26,7 @@
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.sy.domain.ArdAccessFence;
+import com.ruoyi.sy.mapper.ArdTankLockMapper;
 import com.ruoyi.sy.param.ArdSyCarParam;
 import com.ruoyi.sy.vo.ArdSyCarVo;
 import com.ruoyi.system.mapper.SysDeptMapper;
@@ -99,6 +100,9 @@
     @Resource
     private SysDeptMapper sysDeptMapper;
 
+    @Resource
+    private ArdTankLockMapper ardTankLockMapper;
+
     @Value("${minio.endpoint}")
     private String minioEndpoint;
 
@@ -130,10 +134,11 @@
 
     @Override
     public AjaxResult ardSyCarList(ArdSyCarParam ardSyCarParam,Map<String,Object> result) {
-        QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
+        /*QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
         queryWrapper.like(ardSyCarParam.getCarBrand()!=null,"car_brand",ardSyCarParam.getCarBrand())
                 .like(ardSyCarParam.getCarType()!=null,"car_type",ardSyCarParam.getCarType());
-        List<ArdSyCar> ardSyCars = ardSyCarMapper.selectList(queryWrapper);
+        List<ArdSyCar> ardSyCars = ardSyCarMapper.selectList(queryWrapper);*/
+        List<ArdSyCar> ardSyCars = ardSyCarMapper.selectByBrandAndType(ardSyCarParam.getCarBrand(),ardSyCarParam.getCarType());
         List<ArdSyCarVo> ardSyCarVoList = new ArrayList<>();
         if(((String)result.get("code")).equals("200")){
             List<Map<String,Object>> list = (List<Map<String, Object>>) result.get("data");
@@ -212,7 +217,16 @@
             }
         }
         MinioUtil.removeObjects("sycar", objectNames);
-        return ardSyCarMapper.deleteArdSyCarByIds(ids);
+        try{
+            return ardSyCarMapper.deleteArdSyCarByIds(ids);
+        }finally {
+            List<String> carIds = new ArrayList();
+            for(ArdSyCar ardSyCar : result){
+                carIds.add(ardSyCar.getCarId());
+            }
+            ardTankLockMapper.deleteArdTankLockAndWallByCarIds(carIds);
+        }
+
     }
 
     /**
@@ -534,9 +548,13 @@
                 map.put("list", new ArrayList());
                 return map;
             }
-            QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
+            /*QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
             queryWrapper.in("dept_id", deptList);
-            List<ArdSyCar> carListTable = ardSyCarMapper.selectList(queryWrapper);
+            List<ArdSyCar> carListTable = ardSyCarMapper.selectList(queryWrapper);*/
+            List<ArdSyCar> carListTable = new ArrayList();
+            if(!deptList.isEmpty()){
+                carListTable = ardSyCarMapper.getCarListByDeptIdList(deptList);
+            }
             int online = 0;
             for (Map<String, Object> map : (List<Map<String, Object>>) result0.get("list")) {
                 Map<String, Object> resultMap = sYClient.getTeamCarList(syURL, (String) map.get("teamId"), result.get("sessionId"));
@@ -559,17 +577,30 @@
                 }
                 for (Map<String, Object> m : carList) {
                     if (((String) m.get("stateCn")).contains("鍦ㄧ嚎")) {
-                        online = online + 1;
+                        String carId = (String) m.get("carId");
+                        ArdSyCar ardSyCarQuery = new ArdSyCar();
+                        ardSyCarQuery.setCarId(carId);
+                        List<ArdSyCar> ardSyCarList = ardSyCarMapper.selectArdSyCarList(ardSyCarQuery);
+                        if(ardSyCarList.size() != 0){
+                            online = online + 1;
+                        }else{
+                            continue;
+                        }
                     } else {
                         continue;
                     }
                 }
-//                for (Map<String, Object> m : (List<Map<String, Object>>) result0.get("list")) {
-//                    if (((String) m.get("teamId")).equals(((String) map.get("teamId")))) {
-//                        map.put("count", Integer.parseInt((String) m.get("carNum")));
-//                    }
-//                }
-                map.put("count", carList.size());
+                List<String> carIdList = new ArrayList();//瀛樻斁杞﹂槦涓嬪叏閮ㄨ溅杈嗕富閿�
+                for(Map<String, Object> carMap : carList){
+                    carIdList.add((String) carMap.get("carId"));
+                }
+                //map.put("count", carList.size());
+                if(carIdList.size() == 0){
+                    map.put("count", 0);
+                }else{
+                    Long count = ardSyCarMapper.getCountByCarIdList(carIdList);
+                    map.put("count", count);
+                }
                 map.put("online", online);
                 online = 0;
             }
@@ -669,35 +700,30 @@
      */
     @Override
     public List<Map<String, String>> carIdByDeptList(List<Long> deptList, List<Map<String, String>> list) {
-        QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
+        /*QueryWrapper<ArdSyCar> queryWrapper = new QueryWrapper<>();
         queryWrapper.in("dept_id", deptList);
-        List<ArdSyCar> carList = ardSyCarMapper.selectList(queryWrapper);
+        List<ArdSyCar> carList = ardSyCarMapper.selectList(queryWrapper);*/
+        List<ArdSyCar> carList = new ArrayList();
+        if(!deptList.isEmpty()){
+            carList = ardSyCarMapper.getCarListByDeptIdList(deptList);
+        }
+
         //瀵规瘮鎶婂尮閰嶅埌鐨勬暟鎹坊鍔犲埌list涓�
         for (int i = 0; i < list.size(); i++) {
             String carId = list.get(i).get("carId");
-            Boolean isCar = false;
             for (int j = 0; j < carList.size(); j++) {
                 ArdSyCar ardSyCar = carList.get(j);
                 if (carId.equals(ardSyCar.getCarId())) {
-                    /*String url = "";
-                    if (ardSyCar.getCarPicture() != null) {
-                        if (!ardSyCar.getCarPicture().equals("")) {
-                            url = ardSyCar.getCarPicture().split("sycar")[0];
-                        }
-                    }*/
                     list.get(i).put("carModel", this.minioEndpoint + "/" + ardSyCar.getCarModel());//zns
-                    //m.put("carModel",ardSyCar.getCarModel());
                     list.get(i).put("carTypeArd", ardSyCar.getCarType());
                     list.get(i).put("carBrand", ardSyCar.getCarBrand());
                     list.get(i).put("carPicture", ardSyCar.getCarPicture());
-                    isCar = true;
+                    list.get(i).put("deptId", ardSyCar.getDeptId());
                     break;
                 }
             }
-            if(!isCar){
-                list.remove(list.get(i));
-            }
         }
+        list = list.stream().filter(map -> map.get("deptId") != null).collect(Collectors.toList());
         return list;
     }
 
@@ -718,7 +744,11 @@
         Map<String, Object> result1 = sYClient.logIn(syURL, passwordMd5, username31);
         Map<String, Object> result0 = new HashMap();
         //result0 = sYClient.getCarGPSTrack(syURL, carId, startTime, endTime, maxSpeed, (String) result1.get("sessionId"));
-        result0 = getCarGPSTrack(syURL, carId, startTime, endTime, maxSpeed, (String) result1.get("sessionId"));
+        try {
+            result0 = getCarGPSTrack(syURL, carId, startTime, endTime, maxSpeed, (String) result1.get("sessionId"));
+        } catch (Exception e) {
+            return Results.error("鏌ヨ鍘嗗彶鏁版嵁鏁伴噺杩囧瀵艰嚧瓒呮椂锛岃缂╁皬鑼冨洿鏌ヨ锛�");
+        }
         List<Map<String, Object>> list = (List<Map<String, Object>>) result0.get("list");
         if (list.isEmpty()) {
             return Results.succeed();
@@ -1313,62 +1343,70 @@
      */
     @Override
     public List<Map<String, Object>> getNearCar(SchedulingParam param) {
-        Double longitude = param.getLongitude();
-        Double latitude = param.getLatitude();
-        Integer radius = param.getSealingRadius();
-        if (longitude == null && latitude == null) {
-            log.debug("鍘熺偣鍧愭爣涓虹┖");
-            return null;
-        }
-        if (radius == null) {
-            log.debug("鍗婂緞璺濈涓虹┖");
-            return null;
-        }
-        String userId = SecurityUtils.getUserId();
-        ArdSyUser syUser = new ArdSyUser();
-        syUser.setSysUserId(userId);
-        List<ArdSyUser> ardSyUserList = ardSyUserMapper.selectArdSyUserList(syUser);
-        if (ardSyUserList.size() == 0) {
-            log.debug("鐢ㄦ埛鏈寕鎺ヤ笁涓�杞﹁締");
-            return null;
-        }
-        ArdSyUser ardSyUser = ardSyUserList.get(0);
-        String syUrl = redisCache.getCacheObject("sys_config:syCarPT");
-        String passwordMd5 = DigestUtils.md5Hex(ardSyUser.getPassword());
-        Map<String, Object> LogInResult = sYClient.logIn(syUrl, passwordMd5, ardSyUser.getUserId());
-        String sessionId = (String) LogInResult.get("sessionId");
+        try {
+            Double longitude = param.getLongitude();
+            Double latitude = param.getLatitude();
+            Integer radius = param.getSealingRadius();
+            if (longitude == null && latitude == null) {
+                log.debug("鍘熺偣鍧愭爣涓虹┖");
+                return null;
+            }
+            if (radius == null) {
+                log.debug("鍗婂緞璺濈涓虹┖");
+                return null;
+            }
+            String userId = SecurityUtils.getUserId();
+            ArdSyUser syUser = new ArdSyUser();
+            syUser.setSysUserId(userId);
+            List<ArdSyUser> ardSyUserList = ardSyUserMapper.selectArdSyUserList(syUser);
+            if (ardSyUserList.size() == 0) {
+                log.debug("鐢ㄦ埛鏈寕鎺ヤ笁涓�杞﹁締");
+                return null;
+            }
+            ArdSyUser ardSyUser = ardSyUserList.get(0);
+            String syUrl = redisCache.getCacheObject("sys_config:syCarPT");
+            String passwordMd5 = DigestUtils.md5Hex(ardSyUser.getPassword());
+            Map<String, Object> LogInResult = sYClient.logIn(syUrl, passwordMd5, ardSyUser.getUserId());
+            String sessionId = (String) LogInResult.get("sessionId");
 
-        Map<String, Object> teamList = sYClient.getTeamList(syUrl, ardSyUser.getUserId(), sessionId);
-        List<Map<String, Object>> listMap = (List<Map<String, Object>>) teamList.get("list");
-        List<Map<String, Object>> allList = new ArrayList<>();
-        for (Map<String, Object> team : listMap) {
-            String teamId = (String) team.get("teamId");
-            Map<String, Object> carListMap = sYClient.getCarList1(syUrl, teamId, ardSyUser.getUserId(), sessionId);
-            if (((String) carListMap.get("rspCode")).equals("1")) {
-                List<Map<String, Object>> list = (List<Map<String, Object>>) carListMap.get("list");
-                allList.addAll(list);
+            Map<String, Object> teamList = sYClient.getTeamList(syUrl, ardSyUser.getUserId(), sessionId);
+            List<Map<String, Object>> listMap = (List<Map<String, Object>>) teamList.get("list");
+            List<Map<String, Object>> allList = new ArrayList<>();
+            for (Map<String, Object> team : listMap) {
+                String teamId = (String) team.get("teamId");
+                Map<String, Object> carListMap = sYClient.getCarList1(syUrl, teamId, ardSyUser.getUserId(), sessionId);
+                if (((String) carListMap.get("rspCode")).equals("1")) {
+                    List<Map<String, Object>> list = (List<Map<String, Object>>) carListMap.get("list");
+                    allList.addAll(list);
+                }
             }
-        }
-        //杩囨护鍦ㄧ嚎杞﹁締
-        List<Map<String, Object>> onlineList = allList.stream()
-                .filter(map -> !"绂荤嚎".equals(map.get("stateCn")))
-                .collect(Collectors.toList());
-        List<Map<String, Object>> filteredList = new ArrayList<>();
-        //杩囨护鍗婂緞
-        for (Map<String, Object> carMap : onlineList) {
-            String carId = (String) carMap.get("carId");
-            Map<String, Object> carGPSTrack = sYClient.getCarNearPositionByCarId(syUrl, carId, ardSyUser.getUserId(), sessionId);
-            List<Map<String, Object>> carGPSMap = (List<Map<String, Object>>) carGPSTrack.get("list");
-            Double lng = Double.valueOf((String) carGPSMap.get(0).get("lng"));
-            Double lat = Double.valueOf((String) carGPSMap.get(0).get("lat"));
-            double distance = GisUtil.getDistance( new double[]{longitude,latitude}, new double[]{lng, lat});
-            if (distance <= radius) {
-                carMap.put("longitude",lng);
-                carMap.put("latitude",lat);
-                filteredList.add(carMap); // 灏嗘弧瓒虫潯浠剁殑杞﹁締娣诲姞鍒扮瓫閫夊垪琛ㄤ腑
+            //杩囨护鍦ㄧ嚎杞﹁締
+            List<Map<String, Object>> onlineList = allList.stream()
+                    .filter(map -> !"绂荤嚎".equals(map.get("stateCn")))
+                    .collect(Collectors.toList());
+            List<Map<String, Object>> filteredList = new ArrayList<>();
+            //杩囨护鍗婂緞
+            for (Map<String, Object> carMap : onlineList) {
+                String carId = (String) carMap.get("carId");
+                Map<String, Object> carGPSTrack = sYClient.getCarNearPositionByCarId(syUrl, carId, ardSyUser.getUserId(), sessionId);
+                List<Map<String, Object>> carGPSMap = (List<Map<String, Object>>) carGPSTrack.get("list");
+                if(carGPSMap.size()>0) {
+                    Double lng = Double.valueOf((String) carGPSMap.get(0).get("lng"));
+                    Double lat = Double.valueOf((String) carGPSMap.get(0).get("lat"));
+                    double distance = GisUtil.getDistance(new double[]{longitude, latitude}, new double[]{lng, lat});
+                    if (distance <= radius) {
+                        carMap.put("longitude", lng);
+                        carMap.put("latitude", lat);
+                        filteredList.add(carMap); // 灏嗘弧瓒虫潯浠剁殑杞﹁締娣诲姞鍒扮瓫閫夊垪琛ㄤ腑
+                    }
+                }
             }
+            return filteredList;
+        }catch (Exception e)
+        {
+           log.error("鑾峰彇闄勮繎鑼冨洿鍐呯殑杞﹁締淇℃伅寮傚父:"+e.getMessage());
+            return null;
         }
-        return filteredList;
     }
     /**
      * 鑾峰彇鑼冨洿鍐呯殑杞﹁締淇℃伅(澶氳竟褰�)
@@ -1515,6 +1553,12 @@
         }
     }
 
+    @Override
+    public List<ArdSyCar> selectArdSyCarAndTankLock() {
+        List<ArdSyCar> result = ardSyCarMapper.selectArdSyCarAndTankLock();
+        return result;
+    }
+
     public List<Long> getOwnAndChildrenDeptIdList(List<Long> deptIdList,List<Long> deptIdListr){
         deptIdListr.addAll(deptIdList);
         List<Long> result = sysDeptMapper.getChildrenDeptIdList(deptIdList);

--
Gitblit v1.9.3