From 82e4e5f6129be2e691138cd8b8ea3262e64943af Mon Sep 17 00:00:00 2001
From: rain <167982779@qq.com>
Date: Thu, 04 Jul 2024 15:54:19 +0800
Subject: [PATCH] 修改播放地址

---
 src/main/java/com/dji/sample/media/service/impl/FileServiceImpl.java        |  359 ++++++++++++++++++-----------------
 src/main/java/com/dji/sample/manage/model/entity/DeviceSetEntity.java       |    5 
 src/main/java/com/dji/sample/manage/service/ILiveStreamService.java         |    3 
 src/main/java/com/dji/sample/media/service/IFileService.java                |    2 
 src/main/java/com/dji/sample/manage/controller/LiveStreamController.java    |    6 
 pom.xml                                                                     |    8 
 src/main/java/com/dji/sample/manage/service/impl/LiveStreamServiceImpl.java |  155 +++++++-------
 src/main/java/com/dji/sample/patches/controller/PatchesController.java      |    3 
 8 files changed, 273 insertions(+), 268 deletions(-)

diff --git a/pom.xml b/pom.xml
index 022bf84..09254a2 100644
--- a/pom.xml
+++ b/pom.xml
@@ -318,14 +318,6 @@
                     </excludes>
                 </configuration>
             </plugin>
-<!--            <plugin>-->
-<!--                <groupId>org.apache.maven.plugins</groupId>-->
-<!--                <artifactId>maven-compiler-plugin</artifactId>-->
-<!--                <configuration>-->
-<!--                    <source>16</source>-->
-<!--                    <target>16</target>-->
-<!--                </configuration>-->
-<!--            </plugin>-->
         </plugins>
 
         <!--配置后才可以扫描到xml文件-->
diff --git a/src/main/java/com/dji/sample/manage/controller/LiveStreamController.java b/src/main/java/com/dji/sample/manage/controller/LiveStreamController.java
index b8f12bf..98f4270 100644
--- a/src/main/java/com/dji/sample/manage/controller/LiveStreamController.java
+++ b/src/main/java/com/dji/sample/manage/controller/LiveStreamController.java
@@ -15,6 +15,7 @@
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletRequest;
+import java.io.IOException;
 import java.util.List;
 
 import static com.dji.sample.component.AuthInterceptor.TOKEN_CLAIM;
@@ -58,7 +59,6 @@
 //        CustomClaim customClaim = (CustomClaim)request.getAttribute(TOKEN_CLAIM);
 
         List<CapacityDeviceDTO> liveCapacity = liveStreamService.getLiveCapacity(workspaceId,sn);
-
         return ResponseResult.success(liveCapacity);
     }
 
@@ -74,8 +74,8 @@
     }
 
     @PostMapping("/streams/address")
