🔨 批量上传任务.
This commit is contained in:
@@ -59,6 +59,16 @@ public class CodeGenerators {
|
|||||||
.labels("准备中", "上传中", "已完成", "已取消")
|
.labels("准备中", "上传中", "已完成", "已取消")
|
||||||
.valueUseFields()
|
.valueUseFields()
|
||||||
.build(),
|
.build(),
|
||||||
|
Template.create("upload_task_file", "上传任务文件", "upload")
|
||||||
|
.disableUnitTest()
|
||||||
|
.vue("exec", "batch-upload-file")
|
||||||
|
.enableRowSelection()
|
||||||
|
.dict("uploadTaskFileStatus", "status")
|
||||||
|
.comment("上传任务文件状态")
|
||||||
|
.fields("WAITING", "UPLOADING", "FINISHED", "CANCELED")
|
||||||
|
.labels("等待中", "上传中", "已完成", "已取消")
|
||||||
|
.valueUseFields()
|
||||||
|
.build(),
|
||||||
};
|
};
|
||||||
// jdbc 配置 - 使用配置文件
|
// jdbc 配置 - 使用配置文件
|
||||||
File yamlFile = new File("orion-ops-launch/src/main/resources/application-dev.yaml");
|
File yamlFile = new File("orion-ops-launch/src/main/resources/application-dev.yaml");
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ import com.orion.ops.framework.log.core.enums.IgnoreLogMode;
|
|||||||
import com.orion.ops.framework.security.core.utils.SecurityUtils;
|
import com.orion.ops.framework.security.core.utils.SecurityUtils;
|
||||||
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
||||||
import com.orion.ops.module.asset.define.operator.ExecCommandLogOperatorType;
|
import com.orion.ops.module.asset.define.operator.ExecCommandLogOperatorType;
|
||||||
import com.orion.ops.module.asset.define.operator.ExecCommandOperatorType;
|
|
||||||
import com.orion.ops.module.asset.entity.request.exec.ExecInterruptRequest;
|
import com.orion.ops.module.asset.entity.request.exec.ExecInterruptRequest;
|
||||||
import com.orion.ops.module.asset.entity.request.exec.ExecLogQueryRequest;
|
import com.orion.ops.module.asset.entity.request.exec.ExecLogQueryRequest;
|
||||||
import com.orion.ops.module.asset.entity.request.exec.ExecLogTailRequest;
|
import com.orion.ops.module.asset.entity.request.exec.ExecLogTailRequest;
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ import com.orion.ops.framework.common.validator.group.Page;
|
|||||||
import com.orion.ops.framework.log.core.annotation.IgnoreLog;
|
import com.orion.ops.framework.log.core.annotation.IgnoreLog;
|
||||||
import com.orion.ops.framework.log.core.enums.IgnoreLogMode;
|
import com.orion.ops.framework.log.core.enums.IgnoreLogMode;
|
||||||
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
||||||
import com.orion.ops.module.asset.define.operator.ExecCommandLogOperatorType;
|
|
||||||
import com.orion.ops.module.asset.define.operator.ExecJobLogOperatorType;
|
import com.orion.ops.module.asset.define.operator.ExecJobLogOperatorType;
|
||||||
import com.orion.ops.module.asset.entity.request.exec.ExecInterruptRequest;
|
import com.orion.ops.module.asset.entity.request.exec.ExecInterruptRequest;
|
||||||
import com.orion.ops.module.asset.entity.request.exec.ExecLogQueryRequest;
|
import com.orion.ops.module.asset.entity.request.exec.ExecLogQueryRequest;
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package com.orion.ops.module.asset.controller;
|
package com.orion.ops.module.asset.controller;
|
||||||
|
|
||||||
import com.orion.lang.define.wrapper.DataGrid;
|
import com.orion.lang.define.wrapper.DataGrid;
|
||||||
|
import com.orion.lang.define.wrapper.HttpWrapper;
|
||||||
import com.orion.ops.framework.biz.operator.log.core.annotation.OperatorLog;
|
import com.orion.ops.framework.biz.operator.log.core.annotation.OperatorLog;
|
||||||
import com.orion.ops.framework.common.validator.group.Page;
|
import com.orion.ops.framework.common.validator.group.Page;
|
||||||
import com.orion.ops.framework.log.core.annotation.IgnoreLog;
|
import com.orion.ops.framework.log.core.annotation.IgnoreLog;
|
||||||
@@ -9,6 +10,7 @@ import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
|||||||
import com.orion.ops.module.asset.define.operator.UploadTaskOperatorType;
|
import com.orion.ops.module.asset.define.operator.UploadTaskOperatorType;
|
||||||
import com.orion.ops.module.asset.entity.request.upload.UploadTaskCreateRequest;
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskCreateRequest;
|
||||||
import com.orion.ops.module.asset.entity.request.upload.UploadTaskQueryRequest;
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskQueryRequest;
|
||||||
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskRequest;
|
||||||
import com.orion.ops.module.asset.entity.vo.UploadTaskCreateVO;
|
import com.orion.ops.module.asset.entity.vo.UploadTaskCreateVO;
|
||||||
import com.orion.ops.module.asset.entity.vo.UploadTaskVO;
|
import com.orion.ops.module.asset.entity.vo.UploadTaskVO;
|
||||||
import com.orion.ops.module.asset.service.UploadTaskService;
|
import com.orion.ops.module.asset.service.UploadTaskService;
|
||||||
@@ -43,9 +45,6 @@ public class UploadTaskController {
|
|||||||
private UploadTaskService uploadTaskService;
|
private UploadTaskService uploadTaskService;
|
||||||
|
|
||||||
// TODO 字典颜色 菜单 操作日志
|
// TODO 字典颜色 菜单 操作日志
|
||||||
// TODO start
|
|
||||||
// TODO cancel
|
|
||||||
// todo CLEAR
|
|
||||||
|
|
||||||
@OperatorLog(UploadTaskOperatorType.UPLOAD)
|
@OperatorLog(UploadTaskOperatorType.UPLOAD)
|
||||||
@PostMapping("/create")
|
@PostMapping("/create")
|
||||||
@@ -55,6 +54,23 @@ public class UploadTaskController {
|
|||||||
return uploadTaskService.createUploadTask(request);
|
return uploadTaskService.createUploadTask(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/start")
|
||||||
|
@Operation(summary = "开始上传")
|
||||||
|
@PreAuthorize("@ss.hasPermission('asset:upload-task:upload')")
|
||||||
|
public HttpWrapper<?> startUploadTask(@Validated @RequestBody UploadTaskRequest request) {
|
||||||
|
uploadTaskService.startUploadTask(request.getId());
|
||||||
|
return HttpWrapper.ok();
|
||||||
|
}
|
||||||
|
|
||||||
|
@OperatorLog(UploadTaskOperatorType.CANCEL)
|
||||||
|
@PostMapping("/cancel")
|
||||||
|
@Operation(summary = "取消上传")
|
||||||
|
@PreAuthorize("@ss.hasPermission('asset:upload-task:upload')")
|
||||||
|
public HttpWrapper<?> cancelUploadTask(@Validated @RequestBody UploadTaskRequest request) {
|
||||||
|
uploadTaskService.cancelUploadTask(request.getId());
|
||||||
|
return HttpWrapper.ok();
|
||||||
|
}
|
||||||
|
|
||||||
@IgnoreLog(IgnoreLogMode.RET)
|
@IgnoreLog(IgnoreLogMode.RET)
|
||||||
@GetMapping("/get")
|
@GetMapping("/get")
|
||||||
@Operation(summary = "查询上传任务")
|
@Operation(summary = "查询上传任务")
|
||||||
@@ -90,5 +106,20 @@ public class UploadTaskController {
|
|||||||
return uploadTaskService.deleteUploadTaskByIdList(idList);
|
return uploadTaskService.deleteUploadTaskByIdList(idList);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/query-count")
|
||||||
|
@Operation(summary = "查询主机连接日志数量")
|
||||||
|
@PreAuthorize("@ss.hasPermission('asset:upload-task:management:clear')")
|
||||||
|
public Long getUploadTaskCount(@RequestBody UploadTaskQueryRequest request) {
|
||||||
|
return uploadTaskService.getUploadTaskCount(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@OperatorLog(UploadTaskOperatorType.CLEAR)
|
||||||
|
@PostMapping("/clear")
|
||||||
|
@Operation(summary = "清空主机连接日志")
|
||||||
|
@PreAuthorize("@ss.hasPermission('asset:upload-task:management:clear')")
|
||||||
|
public Integer clearUploadTask(@RequestBody UploadTaskQueryRequest request) {
|
||||||
|
return uploadTaskService.clearUploadTask(request);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,26 @@
|
|||||||
|
package com.orion.ops.module.asset.convert;
|
||||||
|
|
||||||
|
import com.orion.ops.module.asset.entity.domain.UploadTaskFileDO;
|
||||||
|
import com.orion.ops.module.asset.entity.vo.UploadTaskFileVO;
|
||||||
|
import org.mapstruct.Mapper;
|
||||||
|
import org.mapstruct.factory.Mappers;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 内部对象转换器
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface UploadTaskFileConvert {
|
||||||
|
|
||||||
|
UploadTaskFileConvert MAPPER = Mappers.getMapper(UploadTaskFileConvert.class);
|
||||||
|
|
||||||
|
UploadTaskFileVO to(UploadTaskFileDO domain);
|
||||||
|
|
||||||
|
List<UploadTaskFileVO> to(List<UploadTaskFileDO> list);
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.orion.ops.module.asset.dao;
|
||||||
|
|
||||||
|
import com.orion.ops.framework.mybatis.core.mapper.IMapper;
|
||||||
|
import com.orion.ops.module.asset.entity.domain.UploadTaskFileDO;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 Mapper 接口
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface UploadTaskFileDAO extends IMapper<UploadTaskFileDO> {
|
||||||
|
|
||||||
|
}
|
||||||
@@ -4,7 +4,8 @@ import com.orion.ops.framework.biz.operator.log.core.annotation.Module;
|
|||||||
import com.orion.ops.framework.biz.operator.log.core.factory.InitializingOperatorTypes;
|
import com.orion.ops.framework.biz.operator.log.core.factory.InitializingOperatorTypes;
|
||||||
import com.orion.ops.framework.biz.operator.log.core.model.OperatorType;
|
import com.orion.ops.framework.biz.operator.log.core.model.OperatorType;
|
||||||
|
|
||||||
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.*;
|
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.H;
|
||||||
|
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.M;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 主机连接日志 操作日志类型
|
* 主机连接日志 操作日志类型
|
||||||
|
|||||||
@@ -4,7 +4,8 @@ import com.orion.ops.framework.biz.operator.log.core.annotation.Module;
|
|||||||
import com.orion.ops.framework.biz.operator.log.core.factory.InitializingOperatorTypes;
|
import com.orion.ops.framework.biz.operator.log.core.factory.InitializingOperatorTypes;
|
||||||
import com.orion.ops.framework.biz.operator.log.core.model.OperatorType;
|
import com.orion.ops.framework.biz.operator.log.core.model.OperatorType;
|
||||||
|
|
||||||
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.*;
|
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.H;
|
||||||
|
import static com.orion.ops.framework.biz.operator.log.core.enums.OperatorRiskLevel.M;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传任务 操作日志类型
|
* 上传任务 操作日志类型
|
||||||
@@ -18,13 +19,19 @@ public class UploadTaskOperatorType extends InitializingOperatorTypes {
|
|||||||
|
|
||||||
public static final String UPLOAD = "upload-task:upload";
|
public static final String UPLOAD = "upload-task:upload";
|
||||||
|
|
||||||
|
public static final String CANCEL = "upload-task:cancel";
|
||||||
|
|
||||||
public static final String DELETE = "upload-task:delete";
|
public static final String DELETE = "upload-task:delete";
|
||||||
|
|
||||||
|
public static final String CLEAR = "upload-task:clear";
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public OperatorType[] types() {
|
public OperatorType[] types() {
|
||||||
return new OperatorType[]{
|
return new OperatorType[]{
|
||||||
new OperatorType(M, UPLOAD, "批量上传文件"),
|
new OperatorType(M, UPLOAD, "批量上传文件 <sb>${count}</sb>个 (<sb>${name}</sb>)"),
|
||||||
new OperatorType(H, DELETE, "删除批量上传记录"),
|
new OperatorType(M, CANCEL, "取消上传文件 <sb>${name}</sb>"),
|
||||||
|
new OperatorType(H, DELETE, "删除上传记录 <sb>${count}</sb>条"),
|
||||||
|
new OperatorType(H, CLEAR, "清理上传记录 <sb>${count}</sb>条"),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,67 @@
|
|||||||
|
package com.orion.ops.module.asset.entity.domain;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import com.orion.ops.framework.mybatis.core.domain.BaseDO;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 实体对象
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@TableName(value = "upload_task_file", autoResultMap = true)
|
||||||
|
@Schema(name = "UploadTaskFileDO", description = "上传任务文件 实体对象")
|
||||||
|
public class UploadTaskFileDO extends BaseDO {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@Schema(description = "id")
|
||||||
|
@TableId(value = "id", type = IdType.AUTO)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@Schema(description = "用户id")
|
||||||
|
@TableField("task_id")
|
||||||
|
private Long taskId;
|
||||||
|
|
||||||
|
@Schema(description = "主机id")
|
||||||
|
@TableField("host_id")
|
||||||
|
private Long hostId;
|
||||||
|
|
||||||
|
@Schema(description = "文件id")
|
||||||
|
@TableField("file_id")
|
||||||
|
private String fileId;
|
||||||
|
|
||||||
|
@Schema(description = "文件路径")
|
||||||
|
@TableField("file_path")
|
||||||
|
private String filePath;
|
||||||
|
|
||||||
|
@Schema(description = "文件大小")
|
||||||
|
@TableField("file_size")
|
||||||
|
private Long fileSize;
|
||||||
|
|
||||||
|
@Schema(description = "状态")
|
||||||
|
@TableField("status")
|
||||||
|
private String status;
|
||||||
|
|
||||||
|
@Schema(description = "开始时间")
|
||||||
|
@TableField("start_time")
|
||||||
|
private Date startTime;
|
||||||
|
|
||||||
|
@Schema(description = "结束时间")
|
||||||
|
@TableField("end_time")
|
||||||
|
private Date endTime;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -7,6 +7,7 @@ import lombok.Data;
|
|||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
import javax.validation.constraints.NotBlank;
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -30,7 +31,11 @@ public class UploadTaskFileRequest implements Serializable {
|
|||||||
private String fileId;
|
private String fileId;
|
||||||
|
|
||||||
@NotBlank
|
@NotBlank
|
||||||
@Schema(description = "远程文件地址")
|
@Schema(description = "文件地址")
|
||||||
private String remotePath;
|
private String filePath;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Schema(description = "文件发小")
|
||||||
|
private Long fileSize;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,13 +33,13 @@ public class UploadTaskQueryRequest extends PageRequest {
|
|||||||
@Schema(description = "描述")
|
@Schema(description = "描述")
|
||||||
private String description;
|
private String description;
|
||||||
|
|
||||||
|
@Schema(description = "远程路径")
|
||||||
|
private String remotePath;
|
||||||
|
|
||||||
@Size(max = 16)
|
@Size(max = 16)
|
||||||
@Schema(description = "状态")
|
@Schema(description = "状态")
|
||||||
private String status;
|
private String status;
|
||||||
|
|
||||||
@Schema(description = "额外信息")
|
|
||||||
private String extraInfo;
|
|
||||||
|
|
||||||
@Schema(description = "开始时间-区间")
|
@Schema(description = "开始时间-区间")
|
||||||
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
|
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
|
||||||
private Date[] startTimeRange;
|
private Date[] startTimeRange;
|
||||||
|
|||||||
@@ -0,0 +1,32 @@
|
|||||||
|
package com.orion.ops.module.asset.entity.request.upload;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务 请求对象
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-7 22:15
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@Schema(name = "UploadTaskRequest", description = "上传任务 请求对象")
|
||||||
|
public class UploadTaskRequest implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Schema(description = "id")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,55 @@
|
|||||||
|
package com.orion.ops.module.asset.entity.vo;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 视图响应对象
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@Schema(name = "UploadTaskFileVO", description = "上传任务文件 视图响应对象")
|
||||||
|
public class UploadTaskFileVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@Schema(description = "id")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@Schema(description = "用户id")
|
||||||
|
private Long taskId;
|
||||||
|
|
||||||
|
@Schema(description = "主机id")
|
||||||
|
private Long hostId;
|
||||||
|
|
||||||
|
@Schema(description = "文件id")
|
||||||
|
private String fileId;
|
||||||
|
|
||||||
|
@Schema(description = "文件路径")
|
||||||
|
private String filePath;
|
||||||
|
|
||||||
|
@Schema(description = "文件大小")
|
||||||
|
private Long fileSize;
|
||||||
|
|
||||||
|
@Schema(description = "状态")
|
||||||
|
private String status;
|
||||||
|
|
||||||
|
@Schema(description = "开始时间")
|
||||||
|
private Date startTime;
|
||||||
|
|
||||||
|
@Schema(description = "结束时间")
|
||||||
|
private Date endTime;
|
||||||
|
|
||||||
|
}
|
||||||
@@ -8,6 +8,7 @@ import lombok.NoArgsConstructor;
|
|||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 上传任务 视图响应对象
|
* 上传任务 视图响应对象
|
||||||
@@ -55,4 +56,7 @@ public class UploadTaskVO implements Serializable {
|
|||||||
@Schema(description = "创建时间")
|
@Schema(description = "创建时间")
|
||||||
private Date createTime;
|
private Date createTime;
|
||||||
|
|
||||||
|
@Schema(description = "上传文件")
|
||||||
|
private List<UploadTaskFileVO> files;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,46 @@
|
|||||||
|
package com.orion.ops.module.asset.enums;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件状态
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.0
|
||||||
|
* @since 2024/5/7 22:21
|
||||||
|
*/
|
||||||
|
public enum UploadTaskFileStatusEnum {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 等待中
|
||||||
|
*/
|
||||||
|
WAITING,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传中
|
||||||
|
*/
|
||||||
|
UPLOADING,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 已完成
|
||||||
|
*/
|
||||||
|
FINISHED,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 已取消
|
||||||
|
*/
|
||||||
|
CANCELED,
|
||||||
|
|
||||||
|
;
|
||||||
|
|
||||||
|
public static UploadTaskFileStatusEnum of(String status) {
|
||||||
|
if (status == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
for (UploadTaskFileStatusEnum value : values()) {
|
||||||
|
if (value.name().equals(status)) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -12,8 +12,8 @@ import com.orion.ops.framework.common.security.PasswordModifier;
|
|||||||
import com.orion.ops.framework.common.utils.Valid;
|
import com.orion.ops.framework.common.utils.Valid;
|
||||||
import com.orion.ops.module.asset.dao.HostIdentityDAO;
|
import com.orion.ops.module.asset.dao.HostIdentityDAO;
|
||||||
import com.orion.ops.module.asset.dao.HostKeyDAO;
|
import com.orion.ops.module.asset.dao.HostKeyDAO;
|
||||||
import com.orion.ops.module.asset.enums.HostSshOsTypeEnum;
|
|
||||||
import com.orion.ops.module.asset.enums.HostSshAuthTypeEnum;
|
import com.orion.ops.module.asset.enums.HostSshAuthTypeEnum;
|
||||||
|
import com.orion.ops.module.asset.enums.HostSshOsTypeEnum;
|
||||||
import com.orion.ops.module.asset.handler.host.config.model.HostSshConfigModel;
|
import com.orion.ops.module.asset.handler.host.config.model.HostSshConfigModel;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
package com.orion.ops.module.asset.handler.host.terminal.handler;
|
package com.orion.ops.module.asset.handler.host.terminal.handler;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.orion.lang.utils.Strings;
|
|
||||||
import com.orion.lang.utils.collect.Lists;
|
import com.orion.lang.utils.collect.Lists;
|
||||||
import com.orion.ops.framework.common.enums.BooleanBit;
|
import com.orion.ops.framework.common.enums.BooleanBit;
|
||||||
import com.orion.ops.module.asset.handler.host.terminal.enums.OutputTypeEnum;
|
import com.orion.ops.module.asset.handler.host.terminal.enums.OutputTypeEnum;
|
||||||
|
|||||||
@@ -0,0 +1,40 @@
|
|||||||
|
package com.orion.ops.module.asset.service;
|
||||||
|
|
||||||
|
import com.orion.ops.module.asset.entity.vo.UploadTaskFileVO;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 服务类
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
public interface UploadTaskFileService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询上传任务文件
|
||||||
|
*
|
||||||
|
* @param taskId taskId
|
||||||
|
* @return row
|
||||||
|
*/
|
||||||
|
List<UploadTaskFileVO> getFileByTaskId(Long taskId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 通过 taskId 删除
|
||||||
|
*
|
||||||
|
* @param taskId taskId
|
||||||
|
* @return effect
|
||||||
|
*/
|
||||||
|
Integer deleteFileByTaskId(Long taskId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 通过 taskId 删除
|
||||||
|
*
|
||||||
|
* @param taskIdList taskIdList
|
||||||
|
* @return effect
|
||||||
|
*/
|
||||||
|
Integer deleteFileByTaskIdList(List<Long> taskIdList);
|
||||||
|
|
||||||
|
}
|
||||||
@@ -41,6 +41,22 @@ public interface UploadTaskService {
|
|||||||
*/
|
*/
|
||||||
DataGrid<UploadTaskVO> getUploadTaskPage(UploadTaskQueryRequest request);
|
DataGrid<UploadTaskVO> getUploadTaskPage(UploadTaskQueryRequest request);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取上传任务数量
|
||||||
|
*
|
||||||
|
* @param request request
|
||||||
|
* @return count
|
||||||
|
*/
|
||||||
|
Long getUploadTaskCount(UploadTaskQueryRequest request);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 清理上传任务
|
||||||
|
*
|
||||||
|
* @param request request
|
||||||
|
* @return count
|
||||||
|
*/
|
||||||
|
Integer clearUploadTask(UploadTaskQueryRequest request);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除上传任务
|
* 删除上传任务
|
||||||
*
|
*
|
||||||
@@ -57,4 +73,32 @@ public interface UploadTaskService {
|
|||||||
*/
|
*/
|
||||||
Integer deleteUploadTaskByIdList(List<Long> idList);
|
Integer deleteUploadTaskByIdList(List<Long> idList);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 开始上传
|
||||||
|
*
|
||||||
|
* @param id id
|
||||||
|
*/
|
||||||
|
void startUploadTask(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 取消上传
|
||||||
|
*
|
||||||
|
* @param id id
|
||||||
|
*/
|
||||||
|
void cancelUploadTask(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除上传交换区的文件
|
||||||
|
*
|
||||||
|
* @param id id
|
||||||
|
*/
|
||||||
|
void clearUploadSwapFiles(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除上传交换区的文件
|
||||||
|
*
|
||||||
|
* @param idList idList
|
||||||
|
*/
|
||||||
|
void clearUploadSwapFiles(List<Long> idList);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,59 @@
|
|||||||
|
package com.orion.ops.module.asset.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.orion.ops.module.asset.convert.UploadTaskFileConvert;
|
||||||
|
import com.orion.ops.module.asset.dao.UploadTaskFileDAO;
|
||||||
|
import com.orion.ops.module.asset.entity.domain.UploadTaskFileDO;
|
||||||
|
import com.orion.ops.module.asset.entity.vo.UploadTaskFileVO;
|
||||||
|
import com.orion.ops.module.asset.service.UploadTaskFileService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 上传任务文件 服务实现类
|
||||||
|
*
|
||||||
|
* @author Jiahang Li
|
||||||
|
* @version 1.0.7
|
||||||
|
* @since 2024-5-8 10:31
|
||||||
|
*/
|
||||||
|
@Slf4j
|
||||||
|
@Service
|
||||||
|
public class UploadTaskFileServiceImpl implements UploadTaskFileService {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private UploadTaskFileDAO uploadTaskFileDAO;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<UploadTaskFileVO> getFileByTaskId(Long taskId) {
|
||||||
|
// 查询
|
||||||
|
return uploadTaskFileDAO.of()
|
||||||
|
.createWrapper()
|
||||||
|
.eq(UploadTaskFileDO::getTaskId, taskId)
|
||||||
|
.then()
|
||||||
|
.list(UploadTaskFileConvert.MAPPER::to);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Integer deleteFileByTaskId(Long taskId) {
|
||||||
|
log.info("UploadTaskFileService-deleteFileByTaskId id: {}", taskId);
|
||||||
|
LambdaQueryWrapper<UploadTaskFileDO> wrapper = uploadTaskFileDAO.wrapper()
|
||||||
|
.eq(UploadTaskFileDO::getTaskId, taskId);
|
||||||
|
int effect = uploadTaskFileDAO.delete(wrapper);
|
||||||
|
log.info("UploadTaskFileService-deleteFileByTaskId id: {}, effect: {}", taskId, effect);
|
||||||
|
return effect;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Integer deleteFileByTaskIdList(List<Long> taskIdList) {
|
||||||
|
log.info("UploadTaskFileService-deleteFileByTaskIdList idList: {}", taskIdList);
|
||||||
|
LambdaQueryWrapper<UploadTaskFileDO> wrapper = uploadTaskFileDAO.wrapper()
|
||||||
|
.in(UploadTaskFileDO::getTaskId, taskIdList);
|
||||||
|
int effect = uploadTaskFileDAO.delete(wrapper);
|
||||||
|
log.info("UploadTaskFileService-deleteFileByTaskIdList effect: {}", effect);
|
||||||
|
return effect;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -5,7 +5,10 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|||||||
import com.orion.lang.define.wrapper.DataGrid;
|
import com.orion.lang.define.wrapper.DataGrid;
|
||||||
import com.orion.lang.utils.Arrays1;
|
import com.orion.lang.utils.Arrays1;
|
||||||
import com.orion.lang.utils.Strings;
|
import com.orion.lang.utils.Strings;
|
||||||
|
import com.orion.lang.utils.collect.Lists;
|
||||||
|
import com.orion.lang.utils.io.Files1;
|
||||||
import com.orion.lang.utils.time.Dates;
|
import com.orion.lang.utils.time.Dates;
|
||||||
|
import com.orion.ops.framework.biz.operator.log.core.utils.OperatorLogs;
|
||||||
import com.orion.ops.framework.common.constant.ErrorMessage;
|
import com.orion.ops.framework.common.constant.ErrorMessage;
|
||||||
import com.orion.ops.framework.common.file.FileClient;
|
import com.orion.ops.framework.common.file.FileClient;
|
||||||
import com.orion.ops.framework.common.security.LoginUser;
|
import com.orion.ops.framework.common.security.LoginUser;
|
||||||
@@ -15,22 +18,30 @@ import com.orion.ops.module.asset.convert.HostConvert;
|
|||||||
import com.orion.ops.module.asset.convert.UploadTaskConvert;
|
import com.orion.ops.module.asset.convert.UploadTaskConvert;
|
||||||
import com.orion.ops.module.asset.dao.HostDAO;
|
import com.orion.ops.module.asset.dao.HostDAO;
|
||||||
import com.orion.ops.module.asset.dao.UploadTaskDAO;
|
import com.orion.ops.module.asset.dao.UploadTaskDAO;
|
||||||
|
import com.orion.ops.module.asset.dao.UploadTaskFileDAO;
|
||||||
import com.orion.ops.module.asset.entity.domain.UploadTaskDO;
|
import com.orion.ops.module.asset.entity.domain.UploadTaskDO;
|
||||||
|
import com.orion.ops.module.asset.entity.domain.UploadTaskFileDO;
|
||||||
import com.orion.ops.module.asset.entity.dto.UploadTaskExtraDTO;
|
import com.orion.ops.module.asset.entity.dto.UploadTaskExtraDTO;
|
||||||
import com.orion.ops.module.asset.entity.request.upload.UploadTaskCreateRequest;
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskCreateRequest;
|
||||||
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskFileRequest;
|
||||||
import com.orion.ops.module.asset.entity.request.upload.UploadTaskQueryRequest;
|
import com.orion.ops.module.asset.entity.request.upload.UploadTaskQueryRequest;
|
||||||
import com.orion.ops.module.asset.entity.vo.HostBaseVO;
|
import com.orion.ops.module.asset.entity.vo.HostBaseVO;
|
||||||
import com.orion.ops.module.asset.entity.vo.UploadTaskCreateVO;
|
import com.orion.ops.module.asset.entity.vo.UploadTaskCreateVO;
|
||||||
|
import com.orion.ops.module.asset.entity.vo.UploadTaskFileVO;
|
||||||
import com.orion.ops.module.asset.entity.vo.UploadTaskVO;
|
import com.orion.ops.module.asset.entity.vo.UploadTaskVO;
|
||||||
import com.orion.ops.module.asset.enums.HostConfigTypeEnum;
|
import com.orion.ops.module.asset.enums.HostConfigTypeEnum;
|
||||||
|
import com.orion.ops.module.asset.enums.UploadTaskFileStatusEnum;
|
||||||
import com.orion.ops.module.asset.enums.UploadTaskStatusEnum;
|
import com.orion.ops.module.asset.enums.UploadTaskStatusEnum;
|
||||||
import com.orion.ops.module.asset.service.AssetAuthorizedDataService;
|
import com.orion.ops.module.asset.service.AssetAuthorizedDataService;
|
||||||
|
import com.orion.ops.module.asset.service.UploadTaskFileService;
|
||||||
import com.orion.ops.module.asset.service.UploadTaskService;
|
import com.orion.ops.module.asset.service.UploadTaskService;
|
||||||
import com.orion.ops.module.infra.api.FileUploadApi;
|
import com.orion.ops.module.infra.api.FileUploadApi;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
@@ -55,6 +66,12 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
@Resource
|
@Resource
|
||||||
private HostDAO hostDAO;
|
private HostDAO hostDAO;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private UploadTaskFileDAO uploadTaskFileDAO;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private UploadTaskFileService uploadTaskFileService;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private AssetAuthorizedDataService assetAuthorizedDataService;
|
private AssetAuthorizedDataService assetAuthorizedDataService;
|
||||||
|
|
||||||
@@ -64,10 +81,12 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
@Resource
|
@Resource
|
||||||
private FileUploadApi fileUploadApi;
|
private FileUploadApi fileUploadApi;
|
||||||
|
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
@Override
|
@Override
|
||||||
public UploadTaskCreateVO createUploadTask(UploadTaskCreateRequest request) {
|
public UploadTaskCreateVO createUploadTask(UploadTaskCreateRequest request) {
|
||||||
LoginUser user = Valid.notNull(SecurityUtils.getLoginUser());
|
LoginUser user = Valid.notNull(SecurityUtils.getLoginUser());
|
||||||
List<Long> hostIdList = request.getHostIdList();
|
List<Long> hostIdList = request.getHostIdList();
|
||||||
|
List<UploadTaskFileRequest> files = request.getFiles();
|
||||||
log.info("UploadTaskService-createUploadTask request: {}", JSON.toJSONString(request));
|
log.info("UploadTaskService-createUploadTask request: {}", JSON.toJSONString(request));
|
||||||
// 检查主机是否有权限
|
// 检查主机是否有权限
|
||||||
this.checkHostPermission(hostIdList);
|
this.checkHostPermission(hostIdList);
|
||||||
@@ -87,12 +106,30 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
.hosts(hosts)
|
.hosts(hosts)
|
||||||
.build();
|
.build();
|
||||||
record.setExtraInfo(JSON.toJSONString(extra));
|
record.setExtraInfo(JSON.toJSONString(extra));
|
||||||
// 插入
|
// 插入任务表
|
||||||
int effect = uploadTaskDAO.insert(record);
|
int effect = uploadTaskDAO.insert(record);
|
||||||
Long id = record.getId();
|
Long id = record.getId();
|
||||||
|
// 插入任务文件表
|
||||||
|
List<UploadTaskFileDO> uploadFiles = new ArrayList<>();
|
||||||
|
for (Long hostId : hostIdList) {
|
||||||
|
files.stream()
|
||||||
|
.map(s -> UploadTaskFileDO.builder()
|
||||||
|
.taskId(id)
|
||||||
|
.hostId(hostId)
|
||||||
|
.fileId(s.getFileId())
|
||||||
|
.filePath(s.getFilePath())
|
||||||
|
.fileSize(s.getFileSize())
|
||||||
|
.status(UploadTaskFileStatusEnum.WAITING.name())
|
||||||
|
.build())
|
||||||
|
.forEach(uploadFiles::add);
|
||||||
|
}
|
||||||
|
uploadTaskFileDAO.insertBatch(uploadFiles);
|
||||||
// 设置 uploadToken
|
// 设置 uploadToken
|
||||||
String token = fileUploadApi.createUploadToken(user.getId(), Strings.format(SWAP_ENDPOINT, id));
|
String token = fileUploadApi.createUploadToken(user.getId(), Strings.format(SWAP_ENDPOINT, id));
|
||||||
log.info("UploadTaskService-createUploadTask id: {}, effect: {}", id, effect);
|
log.info("UploadTaskService-createUploadTask id: {}, effect: {}", id, effect);
|
||||||
|
// 添加日志参数
|
||||||
|
OperatorLogs.add(OperatorLogs.NAME, record.getDescription());
|
||||||
|
OperatorLogs.add(OperatorLogs.COUNT, files.size());
|
||||||
return UploadTaskCreateVO.builder()
|
return UploadTaskCreateVO.builder()
|
||||||
.id(id)
|
.id(id)
|
||||||
.token(token)
|
.token(token)
|
||||||
@@ -101,11 +138,15 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UploadTaskVO getUploadTaskById(Long id) {
|
public UploadTaskVO getUploadTaskById(Long id) {
|
||||||
// 查询
|
// 查询任务
|
||||||
UploadTaskDO record = uploadTaskDAO.selectById(id);
|
UploadTaskDO record = uploadTaskDAO.selectById(id);
|
||||||
Valid.notNull(record, ErrorMessage.DATA_ABSENT);
|
Valid.notNull(record, ErrorMessage.DATA_ABSENT);
|
||||||
// 转换
|
// 查询任务文件 TODO PROGRESS
|
||||||
return UploadTaskConvert.MAPPER.to(record);
|
List<UploadTaskFileVO> files = uploadTaskFileService.getFileByTaskId(id);
|
||||||
|
// 返回
|
||||||
|
UploadTaskVO task = UploadTaskConvert.MAPPER.to(record);
|
||||||
|
task.setFiles(files);
|
||||||
|
return task;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -119,23 +160,70 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Integer deleteUploadTaskById(Long id) {
|
public Long getUploadTaskCount(UploadTaskQueryRequest request) {
|
||||||
log.info("UploadTaskService-deleteUploadTaskById id: {}", id);
|
return uploadTaskDAO.selectCount(this.buildQueryWrapper(request));
|
||||||
// 检查数据是否存在
|
}
|
||||||
UploadTaskDO record = uploadTaskDAO.selectById(id);
|
|
||||||
Valid.notNull(record, ErrorMessage.DATA_ABSENT);
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@Override
|
||||||
|
public Integer clearUploadTask(UploadTaskQueryRequest request) {
|
||||||
|
// 查询id
|
||||||
|
LambdaQueryWrapper<UploadTaskDO> wrapper = this.buildQueryWrapper(request)
|
||||||
|
.select(UploadTaskDO::getId);
|
||||||
|
List<Long> idList = uploadTaskDAO.of(wrapper)
|
||||||
|
.list(UploadTaskDO::getId);
|
||||||
// 删除
|
// 删除
|
||||||
int effect = uploadTaskDAO.deleteById(id);
|
return this.deleteUploadTaskByIdList(idList);
|
||||||
log.info("UploadTaskService-deleteUploadTaskById id: {}, effect: {}", id, effect);
|
}
|
||||||
|
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@Override
|
||||||
|
public Integer deleteUploadTaskById(Long id) {
|
||||||
|
return this.deleteUploadTaskByIdList(Lists.singleton(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@Override
|
||||||
|
public Integer deleteUploadTaskByIdList(List<Long> idList) {
|
||||||
|
// TODO 暂停 / 删除交换区文件
|
||||||
|
log.info("UploadTaskService-deleteUploadTaskByIdList idList: {}", idList);
|
||||||
|
// 删除任务
|
||||||
|
int effect = uploadTaskDAO.deleteBatchIds(idList);
|
||||||
|
// 删除任务文件
|
||||||
|
uploadTaskFileService.deleteFileByTaskIdList(idList);
|
||||||
|
// 添加日志参数
|
||||||
|
OperatorLogs.add(OperatorLogs.COUNT, effect);
|
||||||
|
log.info("UploadTaskService-deleteUploadTaskByIdList effect: {}", effect);
|
||||||
return effect;
|
return effect;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Integer deleteUploadTaskByIdList(List<Long> idList) {
|
public void startUploadTask(Long id) {
|
||||||
log.info("UploadTaskService-deleteUploadTaskByIdList idList: {}", idList);
|
|
||||||
int effect = uploadTaskDAO.deleteBatchIds(idList);
|
}
|
||||||
log.info("UploadTaskService-deleteUploadTaskByIdList effect: {}", effect);
|
|
||||||
return effect;
|
@Override
|
||||||
|
public void cancelUploadTask(Long id) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clearUploadSwapFiles(Long id) {
|
||||||
|
this.clearUploadSwapFiles(Lists.singleton(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clearUploadSwapFiles(List<Long> idList) {
|
||||||
|
// 查询记录
|
||||||
|
List<String> paths = idList.stream()
|
||||||
|
.map(s -> Strings.format(SWAP_ENDPOINT, s))
|
||||||
|
.map(localFileClient::getReturnPath)
|
||||||
|
.map(localFileClient::getAbsolutePath)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
// TODO test
|
||||||
|
paths.forEach(System.out::println);
|
||||||
|
// 删除文件
|
||||||
|
paths.forEach(Files1::delete);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -148,7 +236,8 @@ public class UploadTaskServiceImpl implements UploadTaskService {
|
|||||||
return uploadTaskDAO.wrapper()
|
return uploadTaskDAO.wrapper()
|
||||||
.eq(UploadTaskDO::getId, request.getId())
|
.eq(UploadTaskDO::getId, request.getId())
|
||||||
.eq(UploadTaskDO::getUserId, request.getUserId())
|
.eq(UploadTaskDO::getUserId, request.getUserId())
|
||||||
.eq(UploadTaskDO::getDescription, request.getDescription())
|
.in(UploadTaskDO::getDescription, request.getDescription())
|
||||||
|
.eq(UploadTaskDO::getRemotePath, request.getRemotePath())
|
||||||
.eq(UploadTaskDO::getStatus, request.getStatus())
|
.eq(UploadTaskDO::getStatus, request.getStatus())
|
||||||
.ge(UploadTaskDO::getStartTime, Arrays1.getIfPresent(request.getStartTimeRange(), 0))
|
.ge(UploadTaskDO::getStartTime, Arrays1.getIfPresent(request.getStartTimeRange(), 0))
|
||||||
.le(UploadTaskDO::getStartTime, Arrays1.getIfPresent(request.getStartTimeRange(), 1))
|
.le(UploadTaskDO::getStartTime, Arrays1.getIfPresent(request.getStartTimeRange(), 1))
|
||||||
|
|||||||
@@ -0,0 +1,28 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.orion.ops.module.asset.dao.UploadTaskFileDAO">
|
||||||
|
|
||||||
|
<!-- 通用查询映射结果 -->
|
||||||
|
<resultMap id="BaseResultMap" type="com.orion.ops.module.asset.entity.domain.UploadTaskFileDO">
|
||||||
|
<id column="id" property="id"/>
|
||||||
|
<result column="task_id" property="taskId"/>
|
||||||
|
<result column="host_id" property="hostId"/>
|
||||||
|
<result column="file_id" property="fileId"/>
|
||||||
|
<result column="file_path" property="filePath"/>
|
||||||
|
<result column="file_size" property="fileSize"/>
|
||||||
|
<result column="status" property="status"/>
|
||||||
|
<result column="start_time" property="startTime"/>
|
||||||
|
<result column="end_time" property="endTime"/>
|
||||||
|
<result column="create_time" property="createTime"/>
|
||||||
|
<result column="update_time" property="updateTime"/>
|
||||||
|
<result column="creator" property="creator"/>
|
||||||
|
<result column="updater" property="updater"/>
|
||||||
|
<result column="deleted" property="deleted"/>
|
||||||
|
</resultMap>
|
||||||
|
|
||||||
|
<!-- 通用查询结果列 -->
|
||||||
|
<sql id="Base_Column_List">
|
||||||
|
id, task_id, host_id, file_id, file_path, file_size, status, start_time, end_time, create_time, update_time, creator, updater, deleted
|
||||||
|
</sql>
|
||||||
|
|
||||||
|
</mapper>
|
||||||
Reference in New Issue
Block a user