From 2aaaaf4598b869085ae35871de018cd35847c232 Mon Sep 17 00:00:00 2001
From: aix <vip_xiaobin810@163.com>
Date: Tue, 09 Jul 2024 16:41:39 +0800
Subject: [PATCH] 航线拐点

---
 src/main/java/com/dji/sample/patches/controller/PatchesController.java |  131 ++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 122 insertions(+), 9 deletions(-)

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 3e53592..60a880c 100644
--- a/src/main/java/com/dji/sample/patches/controller/PatchesController.java
+++ b/src/main/java/com/dji/sample/patches/controller/PatchesController.java
@@ -4,27 +4,31 @@
 import com.dji.sample.common.model.PaginationData;
 import com.dji.sample.common.model.ResponseResult;
 import com.dji.sample.common.util.MinioUrlUtils;
-import com.dji.sample.log.aspect.SysLogAnnotation;
 import com.dji.sample.media.model.MediaFileEntity;
+import com.dji.sample.media.service.impl.FileServiceImpl;
 import com.dji.sample.patches.model.Param.PatchesParam;
 import com.dji.sample.patches.model.entity.LotInfo;
 import com.dji.sample.patches.service.GetPatchesService;
 import com.dji.sample.patches.service.ShpToDataSourceService;
-import com.dji.sample.patches.service.impl.ShpToDataSourceServiceImpl;
+import com.dji.sample.patches.utils.DistrictCodeUtils;
 import com.dji.sample.patches.utils.TimerUtil;
 import com.dji.sample.territory.service.impl.TbDkjbxxServiceImpl;
 import com.dji.sample.wayline.model.entity.WaylineFileEntity;
 import com.dji.sample.wayline.service.IWaylineFileService;
+import com.dji.sample.wayline.service.IWaylineJobService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
 import javax.servlet.http.HttpServletRequest;
+import java.io.IOException;
 import java.net.URL;
 import java.sql.SQLException;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
 
 import static com.dji.sample.component.AuthInterceptor.TOKEN_CLAIM;
 
@@ -38,9 +42,14 @@
     @Autowired
     private IWaylineFileService waylineFileService;
     @Autowired
+    private IWaylineJobService waylineJobService;
+    @Autowired
     private TbDkjbxxServiceImpl tbDkjbxxService;
     @Autowired
+    private FileServiceImpl fileService;
+    @Autowired
     private TimerUtil timerUtil;
+
     /**
      * 根据workspaceId获取图斑列表信息
      *
@@ -50,15 +59,27 @@
      * @return
      */
     @GetMapping("/listPatches")
-    @SysLogAnnotation(operModul = "图斑", operType = "查询", operDesc = "查询图斑的全部信息")
     public ResponseResult<PaginationData<LotInfo>> page(@RequestParam Integer page,
                                                         @RequestParam(name = "page_size", defaultValue = "10") Integer pageSize,
-                                                        @RequestParam String workspaceId) {
+                                                        @RequestParam String workspaceId,
+                                                        @RequestParam(name = "dkbh", required = false) String dkbh,
+                                                        @RequestParam(name = "xzqdm", required = false) String xzqdm,
+                                                        @RequestParam(name = "bsm", required = false) String bsm,
+                                                        @RequestParam(name = "xmc", required = false) String xmc,
+                                                        @RequestParam(name = "investigate", required = false) Integer investigate
+    ) {
+        fileService.getNoaddFile();
         //调用service分页查询
         PatchesParam param = PatchesParam.builder()
                 .page(page)
                 .workspaceId(workspaceId)
-                .pageSize(pageSize).build();
+                .pageSize(pageSize)
+                .dkbh(dkbh)
+                .xzqdm(xzqdm)
+                .bsm(bsm)
+                .xmc(xmc)
+                .investigate(investigate)
+                .build();
         PaginationData<LotInfo> data = getPatchesService.limitGet(param);
         return ResponseResult.success(data);
     }
@@ -70,14 +91,105 @@
      * @return 返回操作结果,如果操作成功,则返回一个成功的响应结果。
      */
     @DeleteMapping("/deletePatches")
