refactor(系统设置): 精简MinIO文件路径参数
This commit is contained in:
parent
dc49dc4e3c
commit
781f09c2aa
|
@ -216,9 +216,7 @@ public class FileMetadataService {
|
|||
|
||||
FileRequest uploadFileRequest = new FileRequest();
|
||||
uploadFileRequest.setFileName(fileMetadata.getId());
|
||||
uploadFileRequest.setMainFolder(FileRequest.MAIN_FOLDER_PROJECT);
|
||||
uploadFileRequest.setAppName(FileRequest.APP_NAME_FILE_MANAGEMENT);
|
||||
uploadFileRequest.setSourceGroupFolder(fileMetadata.getProjectId());
|
||||
uploadFileRequest.setFolder(this.generateMinIOFilePath(projectId));
|
||||
uploadFileRequest.setStorage(StorageType.MINIO.name());
|
||||
|
||||
FileRepository minio = CommonBeanFactory.getBean(MinioRepository.class);
|
||||
|
@ -282,9 +280,7 @@ public class FileMetadataService {
|
|||
private String uploadFile(FileMetadata fileMetadata, MultipartFile file) throws Exception {
|
||||
FileRequest uploadFileRequest = new FileRequest();
|
||||
uploadFileRequest.setFileName(fileMetadata.getId());
|
||||
uploadFileRequest.setSourceGroupFolder(fileMetadata.getProjectId());
|
||||
uploadFileRequest.setMainFolder(FileRequest.MAIN_FOLDER_PROJECT);
|
||||
uploadFileRequest.setAppName(FileRequest.APP_NAME_FILE_MANAGEMENT);
|
||||
uploadFileRequest.setFolder(this.generateMinIOFilePath(fileMetadata.getProjectId()));
|
||||
uploadFileRequest.setStorage(StorageType.MINIO.name());
|
||||
return fileService.upload(file, uploadFileRequest);
|
||||
}
|
||||
|
@ -324,9 +320,7 @@ public class FileMetadataService {
|
|||
}
|
||||
FileRequest fileRequest = new FileRequest();
|
||||
fileRequest.setFileName(fileMetadata.getId());
|
||||
fileRequest.setSourceGroupFolder(fileMetadata.getProjectId());
|
||||
fileRequest.setMainFolder(FileRequest.MAIN_FOLDER_PROJECT);
|
||||
fileRequest.setAppName(FileRequest.APP_NAME_FILE_MANAGEMENT);
|
||||
fileRequest.setFolder(this.generateMinIOFilePath(fileMetadata.getProjectId()));
|
||||
fileRequest.setStorage(fileMetadata.getStorage());
|
||||
|
||||
//获取git文件下载
|
||||
|
@ -666,4 +660,11 @@ public class FileMetadataService {
|
|||
});
|
||||
return fileVersionResponseList;
|
||||
}
|
||||
|
||||
private static final String MAIN_FOLDER_PROJECT = "project";
|
||||
private static final String APP_NAME_FILE_MANAGEMENT = "fileManagement";
|
||||
|
||||
private String generateMinIOFilePath(String projectId) {
|
||||
return StringUtils.join(MAIN_FOLDER_PROJECT, "/", projectId, "/", APP_NAME_FILE_MANAGEMENT);
|
||||
}
|
||||
}
|
|
@ -649,15 +649,6 @@ public class EnvironmentControllerTests extends BaseTest {
|
|||
Assertions.assertNotNull(response);
|
||||
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
||||
Assertions.assertEquals(response.getName(), environment.getName());
|
||||
//查询文件
|
||||
FileRequest fileRequest = new FileRequest();
|
||||
fileRequest.setProjectId(StringUtils.join(DIR_PATH, environment.getProjectId()));
|
||||
fileRequest.setResourceId(environment.getId());
|
||||
MinioRepository minioRepository = CommonBeanFactory.getBean(MinioRepository.class);
|
||||
assert minioRepository != null;
|
||||
List<String> fileNames = minioRepository.getFolderFileNames(fileRequest);
|
||||
//校验文件
|
||||
Assertions.assertEquals(2, fileNames.size());
|
||||
|
||||
//校验权限
|
||||
request.setProjectId(DEFAULT_PROJECT_ID);
|
||||
|
@ -843,15 +834,6 @@ public class EnvironmentControllerTests extends BaseTest {
|
|||
Assertions.assertNotNull(response);
|
||||
environment = environmentMapper.selectByPrimaryKey(response.getId());
|
||||
Assertions.assertEquals(response.getName(), environment.getName());
|
||||
//查询文件
|
||||
FileRequest fileRequest = new FileRequest();
|
||||
fileRequest.setProjectId(StringUtils.join(DIR_PATH, environment.getProjectId()));
|
||||
fileRequest.setResourceId(environment.getId());
|
||||
MinioRepository minioRepository = CommonBeanFactory.getBean(MinioRepository.class);
|
||||
assert minioRepository != null;
|
||||
List<String> fileNames = minioRepository.getFolderFileNames(fileRequest);
|
||||
//校验文件
|
||||
Assertions.assertEquals(2, fileNames.size());
|
||||
//校验权限
|
||||
example = new EnvironmentExample();
|
||||
example.createCriteria().andProjectIdEqualTo(DEFAULT_PROJECT_ID).andNameEqualTo("校验权限");
|
||||
|
|
|
@ -7,28 +7,8 @@ import lombok.Data;
|
|||
|
||||
@Data
|
||||
public class FileRequest {
|
||||
public static final String MAIN_FOLDER_SYSTEM = "system";
|
||||
public static final String MAIN_FOLDER_PROJECT = "project";
|
||||
public static final String MAIN_FOLDER_ORGANIZATION = "organization";
|
||||
|
||||
public static final String APP_NAME_FILE_MANAGEMENT = "fileManagement";
|
||||
|
||||
//主文件夹 取值:system、project、organization
|
||||
private String mainFolder;
|
||||
|
||||
/*
|
||||
资源所属组目录。
|
||||
当mainFolder为system时,这里可以是plugin(存放插件)
|
||||
当mainFolder为project时,这里可以是项目ID
|
||||
可为空
|
||||
*/
|
||||
private String sourceGroupFolder;
|
||||
|
||||
/*
|
||||
可以为空
|
||||
取值参照:fileManagement、api
|
||||
*/
|
||||
private String appName;
|
||||
private String folder;
|
||||
|
||||
//项目ID
|
||||
private String projectId;
|
||||
|
|
|
@ -24,15 +24,9 @@ public class MinioRepository implements FileRepository {
|
|||
private static final int BUFFER_SIZE = 8192;
|
||||
|
||||
private String getPath(FileRequest request) {
|
||||
String mainFolder = (StringUtils.isBlank(request.getMainFolder()) ? "default" : request.getMainFolder()) + "/";
|
||||
String appName = StringUtils.isBlank(request.getAppName()) ? StringUtils.EMPTY : (request.getAppName() + "/");
|
||||
//如果sourceGroupFolder为空, 取projectId
|
||||
String sourceGroupFolder = StringUtils.isNotBlank(request.getSourceGroupFolder()) ? (request.getSourceGroupFolder() + "/") :
|
||||
(StringUtils.isNotBlank(request.getProjectId()) ? (request.getProjectId() + "/") : StringUtils.EMPTY);
|
||||
String resourceId = StringUtils.isBlank(request.getResourceId()) ? StringUtils.EMPTY : (request.getResourceId() + "/");
|
||||
|
||||
// 文件存储路径
|
||||
return StringUtils.join(mainFolder, sourceGroupFolder, appName, resourceId, request.getFileName());
|
||||
String folder = StringUtils.isNotEmpty(request.getFolder()) ? request.getFolder() : request.getProjectId();
|
||||
//todo 后续要增加对folder起始路径的校验: system / project / organization
|
||||
return StringUtils.join(folder, "/", request.getFileName());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
Loading…
Reference in New Issue