영상관리 싱크하기 수정

This commit is contained in:
Harry M. You
2025-12-04 15:59:41 +09:00
parent bce49b7a0b
commit c891aa514a
6 changed files with 193 additions and 1 deletions

View File

@@ -8,6 +8,7 @@ import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.FoldersDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFilesDepthDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFilesDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFoldersDto;
import com.kamco.cd.kamcoback.mapsheet.dto.ImageryDto;
import com.kamco.cd.kamcoback.mapsheet.dto.MapSheetMngDto;
import com.kamco.cd.kamcoback.mapsheet.service.MapSheetMngService;
import io.swagger.v3.oas.annotations.Operation;
@@ -100,7 +101,7 @@ public class MapSheetMngApiController {
return ApiResponseDto.ok(mapSheetMngService.findMapSheetErrorList(searchReq));
}
@Operation(summary = "영상관리목록 조회", description = "영상관리목록 조회")
@Operation(summary = "영상데이터관리목록 조회", description = "영상데이터관리목록 조회")
@ApiResponses(
value = {
@ApiResponse(
@@ -119,6 +120,27 @@ public class MapSheetMngApiController {
return ApiResponseDto.ok(mapSheetMngService.findMapSheetMngList(searchReq));
}
@Operation(summary = "영상데이터관리 > 영상파일 동기화", description = "영상파일 동기화")
@ApiResponses(
value = {
@ApiResponse(
responseCode = "200",
description = "동기화 성공",
content =
@Content(
mediaType = "application/json",
schema = @Schema(implementation = CommonCodeDto.Basic.class))),
@ApiResponse(responseCode = "404", description = "동기화 할수 없음", content = @Content),
@ApiResponse(responseCode = "500", description = "서버 오류", content = @Content)
})
@PostMapping("/sync-process")
public ApiResponseDto<MapSheetMngDto.DmlReturn> uploadProcess(
@RequestBody @Valid ImageryDto.searchReq searchReq) {
return ApiResponseDto.ok(mapSheetMngService.syncProcess(searchReq));
}
/**
* @param hstUidList
* @return

View File

@@ -0,0 +1,87 @@
package com.kamco.cd.kamcoback.mapsheet.dto;
import com.kamco.cd.kamcoback.config.enums.EnumType;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.persistence.Column;
import jakarta.validation.constraints.NotNull;
import java.time.ZonedDateTime;
import java.util.UUID;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import org.hibernate.annotations.ColumnDefault;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
public class ImageryDto {
@Schema(name = "searchReq", description = "영상관리 Sync대상 검색 요청")
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public static class searchReq {
// 페이징 파라미터
@Schema(description = "페이지 번호 (0부터 시작) ", example = "0")
@NotNull
private int page = 0;
@Schema(description = "페이지 크기", example = "20000")
@NotNull
private int size = 20000;
@Schema(description = "정렬", example = "id desc")
private String sort;
@Schema(description = "검색어(36809 또는 36809010)", example = "36809010")
private String searchValue;
@Schema(description = "년도", example = "2025")
@NotNull
private Integer mngYyyy;
public Pageable toPageable() {return PageRequest.of(page, size);}
}
@Schema(name = "ImageryDto", description = "영상관리파일 검색 리턴")
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public static class BasicDto {
private Long id;
private UUID uuid;
private Integer year;
private String scene50k;
private String scene5k;
private Integer sceneId50k;
private Integer sceneId5k;
private ZonedDateTime createdDate;
private String middlePath;
private String cogMiddlePath;
private String filename;
private String cogFilename;
}
@Schema(name = "ImagerySyncDto", description = "영상싱크파일 검색 리턴")
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public static class SyncDto {
private Long id;
private Integer year;
private String scene50k;
private String scene5k;
private String middlePath;
private String cogMiddlePath;
private String filename;
private String cogFilename;
}
}

View File

@@ -10,6 +10,7 @@ import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.FoldersDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFilesDepthDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFilesDto;
import com.kamco.cd.kamcoback.mapsheet.dto.FileDto.SrchFoldersDto;
import com.kamco.cd.kamcoback.mapsheet.dto.ImageryDto;
import com.kamco.cd.kamcoback.mapsheet.dto.MapSheetMngDto;
import com.kamco.cd.kamcoback.postgres.core.MapSheetMngCoreService;
import jakarta.validation.Valid;
@@ -322,4 +323,9 @@ public class MapSheetMngService {
public MapSheetMngDto.DmlReturn updateExceptUseInference(@Valid List<Long> hstUidList) {
return mapSheetMngCoreService.updateExceptUseInference(hstUidList);
}
public MapSheetMngDto.DmlReturn syncProcess(ImageryDto.searchReq searchReq) {
return mapSheetMngCoreService.syncProcess(searchReq);
}
}