From b91ed5dd0ea55beb1de7a9d3fe91d07c2460bfeb Mon Sep 17 00:00:00 2001 From: yeonjy Date: Tue, 23 Jul 2024 11:52:11 +0900 Subject: [PATCH 1/3] =?UTF-8?q?feat:=20=EC=9D=B4=EB=AF=B8=EC=A7=80=20?= =?UTF-8?q?=EC=97=AC=EB=9F=AC=EC=9E=A5=20=EC=97=85=EB=A1=9C=EB=93=9C=20?= =?UTF-8?q?=EA=B0=80=EB=8A=A5=ED=95=98=EB=8F=84=EB=A1=9D=20API=20=ED=8C=8C?= =?UTF-8?q?=EB=9D=BC=EB=AF=B8=ED=84=B0=20=ED=83=80=EC=9E=85=20List?= =?UTF-8?q?=EB=A1=9C=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/com/pyro/yolog/global/s3/api/S3ImageApi.java | 4 +++- .../pyro/yolog/global/s3/api/S3ImageImageController.java | 6 ++++-- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/pyro/yolog/global/s3/api/S3ImageApi.java b/src/main/java/com/pyro/yolog/global/s3/api/S3ImageApi.java index 9a9f3ff..4ac808c 100644 --- a/src/main/java/com/pyro/yolog/global/s3/api/S3ImageApi.java +++ b/src/main/java/com/pyro/yolog/global/s3/api/S3ImageApi.java @@ -7,6 +7,8 @@ import io.swagger.v3.oas.annotations.security.SecurityRequirement; import org.springframework.web.multipart.MultipartFile; +import java.util.List; + public interface S3ImageApi { @Operation( summary = "이미지 업로드", @@ -20,7 +22,7 @@ public interface S3ImageApi { description = "Created" ) }) - S3ImageDto uploadImage(MultipartFile image); + List uploadImage(List image); @Operation( summary = "이미지 삭제", diff --git a/src/main/java/com/pyro/yolog/global/s3/api/S3ImageImageController.java b/src/main/java/com/pyro/yolog/global/s3/api/S3ImageImageController.java index 381fa07..086e028 100644 --- a/src/main/java/com/pyro/yolog/global/s3/api/S3ImageImageController.java +++ b/src/main/java/com/pyro/yolog/global/s3/api/S3ImageImageController.java @@ -7,6 +7,8 @@ import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; +import java.util.List; + @RestController @RequiredArgsConstructor @RequestMapping("images") @@ -16,8 +18,8 @@ public class S3ImageImageController implements S3ImageApi { @ResponseStatus(HttpStatus.CREATED) @PostMapping("") @Override - public S3ImageDto uploadImage(@RequestPart(value = "image", required = false) MultipartFile image) { - return s3ImageService.uploadImage(image); + public List uploadImage(@RequestPart(value = "images", required = false) List images) { + return s3ImageService.uploadImage(images); } @ResponseStatus(HttpStatus.CREATED) From cd2a0154aa04d640f198d9644ffbddec7ccc7622 Mon Sep 17 00:00:00 2001 From: yeonjy Date: Tue, 23 Jul 2024 11:52:42 +0900 Subject: [PATCH 2/3] =?UTF-8?q?feat:=20S3=20=EC=9D=B4=EB=AF=B8=EC=A7=80=20?= =?UTF-8?q?=EC=97=AC=EB=9F=AC=EC=9E=A5=20=EC=97=85=EB=A1=9C=EB=93=9C=20?= =?UTF-8?q?=EA=B0=80=EB=8A=A5=ED=95=98=EB=8F=84=EB=A1=9D=20service=20?= =?UTF-8?q?=EB=A1=9C=EC=A7=81=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../pyro/yolog/global/s3/service/S3ImageService.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/pyro/yolog/global/s3/service/S3ImageService.java b/src/main/java/com/pyro/yolog/global/s3/service/S3ImageService.java index 86e2eaf..cf6c609 100644 --- a/src/main/java/com/pyro/yolog/global/s3/service/S3ImageService.java +++ b/src/main/java/com/pyro/yolog/global/s3/service/S3ImageService.java @@ -20,6 +20,7 @@ import java.net.URL; import java.net.URLDecoder; import java.nio.charset.StandardCharsets; +import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.UUID; @@ -34,9 +35,13 @@ public class S3ImageService { private final AmazonS3 amazonS3; - public S3ImageDto uploadImage(MultipartFile file) { - validateImageExtension(file.getOriginalFilename()); - return new S3ImageDto(uploadImageToS3(file)); + public List uploadImage(List files) { + List imageUrls = new ArrayList<>(); + files.forEach(file -> { + validateImageExtension(file.getOriginalFilename()); + imageUrls.add(new S3ImageDto(uploadImageToS3(file))); + }); + return imageUrls; } private void validateImageExtension(String fileName) { From a52b87369d185ee99e3e36a355fa462332b17cf0 Mon Sep 17 00:00:00 2001 From: yeonjy Date: Wed, 24 Jul 2024 12:30:48 +0900 Subject: [PATCH 3/3] =?UTF-8?q?refactor:=20enum=20=EA=B0=92=20=EC=98=81?= =?UTF-8?q?=EC=96=B4=EB=A1=9C=20=EB=B0=9B=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/pyro/yolog/domain/diary/entity/Mood.java | 8 -------- .../java/com/pyro/yolog/domain/diary/entity/Weather.java | 8 -------- 2 files changed, 16 deletions(-) diff --git a/src/main/java/com/pyro/yolog/domain/diary/entity/Mood.java b/src/main/java/com/pyro/yolog/domain/diary/entity/Mood.java index 9bf3be1..3082801 100644 --- a/src/main/java/com/pyro/yolog/domain/diary/entity/Mood.java +++ b/src/main/java/com/pyro/yolog/domain/diary/entity/Mood.java @@ -17,12 +17,4 @@ public enum Mood { ANGRY("화나는"); private final String name; - - @JsonCreator - public static Mood parsing(String inputValue) { - return Stream.of(Mood.values()) - .filter(mood -> mood.getName().equals(inputValue)) - .findFirst() - .orElseThrow(RequestMoodNameInvalidException::new); - } } \ No newline at end of file diff --git a/src/main/java/com/pyro/yolog/domain/diary/entity/Weather.java b/src/main/java/com/pyro/yolog/domain/diary/entity/Weather.java index 8a21b52..eb9ecb0 100644 --- a/src/main/java/com/pyro/yolog/domain/diary/entity/Weather.java +++ b/src/main/java/com/pyro/yolog/domain/diary/entity/Weather.java @@ -17,12 +17,4 @@ public enum Weather { WINDS("바람"); private final String name; - - @JsonCreator - public static Weather parsing(String inputValue) { - return Stream.of(Weather.values()) - .filter(weather -> weather.getName().equals(inputValue)) - .findFirst() - .orElseThrow(RequestWeatherNameInvalidException::new); - } }