-    public ResponseResult liveAddress(@RequestParam String deviceSn,@RequestParam String deviceId) {
-        return liveStreamService.liveAddress(deviceSn,deviceId);
+    public ResponseResult liveAddress(@RequestParam String deviceSn,@RequestParam String deviceName) throws IOException {
+        return liveStreamService.liveAddress(deviceSn,deviceName);
     }
 
     /**
diff --git a/src/main/java/com/dji/sample/manage/model/entity/DeviceSetEntity.java b/src/main/java/com/dji/sample/manage/model/entity/DeviceSetEntity.java
index 6dd9566..630e216 100644
--- a/src/main/java/com/dji/sample/manage/model/entity/DeviceSetEntity.java
+++ b/src/main/java/com/dji/sample/manage/model/entity/DeviceSetEntity.java
@@ -43,11 +43,10 @@
     @TableField(value = "gbServer_id")
     private String gbServerId;
 
-    @TableField(value = "device_id")
-    private String deviceId;
+    @TableField(value = "device_name")
+    private String deviceName;
 
     @TableField(value = "workspace_id")
     private String workspaceId;
-
 
 }
diff --git a/src/main/java/com/dji/sample/manage/service/ILiveStreamService.java b/src/main/java/com/dji/sample/manage/service/ILiveStreamService.java
index 63742fb..f29313b 100644
--- a/src/main/java/com/dji/sample/manage/service/ILiveStreamService.java
+++ b/src/main/java/com/dji/sample/manage/service/ILiveStreamService.java
@@ -5,6 +5,7 @@
 import com.dji.sample.manage.model.dto.LiveTypeDTO;
 import com.dji.sample.manage.model.receiver.LiveCapacityReceiver;
 
+import java.io.IOException;
 import java.util.List;
 
 /**
@@ -36,7 +37,7 @@
      * @return
      */
     ResponseResult liveStart(LiveTypeDTO liveParam);
-    ResponseResult liveAddress(String deviceSn,String deviceId);
+    ResponseResult liveAddress(String deviceSn,String deviceName) throws IOException;
     /**
      * Stop the live streaming by publishing mqtt message.
      * 通过发布mqtt消息来停止实时流。
diff --git a/src/main/java/com/dji/sample/manage/service/impl/LiveStreamServiceImpl.java b/src/main/java/com/dji/sample/manage/service/impl/LiveStreamServiceImpl.java
index 6f630a2..7d8e623 100644
--- a/src/main/java/com/dji/sample/manage/service/impl/LiveStreamServiceImpl.java
+++ b/src/main/java/com/dji/sample/manage/service/impl/LiveStreamServiceImpl.java
@@ -1,5 +1,8 @@
 package com.dji.sample.manage.service.impl;
 
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.dji.sample.common.error.LiveErrorEnum;
 import com.dji.sample.common.model.ResponseResult;
@@ -19,6 +22,8 @@
 import com.dji.sample.manage.model.receiver.CapacityDeviceReceiver;
 import com.dji.sample.manage.model.receiver.LiveCapacityReceiver;
 import com.dji.sample.manage.service.*;
+import com.dji.sample.patches.utils.DistrictCodeUtils;
+import com.fasterxml.jackson.core.JsonProcessingException;
 import com.fasterxml.jackson.databind.JsonNode;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -26,6 +31,7 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.StringUtils;
 
+import java.io.IOException;
 import java.lang.reflect.Field;
 import java.util.*;
 import java.util.concurrent.ConcurrentHashMap;
@@ -37,8 +43,8 @@
 
 /**
  * @author sean.zhou
- * @date 2021/11/22
  * @version 0.1
+ * @date 2021/11/22
  */
 @Service
 @Transactional
@@ -60,8 +66,9 @@
 
     @Autowired
     private IDeviceRedisService deviceRedisService;
+
     @Override
-    public List<CapacityDeviceDTO> getLiveCapacity(String workspaceId,String sn) {
+    public List<CapacityDeviceDTO> getLiveCapacity(String workspaceId, String sn) {
 
         // Query all devices in this workspace.
         //查询该工作区中的所有设备。
@@ -71,7 +78,6 @@
                         .deviceSn(sn)
                         .domains(List.of(DeviceDomainEnum.SUB_DEVICE.getVal(), DeviceDomainEnum.DOCK.getVal()))
                         .build());
-
         // Query the live capability of each drone.
         return devicesList.stream()
                 //过滤出在线设备
@@ -113,7 +119,7 @@
             return responseResult;
         }
 
-        DeviceDTO data = (DeviceDTO)responseResult.getData();
+        DeviceDTO data = (DeviceDTO) responseResult.getData();
         // target topic
         //thing/product/{gateway_sn}/services   云平台向设备发送的服务
         String respTopic = THING_MODEL_PRE + PRODUCT +
@@ -123,17 +129,17 @@
         ServiceReply receiveReply = this.publishLiveStart(respTopic, liveParam);
 
         //相机已经在直播中,请勿重复开启直播
-        if(receiveReply.getResult() == 513003) {
+        if (receiveReply.getResult() == 513003) {
             LiveDTO live = new LiveDTO();
-            live.setUrl(liveParam.getUrl().replace("rtmp", "https").replace("735","700") + ".flv");
-//            LiveUrlGB28181DTO gb28181 = urlToGB28181(liveParam.getUrl());
-//            live.setUrl(new StringBuilder()
-//                    .append("https://wrj.shuixiongit.com/zb/rtp/")
-//                    .append(gb28181.getAgentID())
-//                    .append("_")
-//                    .append(gb28181.getChannel())
-//                    .append(".live.flv")
-//                    .toString());
+//            live.setUrl(liveParam.getUrl().replace("rtmp", "https").replace("735", "700") + ".flv");
+            LiveUrlGB28181DTO gb28181 = urlToGB28181(liveParam.getUrl());
+            live.setUrl(new StringBuilder()
+                    .append("https://wrj.shuixiongit.com/zb/rtp/")
+                    .append(gb28181.getAgentID())
+                    .append("_")
+                    .append(gb28181.getChannel())
+                    .append(".live.flv")
+                    .toString());
             return ResponseResult.success(live);
         }
 
@@ -148,29 +154,29 @@
         switch (urlType) {
             case RTMP:
 //                live.setUrl(liveParam.getUrl().replace("rtmp", "webrtc"));
-                live.setUrl(liveParam.getUrl().replace("rtmp", "https").replace("735","700") + ".flv");
-                break;
-            case GB28181:
-                LiveUrlGB28181DTO gb28181 = urlToGB28181(liveParam.getUrl());
-                live.setUrl(new StringBuilder()
-                        .append("webrtc://")
-                        .append(gb28181.getServerIP())
-                        .append("/live/")
-                        .append(gb28181.getAgentID())
-                        .append("@")
-                        .append(gb28181.getChannel())
-                        .toString());
+                live.setUrl(liveParam.getUrl().replace("rtmp", "https").replace("735", "700") + ".flv");
                 break;
 //            case GB28181:
 //                LiveUrlGB28181DTO gb28181 = urlToGB28181(liveParam.getUrl());
 //                live.setUrl(new StringBuilder()
-//                        .append("https://wrj.shuixiongit.com/zb/rtp/")
+//                        .append("webrtc://")
+//                        .append(gb28181.getServerIP())
+//                        .append("/live/")
 //                        .append(gb28181.getAgentID())
-//                        .append("_")
+//                        .append("@")
 //                        .append(gb28181.getChannel())
-//                        .append(".live.flv")
 //                        .toString());
 //                break;
+            case GB28181:
+                LiveUrlGB28181DTO gb28181 = urlToGB28181(liveParam.getUrl());
+                live.setUrl(new StringBuilder()
+                        .append("https://wrj.shuixiongit.com/zb/rtp/")
+                        .append(gb28181.getAgentID())
+                        .append("_")
+                        .append(gb28181.getChannel())
+                        .append(".live.flv")
+                        .toString());
+                break;
             case RTSP:
                 String url = receiveReply.getOutput().toString();
                 this.resolveUrlUser(url, live);
@@ -178,65 +184,51 @@
             case UNKNOWN:
                 return ResponseResult.error(LiveErrorEnum.URL_TYPE_NOT_SUPPORTED);
         }
-
         return ResponseResult.success(live);
 
     }
 
     @Override
-    public ResponseResult liveAddress(String deviceSn,String deviceId) {
-       DeviceSetEntity deviceSet= deviceSetMapper.selectOne(new LambdaQueryWrapper<DeviceSetEntity>()
-                .eq(DeviceSetEntity::getDeviceSn,deviceSn)
-                .eq(DeviceSetEntity::getDeviceId,deviceId)
+    public ResponseResult liveAddress(String deviceSn, String deviceName) throws IOException {
+        DeviceSetEntity deviceSet = deviceSetMapper.selectOne(new LambdaQueryWrapper<DeviceSetEntity>()
+                .eq(DeviceSetEntity::getDeviceSn, deviceSn)
+                .eq(DeviceSetEntity::getDeviceName, deviceName)
         );
-        String workspaceId=getIdBySn(deviceSn);
-        List<CapacityDeviceDTO> dto=getLiveCapacity(workspaceId,deviceSn);
-        String vedioId=deviceSn+"/165-0-7/normal-0";
-        String url="https://"+deviceSet.getServerIp()+"/zb/rtp/"+deviceSet.getAgentId()+"_"+deviceSet.getChannel()+".live.flv";
-        LiveTypeDTO liveParam=new LiveTypeDTO();
+        String workspaceId = getIdBySn(deviceSn);
+        String url = "serverIP=" + deviceSet.getServerIp() + "&serverPort=" + deviceSet.getServerPort() + "&agentID=" + deviceSet.getAgentId()
+                + "&agentPassword=" + deviceSet.getAgentPassword() + "&localPort=" + deviceSet.getLocalPort() + "&serverID=" + deviceSet.getGbServerId() + "&channel=" + deviceSet.getChannel();
+        LiveTypeDTO liveParam = new LiveTypeDTO();
         liveParam.setUrl(url);
         liveParam.setUrlType(3);
-        liveParam.setVideoId(vedioId);
+        liveParam.setVideoId(getVedioId(getLiveCapacity(workspaceId, deviceSn), deviceSn,deviceName));
         liveParam.setVideoQuality(0);
-        ResponseResult responseResult = this.checkBeforeLive(liveParam.getVideoId());
-        if (ResponseResult.CODE_SUCCESS != responseResult.getCode()) {
-            return responseResult;
-        }
-
-        DeviceDTO data = (DeviceDTO)responseResult.getData();
-        String respTopic = THING_MODEL_PRE + PRODUCT +
-                data.getDeviceSn() + SERVICES_SUF;
-
-        //获取返回结果
-        ServiceReply receiveReply = this.publishLiveStart(respTopic, liveParam);
-        System.out.println(receiveReply.getResult());
-        LiveDTO live = new LiveDTO();
-        live.setUrl(url);
-        //相机已经在直播中,请勿重复开启直播
-        if(receiveReply.getResult() == 513003) {
-            return ResponseResult.success(live);
-        }
-        return ResponseResult.success(live);
+        System.out.println(liveStart(liveParam));
+        return liveStart(liveParam);
     }
 
+    public static String getVedioId(List<CapacityDeviceDTO> data, String sn,String name) throws IOException {
+        return findAndConcatenateIndexes(data, sn,name);
+    }
 
-        public static String getVedioId(String data,String sn) {
-            return findDeviceBySn(data, sn);
-        }
-
-        public static String findDeviceBySn(String dtoListString, String snToFind) {
-            String regex = "CapacityDeviceDTO\\(sn=" + snToFind + ", .*? index=([\\w\\-]+).*? index=([\\w\\-]+).*?\\)";
-            Pattern pattern = Pattern.compile(regex);
-            Matcher matcher = pattern.matcher(dtoListString);
-
-            if (matcher.find()) {
-                String index1 = matcher.group(1);
-                String index2 = matcher.group(2);
-                return snToFind + "/" + index1 + "/" + index2;
+    public static String findAndConcatenateIndexes(List<CapacityDeviceDTO> devices, String sn, String cameraName) {
+        for (CapacityDeviceDTO device : devices) {
+            if (device.getSn().equals(sn)) {
+                StringBuilder result = new StringBuilder();
+                for (CapacityCameraDTO camera : device.getCamerasList()) {
+                    if (camera.getName().equals(cameraName)) {
+                        result.append(device.getSn())
+                                .append("/")
+                                .append(camera.getIndex())
+                                .append("/")
+                                .append(camera.getVideosList().get(0).getIndex()) // Assuming we take the first video index
+                                .append(" "); // Add a space separator or customize as needed
+                    }
+                }
+                return result.toString().trim(); // Trim to remove trailing space
             }
-
-            return null; // 如果未找到匹配的sn,则返回null或者适当的默认值
         }
+        return ""; // Handle case where sn or cameraName is not found
+    }
 
     @Override
     public ResponseResult liveStop(String videoId) {
@@ -246,7 +238,7 @@
         }
         //thing/product/{gateway_sn}/services
         String respTopic = THING_MODEL_PRE + PRODUCT + responseResult.getData().getDeviceSn() + SERVICES_SUF;
-        videoId = videoId.replace("_","/");
+        videoId = videoId.replace("_", "/");
 
         ServiceReply receiveReply = this.publishLiveStop(respTopic, videoId);
         if (receiveReply.getResult() != 0) {
@@ -317,6 +309,7 @@
     /**
      * Check if this lens is available live.
      * 检查镜头是否可用
+     *
      * @param videoId
      * @return
      */
@@ -352,6 +345,7 @@
 
     /**
      * When using rtsp live, the account and password are parsed from the information returned by the pilot.
+     *
      * @param url
      * @param live
      */
@@ -372,6 +366,7 @@
 
     /**
      * When using GB28181 live, url parameters are resolved into objects.
+     *
      * @param url
      * @return
      */
@@ -398,7 +393,8 @@
 
     /**
      * Send a message to the pilot via mqtt to start the live streaming.
-     *通过mqtt向飞行员发送消息以启动直播。
+     * 通过mqtt向飞行员发送消息以启动直播。
+     *
      * @param topic
      * @param liveParam
      * @return
@@ -413,12 +409,14 @@
         return messageSender.publishWithReply(ServiceReply.class, topic, response);
     }
 
-    private String getIdBySn(String dockSn){
-        DeviceSetEntity entity=deviceSetMapper.selectOne(new LambdaQueryWrapper<DeviceSetEntity>().eq(DeviceSetEntity::getDeviceSn,dockSn));
+    private String getIdBySn(String dockSn) {
+        DeviceSetEntity entity = deviceSetMapper.selectOne(new LambdaQueryWrapper<DeviceSetEntity>().eq(DeviceSetEntity::getDeviceSn, dockSn));
         return entity.getWorkspaceId();
     }
+
     /**
      * Send a message to the pilot via mqtt to set quality.
+     *
      * @param respTopic
      * @param liveParam
      * @return
@@ -438,6 +436,7 @@
 
     /**
      * Send a message to the pilot via mqtt to stop the live streaming.
+     *
      * @param topic
      * @param videoId
      * @return
diff --git a/src/main/java/com/dji/sample/media/service/IFileService.java b/src/main/java/com/dji/sample/media/service/IFileService.java
index 0147cc5..66b9e8e 100644
--- a/src/main/java/com/dji/sample/media/service/IFileService.java
+++ b/src/main/java/com/dji/sample/media/service/IFileService.java
@@ -48,7 +48,7 @@
      * @throws ImageProcessingException
      */
     void saveMarkFile(String workspaceId, FileUploadDTO file) throws IOException, FontFormatException, ImageProcessingException;
-//    void updateMarkMediaFileNames(String jobId);
+    void updateMarkMediaFileNames(String jobId);
     /**
      * 获取媒体文件状态
      * @param fileId
diff --git a/src/main/java/com/dji/sample/media/service/impl/FileServiceImpl.java b/src/main/java/com/dji/sample/media/service/impl/FileServiceImpl.java
index 27e1e77..7967e94 100644
--- a/src/main/java/com/dji/sample/media/service/impl/FileServiceImpl.java
+++ b/src/main/java/com/dji/sample/media/service/impl/FileServiceImpl.java
@@ -344,7 +344,7 @@
         if (file != null) {
             builder.fileName(file.getName())
                     .filePath(file.getPath())
-                    .examine(1)
+                    .examine(0)
                     .fingerprint(file.getFingerprint())
                     .objectKey(file.getObjectKey())
                     .subFileType(file.getSubFileType())
@@ -454,171 +454,184 @@
     }
 
 
-//    public void updateMediaFileNames(String jobId) {
-//        // 查询符合条件的数据
-//        List<MediaFileEntity> mediaFiles = mapper.selectList(new LambdaQueryWrapper<MediaFileEntity>()
-//                        .eq(MediaFileEntity::getJobId, jobId)
-////                .eq(MediaFileMarkEntity::getIsadd, 0)
-//        );
-//
-//        // 筛选出name字段不包含'~'的数据
-//        List<MediaFileEntity> filteredFiles = mediaFiles.stream()
-//                .filter(file -> !file.getFileName().contains("~"))
-//                .toList();
-//        for (MediaFileEntity currentFile : filteredFiles) {
-//            String currentName = currentFile.getFileName();
-//            Map<String, Object> currentMetadata = JSON.parseObject(JSON.toJSONString(currentFile.getMetadata()), Map.class);
-//            Long currentCreatedTime = (Long) currentMetadata.get("createdTime");
-//            // 找到metadata中的createdTime小于当前数据的createdTime且最接近的那条数据
-//            Optional<MediaFileEntity> closestFileOpt = mediaFiles.stream()
-//                    .filter(file -> {
-//                        Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
-//                        Long createdTime = (Long) metadata.get("createdTime");
-//                        String filename = file.getFileName();
-//                        return createdTime < currentCreatedTime && filename.contains("~");
-//                    })
-//                    .min((file1, file2) -> {
-//                        Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
-//                        Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
-//                        Long time1 = (Long) metadata1.get("createdTime");
-//                        Long time2 = (Long) metadata2.get("createdTime");
-//                        return Long.compare(currentCreatedTime - time1, currentCreatedTime - time2);
-//                    });
-//            if (closestFileOpt.isEmpty()) {
-//                // 找不到小于的文件,尝试找大于且最接近的文件
-//                closestFileOpt = mediaFiles.stream()
-//                        .filter(file -> {
-//                            Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
-//                            Long createdTime = (Long) metadata.get("createdTime");
-//                            String filename = file.getFileName();
-//                            return createdTime > currentCreatedTime && filename.contains("~");
-//                        })
-//                        .min((file1, file2) -> {
-//                            Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
-//                            Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
-//                            Long time1 = (Long) metadata1.get("createdTime");
-//                            Long time2 = (Long) metadata2.get("createdTime");
-//                            return Long.compare(time1 - currentCreatedTime, time2 - currentCreatedTime);
-//                        });}
-//            if (closestFileOpt.isEmpty()) {
-//                throw new RuntimeException("当前图片无法绑定图斑");
-//            }
-//            // 提取并替换name字段
-//            closestFileOpt.ifPresent(closestFile -> {
-//                String closestName = closestFile.getFileName();
-//                int startIndex = closestName.indexOf("V");
-//                if (closestName.contains("W")) {
-//                    startIndex = closestName.indexOf("W");
-//                }
-//                if (closestName.contains("Z")) {
-//                    startIndex = closestName.indexOf("Z");
-//                }
-//                int endIndex = closestName.indexOf(".", startIndex);
-//                String replacement = closestName.substring(startIndex, endIndex);
-//                int currentStartIndex = currentName.indexOf("V");
-//                if (currentName.contains("W")) {
-//                    currentStartIndex = closestName.indexOf("W");
-//                }
-//                if (currentName.contains("Z")) {
-//                    currentStartIndex = closestName.indexOf("Z");
-//                }
-//                int currentEndIndex = currentName.indexOf(".", currentStartIndex);
-//                String newName = currentName.substring(0, currentStartIndex)
-//                        + replacement
-//                        + currentName.substring(currentEndIndex);
-//                currentFile.setFileName(newName);
-//                updateMediaById(currentFile.getId(), currentFile);
-//            });
-//        }
-//    }
-//
-//    @Override
-//    public void updateMarkMediaFileNames(String jobId) {
-//        try {
-//
-//
-//            // 查询符合条件的数据
-//            List<MediaFileMarkEntity> mediaFiles = markMapper.selectList(new LambdaQueryWrapper<MediaFileMarkEntity>()
-//                            .eq(MediaFileMarkEntity::getJobId, jobId)
-////                .eq(MediaFileMarkEntity::getIsadd, 0)
-//            );
-//
-//
-//            // 筛选出name字段不包含'~'的数据
-//            List<MediaFileMarkEntity> filteredFiles = mediaFiles.stream()
-//                    .filter(file -> !file.getFileName().contains("~"))
-//                    .toList();
-//
-//            for (MediaFileMarkEntity currentFile : filteredFiles) {
-//                String currentName = currentFile.getFileName();
-//                Map<String, Object> currentMetadata = JSON.parseObject(JSON.toJSONString(currentFile.getMetadata()), Map.class);
-//                Long currentCreatedTime = (Long) currentMetadata.get("createdTime");
-//                // 找到metadata中的createdTime小于当前数据的createdTime且最接近的那条数据
-//                Optional<MediaFileMarkEntity> closestFileOpt = mediaFiles.stream()
-//                        .filter(file -> {
-//                            Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
-//                            Long createdTime = (Long) metadata.get("createdTime");
-//                            String filename = file.getFileName();
-//                            return createdTime < currentCreatedTime && filename.contains("~");
-//                        })
-//                        .min((file1, file2) -> {
-//                            Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
-//                            Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
-//                            Long time1 = (Long) metadata1.get("createdTime");
-//                            Long time2 = (Long) metadata2.get("createdTime");
-//                            return Long.compare(currentCreatedTime - time1, currentCreatedTime - time2);
-//                        });
-//                if (closestFileOpt.isEmpty()) {
-//                    // 找不到小于的文件,尝试找大于且最接近的文件
-//                    closestFileOpt = mediaFiles.stream()
-//                            .filter(file -> {
-//                                Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
-//                                Long createdTime = (Long) metadata.get("createdTime");
-//                                String filename = file.getFileName();
-//                                return createdTime > currentCreatedTime && filename.contains("~");
-//                            })
-//                            .min((file1, file2) -> {
-//                                Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
-//                                Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
-//                                Long time1 = (Long) metadata1.get("createdTime");
-//                                Long time2 = (Long) metadata2.get("createdTime");
-//                                return Long.compare(time1 - currentCreatedTime, time2 - currentCreatedTime);
-//                            });
-//                }
-//                if (closestFileOpt.isEmpty()) {
-//                    throw new RuntimeException("没有符合时间的对象");
-//                }
-//                // 提取并替换name字段
-//                closestFileOpt.ifPresent(closestFile -> {
-//                    String closestName = closestFile.getFileName();
-//                    int startIndex = closestName.indexOf("V");
-//                    if (closestName.contains("W")) {
-//                        startIndex = closestName.indexOf("W");
-//                    }
-//                    if (closestName.contains("Z")) {
-//                        startIndex = closestName.indexOf("Z");
-//                    }
-//                    int endIndex = closestName.indexOf(".", startIndex);
-//                    String replacement = closestName.substring(startIndex, endIndex);
-//                    int currentStartIndex = currentName.indexOf("V");
-//                    if (currentName.contains("W")) {
-//                        currentStartIndex = closestName.indexOf("W");
-//                    }
-//                    if (currentName.contains("Z")) {
-//                        currentStartIndex = closestName.indexOf("Z");
-//                    }
-//                    int currentEndIndex = currentName.indexOf(".", currentStartIndex);
-//                    String newName = currentName.substring(0, currentStartIndex)
-//                            + replacement
-//                            + currentName.substring(currentEndIndex);
-//                    currentFile.setFileName(newName);
-//                    updateById(currentFile.getId(), currentFile);
-//                });
-//            }
-//        } catch (Exception e) {
-//            e.printStackTrace();
-//        }
-//    }
+    public void updateMediaFileNames(String jobId) {
+        // 查询符合条件的数据
+        List<MediaFileEntity> mediaFiles = mapper.selectList(new LambdaQueryWrapper<MediaFileEntity>()
+                        .eq(MediaFileEntity::getJobId, jobId)
+//                .eq(MediaFileMarkEntity::getIsadd, 0)
+        );
+        boolean allContainTilde = mediaFiles.stream().allMatch(file -> file.getFileName().contains("~"));
+        boolean noneContainTilde = mediaFiles.stream().noneMatch(file -> file.getFileName().contains("~"));
+
+        // 如果所有 fileName 都包含 '~' 或者都不包含 '~',将 is_add 字段改为 1
+        if (allContainTilde || noneContainTilde) {
+            return;
+        }
+
+        // 筛选出name字段不包含'~'的数据
+        List<MediaFileEntity> filteredFiles = mediaFiles.stream()
+                .filter(file -> !file.getFileName().contains("~"))
+                .collect(Collectors.toList());
+        for (MediaFileEntity currentFile : filteredFiles) {
+            String currentName = currentFile.getFileName();
+            Map<String, Object> currentMetadata = JSON.parseObject(JSON.toJSONString(currentFile.getMetadata()), Map.class);
+            Long currentCreatedTime = (Long) currentMetadata.get("createdTime");
+            // 找到metadata中的createdTime小于当前数据的createdTime且最接近的那条数据
+            Optional<MediaFileEntity> closestFileOpt = mediaFiles.stream()
+                    .filter(file -> {
+                        Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
+                        Long createdTime = (Long) metadata.get("createdTime");
+                        String filename = file.getFileName();
+                        return createdTime < currentCreatedTime && filename.contains("~");
+                    })
+                    .min((file1, file2) -> {
+                        Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
+                        Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
+                        Long time1 = (Long) metadata1.get("createdTime");
+                        Long time2 = (Long) metadata2.get("createdTime");
+                        return Long.compare(currentCreatedTime - time1, currentCreatedTime - time2);
+                    });
+            if (closestFileOpt.isEmpty()) {
+                // 找不到小于的文件,尝试找大于且最接近的文件
+                closestFileOpt = mediaFiles.stream()
+                        .filter(file -> {
+                            Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
+                            Long createdTime = (Long) metadata.get("createdTime");
+                            String filename = file.getFileName();
+                            return createdTime > currentCreatedTime && filename.contains("~");
+                        })
+                        .min((file1, file2) -> {
+                            Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
+                            Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
+                            Long time1 = (Long) metadata1.get("createdTime");
+                            Long time2 = (Long) metadata2.get("createdTime");
+                            return Long.compare(time1 - currentCreatedTime, time2 - currentCreatedTime);
+                        });
+            }
+            // 提取并替换name字段
+            closestFileOpt.ifPresent(closestFile -> {
+                String closestName = closestFile.getFileName();
+                int startIndex = closestName.indexOf("V");
+                if (closestName.contains("W")) {
+                    startIndex = closestName.indexOf("W");
+                }
+                if (closestName.contains("Z")) {
+                    startIndex = closestName.indexOf("Z");
+                }
+                int endIndex = closestName.indexOf(".", startIndex);
+                String replacement = closestName.substring(startIndex, endIndex);
+                int currentStartIndex = currentName.indexOf("V");
+                if (currentName.contains("W")) {
+                    currentStartIndex = closestName.indexOf("W");
+                }
+                if (currentName.contains("Z")) {
+                    currentStartIndex = closestName.indexOf("Z");
+                }
+                int currentEndIndex = currentName.indexOf(".", currentStartIndex);
+                String newName = currentName.substring(0, currentStartIndex)
+                        + replacement
+                        + currentName.substring(currentEndIndex);
+                currentFile.setFileName(newName);
+                updateMediaById(currentFile.getId(), currentFile);
+            });
+        }
+    }
+
+    @Override
+    public void updateMarkMediaFileNames(String jobId) {
+        try {
+
+
+            // 查询符合条件的数据
+            List<MediaFileMarkEntity> mediaFiles = markMapper.selectList(new LambdaQueryWrapper<MediaFileMarkEntity>()
+                            .eq(MediaFileMarkEntity::getJobId, jobId)
+//                .eq(MediaFileMarkEntity::getIsadd, 0)
+            );
+            // 判断所有 fileName 是否都包含 '~' 或者都不包含 '~'
+            boolean allContainTilde = mediaFiles.stream().allMatch(file -> file.getFileName().contains("~"));
+            boolean noneContainTilde = mediaFiles.stream().noneMatch(file -> file.getFileName().contains("~"));
+
+            // 如果所有 fileName 都包含 '~' 或者都不包含 '~',将 is_add 字段改为 1
+            if (allContainTilde || noneContainTilde) {
+                mediaFiles.forEach(file -> {
+                    file.setIsadd(1);
+                    updateById(file.getId(), file);
+                });
+                    return;
+
+            }
+            // 筛选出name字段不包含'~'的数据
+            List<MediaFileMarkEntity> filteredFiles = mediaFiles.stream()
+                    .filter(file -> !file.getFileName().contains("~"))
+                    .collect(Collectors.toList());
+
+            for (MediaFileMarkEntity currentFile : filteredFiles) {
+                String currentName = currentFile.getFileName();
+                Map<String, Object> currentMetadata = JSON.parseObject(JSON.toJSONString(currentFile.getMetadata()), Map.class);
+                Long currentCreatedTime = (Long) currentMetadata.get("createdTime");
+                // 找到metadata中的createdTime小于当前数据的createdTime且最接近的那条数据
+                Optional<MediaFileMarkEntity> closestFileOpt = mediaFiles.stream()
+                        .filter(file -> {
+                            Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
+                            Long createdTime = (Long) metadata.get("createdTime");
+                            String filename = file.getFileName();
+                            return createdTime < currentCreatedTime && filename.contains("~");
+                        })
+                        .min((file1, file2) -> {
+                            Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
+                            Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
+                            Long time1 = (Long) metadata1.get("createdTime");
+                            Long time2 = (Long) metadata2.get("createdTime");
+                            return Long.compare(currentCreatedTime - time1, currentCreatedTime - time2);
+                        });
+                if (closestFileOpt.isEmpty()) {
+                    // 找不到小于的文件,尝试找大于且最接近的文件
+                    closestFileOpt = mediaFiles.stream()
+                            .filter(file -> {
+                                Map<String, Object> metadata = JSON.parseObject(JSON.toJSONString(file.getMetadata()), Map.class);
+                                Long createdTime = (Long) metadata.get("createdTime");
+                                String filename = file.getFileName();
+                                return createdTime > currentCreatedTime && filename.contains("~");
+                            })
+                            .min((file1, file2) -> {
+                                Map<String, Object> metadata1 = JSON.parseObject(JSON.toJSONString(file1.getMetadata()), Map.class);
+                                Map<String, Object> metadata2 = JSON.parseObject(JSON.toJSONString(file2.getMetadata()), Map.class);
+                                Long time1 = (Long) metadata1.get("createdTime");
+                                Long time2 = (Long) metadata2.get("createdTime");
+                                return Long.compare(time1 - currentCreatedTime, time2 - currentCreatedTime);
+                            });
+                }
+                // 提取并替换name字段
+                closestFileOpt.ifPresent(closestFile -> {
+                    String closestName = closestFile.getFileName();
+                    int startIndex = closestName.indexOf("V");
+                    if (closestName.contains("W")) {
+                        startIndex = closestName.indexOf("W");
+                    }
+                    if (closestName.contains("Z")) {
+                        startIndex = closestName.indexOf("Z");
+                    }
+                    int endIndex = closestName.indexOf(".", startIndex);
+                    String replacement = closestName.substring(startIndex, endIndex);
+                    int currentStartIndex = currentName.indexOf("V");
+                    if (currentName.contains("W")) {
+                        currentStartIndex = closestName.indexOf("W");
+                    }
+                    if (currentName.contains("Z")) {
+                        currentStartIndex = closestName.indexOf("Z");
+                    }
+                    int currentEndIndex = currentName.indexOf(".", currentStartIndex);
+                    String newName = currentName.substring(0, currentStartIndex)
+                            + replacement
+                            + currentName.substring(currentEndIndex);
+                    currentFile.setFileName(newName);
+                    updateById(currentFile.getId(), currentFile);
+                });
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
 
     public void updateById(Integer id, MediaFileMarkEntity entity) {
         entity.setIsadd(1);
@@ -633,13 +646,13 @@
         mapper.update(entity, updateWrapper);
     }
 
-//    public void getNoaddFile() {
-//        List<MediaFileMarkEntity> markEntities = markMapper.selectList(new LambdaQueryWrapper<MediaFileMarkEntity>().eq(MediaFileMarkEntity::getIsadd, 0));
-//        for (MediaFileMarkEntity mark : markEntities) {
-//            updateMarkMediaFileNames(mark.getJobId());
-//            updateMediaFileNames(mark.getJobId());
-//        }
-//    }
+    public void getNoaddFile() {
+        List<MediaFileMarkEntity> markEntities = markMapper.selectList(new LambdaQueryWrapper<MediaFileMarkEntity>().eq(MediaFileMarkEntity::getIsadd, 0));
+        for (MediaFileMarkEntity mark : markEntities) {
+            updateMarkMediaFileNames(mark.getJobId());
+            updateMediaFileNames(mark.getJobId());
+        }
+    }
 
 }
 
diff --git a/src/main/java/com/dji/sample/patches/controller/PatchesController.java b/src/main/java/com/dji/sample/patches/controller/PatchesController.java
index 5ea6566..ce6ff55 100644
--- a/src/main/java/com/dji/sample/patches/controller/PatchesController.java
+++ b/src/main/java/com/dji/sample/patches/controller/PatchesController.java
@@ -202,8 +202,9 @@
                                                                            @RequestParam(name = "page_size", defaultValue = "10") Integer pageSize,
                                                                            @RequestParam String workspaceId,
                                                                            @RequestParam String dkbh) {
-//        fileService.getNoaddFile();
+
         try {
+            fileService.getNoaddFile();
             PatchesParam param = PatchesParam.builder()
                     .page(page)
                     .workspaceId(workspaceId)

--
Gitblit v1.9.3