From 2b35b23f53cde5e76a9cc7d0c6a027335bd59f9a Mon Sep 17 00:00:00 2001
From: shenyijian <1178253012@qq.com>
Date: Sat, 11 Nov 2023 16:31:11 +0800
Subject: [PATCH] 无人机 - 媒体库列表新增查询条件航线库ID

---
 src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java |   73 ++++++++++++++++++++++++++++++++++--
 1 files changed, 69 insertions(+), 4 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 cbc8ad4..da5b60b 100644
--- a/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java
+++ b/src/main/java/com/dji/sample/wayline/controller/WaylineJobController.java
@@ -3,7 +3,10 @@
 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.model.dto.WaylineJobCountDTO;
 import com.dji.sample.wayline.model.dto.WaylineJobDTO;
+import com.dji.sample.wayline.model.entity.WaylineJobEntity;
 import com.dji.sample.wayline.model.param.CreateJobParam;
 import com.dji.sample.wayline.model.param.UpdateJobParam;
 import com.dji.sample.wayline.model.param.WaylineJobQueryParam;
@@ -31,7 +34,7 @@
     private IWaylineJobService waylineJobService;
 
     /**
-     * Create a wayline task for the Dock.
+     * 创建航路任务。
      * @param request
      * @param param
      * @param workspaceId
@@ -39,6 +42,7 @@
      * @throws SQLException
      */
     @PostMapping("/{workspace_id}/flight-tasks")
+    @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);
@@ -47,14 +51,34 @@
         return waylineJobService.publishFlightTask(param, customClaim);
     }
 
+
     /**
-     * Paginate through all jobs in this workspace.
+     * 创建航路任务(重复定时和连续执行)
+     * @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);
+    }
+
+    /**
+     * 分页查询
      * @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, WaylineJobQueryParam waylineJobQueryParam){
@@ -63,13 +87,29 @@
     }
 
     /**
-     * Send the command to cancel the jobs.
+     * 查询最新的记录
+     * @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
      */
     @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);
@@ -77,12 +117,13 @@
     }
 
     /**
-     * Set the media files for this job to upload immediately.
+     * 将此作业的媒体文件设置为立即上传。
      * @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);
@@ -90,10 +131,34 @@
     }
 
     @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){
+
+        WaylineJobCountDTO waylineJobCountDTO = waylineJobService.patrolStatistics(workspaceId);
+
+        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();
+    }
 }

--
Gitblit v1.9.3