From fa89f5c4b746a41efee0362bd3a42ea2c97e2cff Mon Sep 17 00:00:00 2001
From: rain <167982779@qq.com>
Date: Mon, 22 Apr 2024 18:13:46 +0800
Subject: [PATCH] 在加水印前对文件进行音视频处理,分别执行不同方法。增加图片压缩、视频压缩方法。

---
 src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java |  178 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 162 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java b/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java
index f066f54..b0a3ac9 100644
--- a/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java
+++ b/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java
@@ -1,16 +1,27 @@
 package com.dji.sample.wayline.controller;
 
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.dji.sample.common.model.CustomClaim;
 import com.dji.sample.common.model.PaginationData;
 import com.dji.sample.common.model.ResponseResult;
+import com.dji.sample.log.aspect.SysLogAnnotation;
+import com.dji.sample.wayline.dao.IWaylineJobMapper;
+import com.dji.sample.wayline.model.dto.WaylineJobCountDTO;
 import com.dji.sample.wayline.model.dto.WaylineJobDTO;
-import com.dji.sample.wayline.model.param.CreateJobParam;
+import com.dji.sample.wayline.model.entity.WaylineJobEntity;
+import com.dji.sample.wayline.model.param.*;
 import com.dji.sample.wayline.service.IWaylineJobService;
+import com.dji.sample.wayline.service.impl.WaylineJobServiceImpl;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
 import javax.servlet.http.HttpServletRequest;
+import javax.validation.Valid;
 import java.sql.SQLException;
+import java.util.List;
+import java.util.Optional;
+import java.util.Set;
 
 import static com.dji.sample.component.AuthInterceptor.TOKEN_CLAIM;
 
@@ -27,7 +38,8 @@
     private IWaylineJobService waylineJobService;
 
     /**
-     * Create a wayline task for the Dock.
+     * 创建航路任务。
+     *
      * @param request
      * @param param
      * @param workspaceId
@@ -35,40 +47,174 @@
      * @throws SQLException
      */
     @PostMapping("/{workspace_id}/flight-tasks")
