영상관리 수정
This commit is contained in:
@@ -2,7 +2,6 @@ package com.kamco.cd.kamcoback.common.utils;
|
|||||||
|
|
||||||
import static java.lang.String.CASE_INSENSITIVE_ORDER;
|
import static java.lang.String.CASE_INSENSITIVE_ORDER;
|
||||||
|
|
||||||
import com.kamco.cd.kamcoback.mapsheet.dto.MapSheetMngDto.DmlReturn;
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
@@ -457,15 +456,13 @@ public class FIleChecker {
|
|||||||
return FIleChecker.getFilesFromAllDepth(dir, targetFileNm, extension, 100, "name", 0, 100);
|
return FIleChecker.getFilesFromAllDepth(dir, targetFileNm, extension, 100, "name", 0, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int getFileCountFromAllDepth(
|
public static int getFileCountFromAllDepth(String dir, String targetFileNm, String extension) {
|
||||||
String dir, String targetFileNm, String extension) {
|
|
||||||
|
|
||||||
List<FIleChecker.Basic> basicList =
|
List<FIleChecker.Basic> basicList =
|
||||||
FIleChecker.getFilesFromAllDepth(dir, targetFileNm, extension);
|
FIleChecker.getFilesFromAllDepth(dir, targetFileNm, extension);
|
||||||
|
|
||||||
return (int) basicList.stream()
|
return (int)
|
||||||
.filter(dto -> dto.getExtension().toString().equals(extension))
|
basicList.stream().filter(dto -> dto.getExtension().toString().equals(extension)).count();
|
||||||
.count();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Long getFileTotSize(List<FIleChecker.Basic> files) {
|
public static Long getFileTotSize(List<FIleChecker.Basic> files) {
|
||||||
@@ -478,8 +475,7 @@ public class FIleChecker {
|
|||||||
return fileTotSize;
|
return fileTotSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean validationMultipart(MultipartFile mfile)
|
public static boolean validationMultipart(MultipartFile mfile) {
|
||||||
{
|
|
||||||
// 파일 유효성 검증
|
// 파일 유효성 검증
|
||||||
if (mfile == null || mfile.isEmpty() || mfile.getSize() == 0) {
|
if (mfile == null || mfile.isEmpty() || mfile.getSize() == 0) {
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -178,9 +178,8 @@ public class MapSheetMngApiController {
|
|||||||
@RequestParam(value = "hstUid", required = false) Long hstUid,
|
@RequestParam(value = "hstUid", required = false) Long hstUid,
|
||||||
@RequestParam(value = "overwrite", required = false) boolean overwrite) {
|
@RequestParam(value = "overwrite", required = false) boolean overwrite) {
|
||||||
|
|
||||||
|
return ApiResponseDto.createOK(
|
||||||
|
mapSheetMngService.uploadPair(tfwFile, tifFile, hstUid, overwrite));
|
||||||
return ApiResponseDto.createOK(mapSheetMngService.uploadPair(tfwFile, tifFile, hstUid, overwrite));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "영상관리 > 파일조회", description = "영상관리 > 파일조회")
|
@Operation(summary = "영상관리 > 파일조회", description = "영상관리 > 파일조회")
|
||||||
|
|||||||
@@ -92,26 +92,27 @@ public class MapSheetMngDto {
|
|||||||
|
|
||||||
public String getMngState() {
|
public String getMngState() {
|
||||||
|
|
||||||
if (this.syncStateDoneCnt == 0)return "NOTYET";
|
if (this.syncStateDoneCnt == 0) return "NOTYET";
|
||||||
else if (this.syncStateDoneCnt < this.syncTotCnt)return "PROCESSING";
|
else if (this.syncStateDoneCnt < this.syncTotCnt) return "PROCESSING";
|
||||||
|
|
||||||
if( (this.syncNotPaireExecCnt + this.syncDuplicateExecCnt + this.syncFaultExecCnt) > 0 )return "TAKINGERROR";
|
if ((this.syncNotPaireExecCnt + this.syncDuplicateExecCnt + this.syncFaultExecCnt) > 0)
|
||||||
|
return "TAKINGERROR";
|
||||||
|
|
||||||
return "DONE";
|
return "DONE";
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSyncState() {
|
public String getSyncState() {
|
||||||
|
|
||||||
if (this.syncStateDoneCnt == 0)return "NOTYET";
|
if (this.syncStateDoneCnt == 0) return "NOTYET";
|
||||||
else if (this.syncStateDoneCnt < this.syncTotCnt)return "PROCESSING";
|
else if (this.syncStateDoneCnt < this.syncTotCnt) return "PROCESSING";
|
||||||
|
|
||||||
return "DONE";
|
return "DONE";
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getDataCheckState() {
|
public String getDataCheckState() {
|
||||||
|
|
||||||
if (this.syncDataCheckDoneCnt == 0)return "NOTYET";
|
if (this.syncDataCheckDoneCnt == 0) return "NOTYET";
|
||||||
else if (this.syncDataCheckDoneCnt < this.syncTotCnt)return "PROCESSING";
|
else if (this.syncDataCheckDoneCnt < this.syncTotCnt) return "PROCESSING";
|
||||||
|
|
||||||
return "DONE";
|
return "DONE";
|
||||||
}
|
}
|
||||||
@@ -138,8 +139,6 @@ public class MapSheetMngDto {
|
|||||||
return this.syncNotPaireExecCnt + this.syncDuplicateExecCnt + this.syncFaultExecCnt;
|
return this.syncNotPaireExecCnt + this.syncDuplicateExecCnt + this.syncFaultExecCnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public String getMngStateName() {
|
public String getMngStateName() {
|
||||||
String enumId = this.mngState;
|
String enumId = this.mngState;
|
||||||
if (enumId == null || enumId.isEmpty()) {
|
if (enumId == null || enumId.isEmpty()) {
|
||||||
@@ -254,8 +253,6 @@ public class MapSheetMngDto {
|
|||||||
this.errorCheckTifFileName = errorCheckTifFileName;
|
this.errorCheckTifFileName = errorCheckTifFileName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private String getSyncStateName(String enumId) {
|
private String getSyncStateName(String enumId) {
|
||||||
if (enumId == null || enumId.isEmpty()) {
|
if (enumId == null || enumId.isEmpty()) {
|
||||||
enumId = "NOTYET";
|
enumId = "NOTYET";
|
||||||
|
|||||||
@@ -33,7 +33,6 @@ public class MapSheetMngService {
|
|||||||
private final MapSheetMngCoreService mapSheetMngCoreService;
|
private final MapSheetMngCoreService mapSheetMngCoreService;
|
||||||
private final FileConfig fileConfig;
|
private final FileConfig fileConfig;
|
||||||
|
|
||||||
|
|
||||||
@Value("${file.sync-root-dir}")
|
@Value("${file.sync-root-dir}")
|
||||||
private String syncRootDir;
|
private String syncRootDir;
|
||||||
|
|
||||||
@@ -85,7 +84,8 @@ public class MapSheetMngService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Transactional
|
@Transactional
|
||||||
public DmlReturn uploadPair(MultipartFile tfwFile, MultipartFile tifFile, Long hstUid, Boolean overwrite) {
|
public DmlReturn uploadPair(
|
||||||
|
MultipartFile tfwFile, MultipartFile tifFile, Long hstUid, Boolean overwrite) {
|
||||||
|
|
||||||
String rootPath = syncRootDir;
|
String rootPath = syncRootDir;
|
||||||
String tmpPath = syncTmpDir;
|
String tmpPath = syncTmpDir;
|
||||||
@@ -103,29 +103,27 @@ public class MapSheetMngService {
|
|||||||
return new DmlReturn("fail", "CREATE TEMP FOLDER ERROR");
|
return new DmlReturn("fail", "CREATE TEMP FOLDER ERROR");
|
||||||
}
|
}
|
||||||
|
|
||||||
//업로드 파일 사이즈,확장자명 체크
|
// 업로드 파일 사이즈,확장자명 체크
|
||||||
dmlReturn = this.validationFile(tfwFile, tifFile);
|
dmlReturn = this.validationFile(tfwFile, tifFile);
|
||||||
if( dmlReturn.getFlag().equals("fail") )return dmlReturn;
|
if (dmlReturn.getFlag().equals("fail")) return dmlReturn;
|
||||||
|
|
||||||
|
|
||||||
MngDto mngDto = mapSheetMngCoreService.findMapSheetMng(errDto.getMngYyyy());
|
MngDto mngDto = mapSheetMngCoreService.findMapSheetMng(errDto.getMngYyyy());
|
||||||
String targetYearDir = mngDto.getMngPath();
|
String targetYearDir = mngDto.getMngPath();
|
||||||
|
|
||||||
// 중복체크
|
// 중복체크
|
||||||
if( !overwrite ) {
|
if (!overwrite) {
|
||||||
|
|
||||||
int tfwCnt = FIleChecker.getFileCountFromAllDepth(targetYearDir, tfwFile.getOriginalFilename(), "tfw");
|
int tfwCnt =
|
||||||
int tifCnt = FIleChecker.getFileCountFromAllDepth(targetYearDir, tfwFile.getOriginalFilename(), "tfw");
|
FIleChecker.getFileCountFromAllDepth(targetYearDir, tfwFile.getOriginalFilename(), "tfw");
|
||||||
|
int tifCnt =
|
||||||
|
FIleChecker.getFileCountFromAllDepth(targetYearDir, tfwFile.getOriginalFilename(), "tfw");
|
||||||
|
|
||||||
if (tfwCnt > 0 || tifCnt > 0) {
|
if (tfwCnt > 0 || tifCnt > 0) {
|
||||||
String tfwtifMsg = "";
|
String tfwtifMsg = "";
|
||||||
if (tfwCnt > 0)
|
if (tfwCnt > 0) tfwtifMsg = tfwFile.getOriginalFilename();
|
||||||
tfwtifMsg = tfwFile.getOriginalFilename();
|
|
||||||
if (tifCnt > 0) {
|
if (tifCnt > 0) {
|
||||||
if (tfwCnt > 0)
|
if (tfwCnt > 0) tfwtifMsg = "," + tifFile.getOriginalFilename();
|
||||||
tfwtifMsg = "," + tifFile.getOriginalFilename();
|
else tfwtifMsg = tifFile.getOriginalFilename();
|
||||||
else
|
|
||||||
tfwtifMsg = tifFile.getOriginalFilename();
|
|
||||||
}
|
}
|
||||||
return new DmlReturn("duplicate", tfwtifMsg);
|
return new DmlReturn("duplicate", tfwtifMsg);
|
||||||
}
|
}
|
||||||
@@ -214,12 +212,13 @@ public class MapSheetMngService {
|
|||||||
return new DmlReturn("success", "파일 업로드 완료되었습니다.");
|
return new DmlReturn("success", "파일 업로드 완료되었습니다.");
|
||||||
}
|
}
|
||||||
|
|
||||||
public DmlReturn validationFile(MultipartFile tfwFile, MultipartFile tifFile)
|
public DmlReturn validationFile(MultipartFile tfwFile, MultipartFile tifFile) {
|
||||||
{
|
if (!FIleChecker.validationMultipart(tfwFile)) return new DmlReturn("fail", "TFW SIZE 오류");
|
||||||
if( !FIleChecker.validationMultipart(tfwFile) )return new DmlReturn("fail", "TFW SIZE 오류");
|
else if (!FIleChecker.validationMultipart(tifFile)) return new DmlReturn("fail", "TFW SIZE 오류");
|
||||||
else if( !FIleChecker.validationMultipart(tifFile) )return new DmlReturn("fail", "TFW SIZE 오류");
|
else if (!FIleChecker.checkExtensions(tfwFile.getOriginalFilename(), "tfw"))
|
||||||
else if (!FIleChecker.checkExtensions(tfwFile.getOriginalFilename(), "tfw"))return new DmlReturn("fail", "TFW FILENAME ERROR");
|
return new DmlReturn("fail", "TFW FILENAME ERROR");
|
||||||
else if (!FIleChecker.checkExtensions(tifFile.getOriginalFilename(), "tif"))return new DmlReturn("fail", "TIF FILENAME ERROR");
|
else if (!FIleChecker.checkExtensions(tifFile.getOriginalFilename(), "tif"))
|
||||||
|
return new DmlReturn("fail", "TIF FILENAME ERROR");
|
||||||
|
|
||||||
return new DmlReturn("success", "파일체크");
|
return new DmlReturn("success", "파일체크");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -79,7 +79,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
mapSheetMngEntity.mngState,
|
mapSheetMngEntity.mngState,
|
||||||
mapSheetMngEntity.syncState,
|
mapSheetMngEntity.syncState,
|
||||||
mapSheetMngEntity.syncCheckState,
|
mapSheetMngEntity.syncCheckState,
|
||||||
|
|
||||||
mapSheetMngHstEntity.count().as("syncTotalCnt"),
|
mapSheetMngHstEntity.count().as("syncTotalCnt"),
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.dataState.eq("DONE"))
|
.when(mapSheetMngHstEntity.dataState.eq("DONE"))
|
||||||
@@ -87,13 +86,11 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum()
|
.sum()
|
||||||
.as("syncStateDoneCnt"),
|
.as("syncStateDoneCnt"),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.ne("NOTYET"))
|
.when(mapSheetMngHstEntity.syncState.ne("NOTYET"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("NOTPAIR"))
|
.when(mapSheetMngHstEntity.syncState.eq("NOTPAIR"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -108,7 +105,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("DUPLICATE"))
|
.when(mapSheetMngHstEntity.syncState.eq("DUPLICATE"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -123,7 +119,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(
|
.when(
|
||||||
mapSheetMngHstEntity
|
mapSheetMngHstEntity
|
||||||
@@ -146,7 +141,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("NOFILE"))
|
.when(mapSheetMngHstEntity.syncState.eq("NOFILE"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -161,8 +155,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
|
|
||||||
mapSheetMngEntity.createdDttm,
|
mapSheetMngEntity.createdDttm,
|
||||||
mapSheetMngHstEntity.syncEndDttm.max()))
|
mapSheetMngHstEntity.syncEndDttm.max()))
|
||||||
.from(mapSheetMngEntity)
|
.from(mapSheetMngEntity)
|
||||||
@@ -231,7 +223,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
mapSheetMngEntity.mngState,
|
mapSheetMngEntity.mngState,
|
||||||
mapSheetMngEntity.syncState,
|
mapSheetMngEntity.syncState,
|
||||||
mapSheetMngEntity.syncCheckState,
|
mapSheetMngEntity.syncCheckState,
|
||||||
|
|
||||||
mapSheetMngHstEntity.count().as("syncTotalCnt"),
|
mapSheetMngHstEntity.count().as("syncTotalCnt"),
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.dataState.eq("DONE"))
|
.when(mapSheetMngHstEntity.dataState.eq("DONE"))
|
||||||
@@ -239,13 +230,11 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum()
|
.sum()
|
||||||
.as("syncStateDoneCnt"),
|
.as("syncStateDoneCnt"),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.ne("NOTYET"))
|
.when(mapSheetMngHstEntity.syncState.ne("NOTYET"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("NOTPAIR"))
|
.when(mapSheetMngHstEntity.syncState.eq("NOTPAIR"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -260,7 +249,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("DUPLICATE"))
|
.when(mapSheetMngHstEntity.syncState.eq("DUPLICATE"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -275,7 +263,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(
|
.when(
|
||||||
mapSheetMngHstEntity
|
mapSheetMngHstEntity
|
||||||
@@ -298,7 +285,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
new CaseBuilder()
|
new CaseBuilder()
|
||||||
.when(mapSheetMngHstEntity.syncState.eq("NOFILE"))
|
.when(mapSheetMngHstEntity.syncState.eq("NOFILE"))
|
||||||
.then(1L)
|
.then(1L)
|
||||||
@@ -313,8 +299,6 @@ public class MapSheetMngRepositoryImpl extends QuerydslRepositorySupport
|
|||||||
.then(1L)
|
.then(1L)
|
||||||
.otherwise(0L)
|
.otherwise(0L)
|
||||||
.sum(),
|
.sum(),
|
||||||
|
|
||||||
|
|
||||||
mapSheetMngEntity.createdDttm,
|
mapSheetMngEntity.createdDttm,
|
||||||
mapSheetMngHstEntity.syncEndDttm.max()))
|
mapSheetMngHstEntity.syncEndDttm.max()))
|
||||||
.from(mapSheetMngEntity)
|
.from(mapSheetMngEntity)
|
||||||
|
|||||||
Reference in New Issue
Block a user