-    public ResponseResult del() {
-        getPatchesService.delPatches();
-        return ResponseResult.success();
+    public ResponseResult del(String workspaceId) {
+        int count = getPatchesService.delPatches(workspaceId);
+        return ResponseResult.success("删除的图斑数量是" + count);
     }
+
+    @DeleteMapping("/deleteOne")
+    public ResponseResult deleteOne(int id) {
+        int count = getPatchesService.deleteOne(id);
+        if (count != 0) {
+            return ResponseResult.success("图斑删除成功id为" + id);
+        }
+        return ResponseResult.error("图斑删除失败");
+    }
+
+    @GetMapping("/getXzq")
+    public ResponseResult xzq(@RequestParam String code) {
+        String xzq = DistrictCodeUtils.nameToCode(code);
+        return ResponseResult.success(xzq);
+    }
+
+    @GetMapping("/getInfoById")
+    public ResponseResult<LotInfo> wayAndPatchesId(@RequestParam String patchesId) {
+        return ResponseResult.success(getPatchesService.getPatchesFromId(patchesId));
+    }
+
+    @GetMapping("/getWayline")
+    public ResponseResult getWayline(@RequestParam String waylineName, @RequestBody List<LotInfo> list) {
+        try {
+            MultipartFile file = timerUtil.getFile(waylineName, list, 25.8917266,116.020940643);
+            return ResponseResult.success(file);
+        } catch (IOException e) {
+            throw new RuntimeException(e);
+        }
+    }
+
+
+        @PostMapping("/patchesToWayline")
+        public ResponseResult patchesToWayline(@RequestBody List<LotInfo> lotInfos,
+                                               @RequestParam String waylineName,
+                                               @RequestParam String spotInFreckle,
+                                               @RequestParam String workspaceId,
+                                               @RequestParam String patchesId,
+                                               @RequestParam double lat,
+                                               @RequestParam double lon,
+                                               HttpServletRequest request) throws IOException {
+            CustomClaim customClaim = (CustomClaim) request.getAttribute(TOKEN_CLAIM);
+            String creator = customClaim.getUsername();
+            MultipartFile file = timerUtil.getFile(waylineName, lotInfos, lat, lon);
+            waylineFileService.importKmzFile(file, workspaceId, creator, patchesId, spotInFreckle);
+            WaylineFileEntity entity = waylineFileService.selectByName(waylineName);
+            Map<String, String> infoMap = new HashMap<>();
+            URL url = null;
+            try {
+                url = waylineFileService.getObjectUrl(workspaceId, entity.getWaylineId());
+                infoMap.put("url", String.valueOf(MinioUrlUtils.getUrl(url)));
+                infoMap.put("waylineId", entity.getWaylineId());
+            } catch (SQLException e) {
+                throw new RuntimeException(e);
+            }
+            return ResponseResult.success(infoMap);
+        }
+
     @GetMapping("/useMyTask")
     public ResponseResult useMyTask() throws Exception {
-        timerUtil.myTask();
+        try {
+//            timerUtil.myTask();
+//            timerUtil.myTask2();
+//            timerUtil.myTask3();
+            timerUtil.mytask4();
+            timerUtil.mytask5();
+            timerUtil.mytask6();
+            timerUtil.mytask7();
+
+        } catch (Exception e) {
+            throw new RuntimeException("db存储发送出现异常" + e);
+        }
         return ResponseResult.success();
+    }
+
+    @GetMapping ("/tests")
+    public ResponseResult use()  {
+            ExecutorService executor = Executors.newSingleThreadExecutor();
+            executor.execute(() -> {
+                try {
+                    timerUtil.sendPostWithFileAndParameter("DB/result_db.db",
+                            "635148ea-0ddb-4b23-945c-8a67abd813c9");
+                } catch (Exception e) {
+                    throw new RuntimeException(e);
+                }
+            });
+            executor.shutdown();
+            return ResponseResult.success();
+    }
+    @PostMapping("/way")
+    public void getway(@RequestParam("file") MultipartFile file,
+                       @RequestParam String workspaceId,
+                       @RequestParam String waylineName,
+                       @RequestParam String username) {
+        waylineFileService.importKmzFileBack(file, workspaceId, username);
     }
 
     /**
@@ -94,6 +206,7 @@
                                                                            @RequestParam(name = "page_size", defaultValue = "10") Integer pageSize,
                                                                            @RequestParam String workspaceId,
                                                                            @RequestParam String dkbh) {
+
         try {
             PatchesParam param = PatchesParam.builder()
                     .page(page)

--
Gitblit v1.9.3