-    public ResponseResult createJob(HttpServletRequest request, @RequestBody CreateJobParam param,
+    @SysLogAnnotation(operModul = "计划库", operType = "新增", operDesc = "创建计划")
+    public ResponseResult createJob(HttpServletRequest request, @Valid @RequestBody CreateJobParam param,
                                     @PathVariable(name = "workspace_id") String workspaceId) throws SQLException {
-        CustomClaim customClaim = (CustomClaim)request.getAttribute(TOKEN_CLAIM);
+        CustomClaim customClaim = (CustomClaim) request.getAttribute(TOKEN_CLAIM);
         customClaim.setWorkspaceId(workspaceId);
-        boolean isCreate = waylineJobService.createJob(param, customClaim);
-        return isCreate ? ResponseResult.success() : ResponseResult.error();
+
+        return waylineJobService.publishFlightTask(param, customClaim);
+    }
+
+
+    /**
+     * 创建航路任务(重复定时和连续执行)
+     *
+     * @param request
+     * @param param
+     * @param workspaceId
+     * @return
+     * @throws SQLException
+     */
+    @PostMapping("/{workspace_id}/flight-tasks-condition")
+    @SysLogAnnotation(operModul = "计划库", operType = "新增", operDesc = "创建航路任务(重复定时和连续执行)")
+    public ResponseResult createJobCondition(HttpServletRequest request, @Valid @RequestBody CreateJobParam param,
+                                             @PathVariable(name = "workspace_id") String workspaceId) throws SQLException {
+        CustomClaim customClaim = (CustomClaim) request.getAttribute(TOKEN_CLAIM);
+        customClaim.setWorkspaceId(workspaceId);
+
+        return waylineJobService.publishFlightTaskCondition(param, customClaim);
     }
 
     /**
-     * Paginate through all jobs in this workspace.
+     * 断点任务
+     * @return
+     */
+    @PostMapping("/{workspace_id}/breakpoint-tasks")
+    @SysLogAnnotation(operModul = "计划库", operType = "断点续飞", operDesc = "创建航路任务(重复定时和连续执行)")
+    public ResponseResult breakPointJob(HttpServletRequest request, @Valid @RequestBody BreakPointJobParam param,
+                                        @PathVariable(name = "workspace_id") String workspaceId) throws SQLException {
+        Optional<WaylineJobDTO> waylineJobDTO = waylineJobService.getJobByJobId(workspaceId, param.getJobId(),param.isBreakPoint());
+        return waylineJobService.publishOneFlightTask(waylineJobDTO.get());
+    }
+
+    /**
+     * 分页查询
+     *
      * @param page
      * @param pageSize
      * @param workspaceId
      * @return
      */
     @GetMapping("/{workspace_id}/jobs")
+    @SysLogAnnotation(operModul = "计划库", operType = "查询", operDesc = "分页查询")
     public ResponseResult<PaginationData<WaylineJobDTO>> getJobs(@RequestParam(defaultValue = "1") Long page,
-                     @RequestParam(name = "page_size", defaultValue = "10") Long pageSize,
-                     @PathVariable(name = "workspace_id") String workspaceId) {
-        PaginationData<WaylineJobDTO> data = waylineJobService.getJobsByWorkspaceId(workspaceId, page, pageSize);
+                                                                 @RequestParam(name = "page_size", defaultValue = "10") Long pageSize,
+                                                                 @PathVariable(name = "workspace_id") String workspaceId, WaylineJobQueryParam waylineJobQueryParam) {
+        PaginationData<WaylineJobDTO> data = waylineJobService.getJobsByWorkspaceId(workspaceId, page, pageSize, waylineJobQueryParam);
+        return ResponseResult.success(data);
+    }
+
+    @GetMapping("/{workspace_id}/jobs-dp")
+    @SysLogAnnotation(operModul = "计划库", operType = "查询", operDesc = "分页查询")
+    public ResponseResult<PaginationData<WaylineJobDTO>> getJobsByState(@RequestParam(defaultValue = "1") Long page,
+                                                                 @RequestParam(name = "page_size", defaultValue = "10") Long pageSize,
+                                                                 @PathVariable(name = "workspace_id") String workspaceId,
+                                                                 @RequestParam(name = "order", defaultValue = "") String order,
+                                                                 WaylineJobQueryParam waylineJobQueryParam) {
+        PaginationData<WaylineJobDTO> data = waylineJobService.getJobsByWorkspaceIdNew(workspaceId, page, pageSize, waylineJobQueryParam,order);
         return ResponseResult.success(data);
     }
 
     /**
-     * Issue wayline mission to the dock for execution.
-     * @param jobId
+     * 子查询
+     * @param workspaceId
+     * @return
+     */
+    @GetMapping("/{workspace_id}/getChildrenJobs")
+    @SysLogAnnotation(operModul = "计划库", operType = "查询", operDesc = "分页查询")
+    public ResponseResult<List<WaylineJobDTO>> getChildrenJobs(
+                                                                 @PathVariable(name = "workspace_id") String workspaceId, WaylineJobQueryParam waylineJobQueryParam) {
+        List<WaylineJobDTO> data = waylineJobService.getChildrenJobs(workspaceId, waylineJobQueryParam);
+        return ResponseResult.success(data);
+    }
+
+
+    /**
+     * 查询最新的记录
+     *
+     * @return
+     */
+    @GetMapping("/{workspace_id}/latestJob")
+    public ResponseResult<WaylineJobEntity> getLatestJobs(@PathVariable(name = "workspace_id") String workspaceId, WaylineJobQueryParam waylineJobQueryParam) {
+
+        WaylineJobEntity waylineJobEntity = waylineJobService.getLatestJob(workspaceId, waylineJobQueryParam);
+
+        return ResponseResult.success(waylineJobEntity);
+    }
+
+
+    /**
+     * 发送命令取消作业。
+     *
+     * @param jobIds
      * @param workspaceId
      * @return
      * @throws SQLException
      */
-    @PostMapping("/{workspace_id}/jobs/{job_id}")
-    public ResponseResult publishJob(@PathVariable(name = "job_id") String jobId,
-                                     @PathVariable(name = "workspace_id") String workspaceId) throws SQLException {
-        waylineJobService.publishFlightTask(workspaceId, jobId);
+    @DeleteMapping("/{workspace_id}/jobs")
+    @SysLogAnnotation(operModul = "计划库", operType = "删除", operDesc = "发送命令取消作业")
+    public ResponseResult publishCancelJob(@RequestParam(name = "job_id") Set<String> jobIds,
+                                           @PathVariable(name = "workspace_id") String workspaceId) throws SQLException {
+        waylineJobService.cancelFlightTask(workspaceId, jobIds);
         return ResponseResult.success();
     }
+
+    /**
+     * 将此作业的媒体文件设置为立即上传。
+     *
+     * @param workspaceId
+     * @param jobId
+     * @return
+     */
+    @PostMapping("/{workspace_id}/jobs/{job_id}/media-highest")
+    @SysLogAnnotation(operModul = "计划库", operType = "修改", operDesc = "将此作业的媒体文件设置为立即上传")
+    public ResponseResult uploadMediaHighestPriority(@PathVariable(name = "workspace_id") String workspaceId,
+                                                     @PathVariable(name = "job_id") String jobId) {
+        waylineJobService.uploadMediaHighestPriority(workspaceId, jobId);
+        return ResponseResult.success();
+    }
+
+    @PutMapping("/{workspace_id}/jobs/{job_id}")
+    @SysLogAnnotation(operModul = "计划库", operType = "修改", operDesc = "修改")
+    public ResponseResult updateJobStatus(@PathVariable(name = "workspace_id") String workspaceId,
+                                          @PathVariable(name = "job_id") String jobId,
+                                          @Valid @RequestBody UpdateJobParam param) {
+        waylineJobService.updateJobStatus(workspaceId, jobId, param);
+        return ResponseResult.success();
+    }
+
+    /**
+     * 统计飞行次数
+     */
+    @PostMapping("/{workspace_id}/patrol_statistics")
+    public ResponseResult<WaylineJobCountDTO> patrolStatistics(@PathVariable(name = "workspace_id") String workspaceId,String queryTime,String deviceSn) {
+
+        WaylineJobCountDTO waylineJobCountDTO = waylineJobService.patrolStatistics(workspaceId,queryTime,deviceSn);
+
+        return ResponseResult.success(waylineJobCountDTO);
+    }
+
+    /**
+     * 收藏媒体库
+     */
+    @PostMapping("/update_job_collect")
+    public ResponseResult updateJobCollect(HttpServletRequest request, @RequestBody WaylineJobEntity waylineJob) {
+        CustomClaim claims = (CustomClaim) request.getAttribute(TOKEN_CLAIM);
+        waylineJob.setUserId(claims.getId());
+        waylineJobService.updateJobCollect(waylineJob);
+
+        return ResponseResult.success();
+    }
+
+    /**
+     * 根据区域飞行
+     *
+     * @return
+     */
+    @PostMapping("/{sn}/jobs/{device_sn}/flyByArea")
+    @SysLogAnnotation(operModul = "根据区域飞行", operType = "根据区域飞行", operDesc = "根据区域飞行")
+    public ResponseResult flyByArea(@PathVariable(name = "sn") String sn, @RequestBody FlyAreaParam flyAreaParam,@PathVariable(name = "device_sn")String deviceSn)throws Exception {
+            return waylineJobService.flyByArea(sn, flyAreaParam,deviceSn);
+    }
 }

--
Gitblit v1.9.3