From 9d7b9bfd118c9b27a692e04ad5ff9c2b09bc3d44 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EC=9D=B4=EC=B0=AC=EB=AF=B8?= Date: Sat, 17 Feb 2024 21:22:47 +0900 Subject: [PATCH 1/3] =?UTF-8?q?[CHORE]=20=EB=B9=88=EC=B9=B8=20=EC=A7=80?= =?UTF-8?q?=EC=9A=B0=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/cicd_dev.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/cicd_dev.yml b/.github/workflows/cicd_dev.yml index b818e0f..e43d23d 100644 --- a/.github/workflows/cicd_dev.yml +++ b/.github/workflows/cicd_dev.yml @@ -32,7 +32,6 @@ jobs: echo "${{ secrets.TATTOUR_DEV_APPLICATION }}" >> ./application.yaml cat ./application.yaml shell: bash - - name: Grant execute permission for gradlew run: chmod +x ./server/gradlew From e872168f3cbc3e21589057fe1f74ffc589370da4 Mon Sep 17 00:00:00 2001 From: 05AM Date: Thu, 22 Feb 2024 02:07:53 +0900 Subject: [PATCH 2/3] =?UTF-8?q?#156=20[REFACTOR]=20=EC=BB=A4=EC=8A=A4?= =?UTF-8?q?=ED=85=80=20=EB=8F=84=EC=95=88=20=EC=8B=A0=EC=B2=AD,=20?= =?UTF-8?q?=EC=9D=BC=EB=B0=98=20=EC=83=81=ED=92=88=20=EA=B5=AC=EB=A7=A4=20?= =?UTF-8?q?=EC=8B=9C=20=EB=94=94=EC=8A=A4=EC=BD=94=EB=93=9C=20=EB=A9=94?= =?UTF-8?q?=EC=8B=9C=EC=A7=80=20=ED=98=95=EC=8B=9D=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../custom/controller/CustomController.java | 7 ++-- .../resquest/CustomApplyDiscordMessage.java | 35 ++++++++++--------- .../resquest/OrderStickerDiscordMessage.java | 27 +++++++------- .../service/DiscordMessageService.java | 13 ++++--- 4 files changed, 46 insertions(+), 36 deletions(-) diff --git a/server/src/main/java/org/tattour/server/domain/custom/controller/CustomController.java b/server/src/main/java/org/tattour/server/domain/custom/controller/CustomController.java index 30ba5b7..e694c29 100644 --- a/server/src/main/java/org/tattour/server/domain/custom/controller/CustomController.java +++ b/server/src/main/java/org/tattour/server/domain/custom/controller/CustomController.java @@ -54,7 +54,7 @@ public ResponseEntity postCustom( @RequestBody @Valid PostCustomReq request ) { PostCustomRes response = PostCustomRes.from( - (customFacade.createCustom(request.getHaveDesign(), userId))); + customFacade.createCustom(request.getHaveDesign(), userId)); return BaseResponse.success(SuccessType.CREATE_CUSTOM_SUCCESS, response); } @@ -79,7 +79,10 @@ public ResponseEntity patchCustom( PatchCustomRes response = PatchCustomRes.from( customFacade.updateCustom( - customInfo.newUpdateCustomReq(userId, customImages, handDrawingImage))); + customInfo.newUpdateCustomReq( + userId, + customImages, + handDrawingImage))); return BaseResponse.success(SuccessType.UPDATE_CUSTOM_SUCCESS, response); } diff --git a/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/CustomApplyDiscordMessage.java b/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/CustomApplyDiscordMessage.java index cecf03f..bf690ef 100644 --- a/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/CustomApplyDiscordMessage.java +++ b/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/CustomApplyDiscordMessage.java @@ -15,28 +15,29 @@ public class CustomApplyDiscordMessage { DiscordCustomImage image; public static CustomApplyDiscordMessage from(User user, Custom custom) { - String title = "Custom Id : " + custom.getId(); - String description; + String title = "커스텀 도안 번호 : " + custom.getId(); + StringBuilder description = new StringBuilder(); + + description.append("\n\n### [유저 정보]") + .append("\n- 연락처: ").append(user.getPhoneNumber()) + .append("\n- 이름: ").append(custom.getName()) + .append("\n\n### [도안 신청 정보]") + .append("\n- 사이즈: ").append(custom.getSize().getSize()) + .append("\n- 수량: ").append(custom.getCount()); + if (custom.getHaveDesign()) { - description = "유저 전화번호 : " + user.getPhoneNumber() - + "\n이름 : " + custom.getName() - + "\n사이즈 : " + custom.getSize().getSize() - + "\n추가 요청 사항 : " + custom.getDemand() - + "\n수량 : " + custom.getCount() - + "\n그려둔 도안 있음"; + description.append("\n- 추가 요청 사항: ").append(custom.getDemand()) + .append("\n- 도안: ").append("`있음`"); } else { - description = "유저 전화번호 : " + user.getPhoneNumber() - + "이름 : " + custom.getName() - + "\n사이즈 : " + custom.getSize().getSize() - + "\n추가 요청 사항 : " + custom.getDemand() - + "\n색상 : " + custom.getIsColored() - + "\n주제 및 설명 : " + custom.getDescription() - + "\n수량 : " + custom.getCount() - + "\n그려둔 도안 없음"; + description.append("\n- 색상: ").append(custom.getIsColored()) + .append("\n- 주제 및 설명: \n").append(custom.getDescription()) + .append("\n- 추가 요청 사항: ").append(custom.getDemand()) + .append("\n- 도안: ").append("`없음`"); } + return new CustomApplyDiscordMessage( title, - description, + description.toString(), new DiscordCustomImage(custom.getMainImageUrl()) ); } diff --git a/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/OrderStickerDiscordMessage.java b/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/OrderStickerDiscordMessage.java index d7732fe..220898f 100644 --- a/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/OrderStickerDiscordMessage.java +++ b/server/src/main/java/org/tattour/server/infra/discord/dto/resquest/OrderStickerDiscordMessage.java @@ -19,27 +19,28 @@ public static OrderStickerDiscordMessage from( List orderedProducts) { String title = "주문 번호: " + orderHistory.getId(); StringBuilder description = new StringBuilder(); + description.append("\n\n### [주문 정보]") - .append("\n유저 번호: ").append(orderHistory.getUser().getId()) - .append("\n상품 금액: ").append(orderHistory.getProductAmount()) - .append("\n총 주문 금액: ").append(orderHistory.getTotalAmount()); + .append("\n- 유저 번호: ").append(orderHistory.getUser().getId()) + .append("\n- 상품 금액: ").append(orderHistory.getProductAmount()) + .append("\n- 총 주문 금액: ").append(orderHistory.getTotalAmount()); description.append("\n\n### [주문 상품 내역]"); orderedProducts.forEach(product -> { description.append("\n"); - description.append("\n상품 번호: ").append(product.getSticker().getId()); - description.append("\n상품명: ").append(product.getSticker().getName()); - description.append("\n가격: ").append(product.getPrice()); - description.append("\n수량: ").append(product.getCount()); + description.append("\n- 상품 번호: ").append(product.getSticker().getId()); + description.append("\n- 상품명: ").append(product.getSticker().getName()); + description.append("\n- 가격: ").append(product.getPrice()); + description.append("\n- 수량: ").append(product.getCount()); }); description.append("\n\n### [배송 정보]") - .append("\n수령인: ").append(orderHistory.getRecipientName()) - .append("\n연락처: ").append(orderHistory.getContact()) - .append("\n우편 번호: ").append(orderHistory.getMailingAddress()) - .append("\n기본 주소: ").append(orderHistory.getBaseAddress()) - .append("\n싱세 주소: ").append(orderHistory.getDetailAddress()) - .append("\n배송비: ").append(orderHistory.getShippingFee()); + .append("\n- 수령인: ").append(orderHistory.getRecipientName()) + .append("\n- 연락처: ").append(orderHistory.getContact()) + .append("\n- 우편 번호: ").append(orderHistory.getMailingAddress()) + .append("\n- 기본 주소: ").append(orderHistory.getBaseAddress()) + .append("\n- 싱세 주소: ").append(orderHistory.getDetailAddress()) + .append("\n- 배송비: ").append(orderHistory.getShippingFee()); return new OrderStickerDiscordMessage(title, description.toString()); } diff --git a/server/src/main/java/org/tattour/server/infra/discord/service/DiscordMessageService.java b/server/src/main/java/org/tattour/server/infra/discord/service/DiscordMessageService.java index a26ca08..5144ee5 100644 --- a/server/src/main/java/org/tattour/server/infra/discord/service/DiscordMessageService.java +++ b/server/src/main/java/org/tattour/server/infra/discord/service/DiscordMessageService.java @@ -25,10 +25,14 @@ public class DiscordMessageService { @Transactional public void sendCustomApplyMessage(Custom custom) { - CustomApplyDiscordMessage payload = CustomApplyDiscordMessage.from(custom.getUser(), - custom); - sendDiscordMessage(customWebhookProperty.getClientId(), customWebhookProperty.getToken(), - custom.getUser(), "님이 커스텀 도안을 신청했습니다.", payload); + CustomApplyDiscordMessage payload = + CustomApplyDiscordMessage.from(custom.getUser(), custom); + + sendDiscordMessage(customWebhookProperty.getClientId(), + customWebhookProperty.getToken(), + custom.getUser(), + "님이 커스텀 도안을 신청했습니다.", + payload); } @Transactional @@ -36,6 +40,7 @@ public void sendOrderStickerMessage(OrderHistory orderHistory, List orderedProducts) { OrderStickerDiscordMessage payload = OrderStickerDiscordMessage.from(orderHistory, orderedProducts); + sendDiscordMessage( orderWebhookProperty.getClientId(), orderWebhookProperty.getToken(), From 7a4803589840d9eb33e98c994b8fca588d060fe4 Mon Sep 17 00:00:00 2001 From: 05AM Date: Thu, 22 Feb 2024 02:23:38 +0900 Subject: [PATCH 3/3] =?UTF-8?q?#156=20[REFACTOR]=20=EC=BB=A4=EC=8A=A4?= =?UTF-8?q?=ED=85=80=20=EB=8F=84=EC=95=88,=20=EC=BB=A4=EC=8A=A4=ED=85=80?= =?UTF-8?q?=20=EC=9E=84=EC=8B=9C=20=EB=8F=84=EC=95=88=20=EC=A0=95=EB=A0=AC?= =?UTF-8?q?=20=EC=88=9C=EC=84=9C=20=EB=B3=80=EA=B2=BD:=20=EC=B5=9C?= =?UTF-8?q?=EA=B7=BC=20=EB=93=B1=EB=A1=9D=EC=88=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../domain/custom/provider/impl/CustomProviderImpl.java | 4 ++-- .../custom/repository/custom/CustomRepositoryCustom.java | 4 ++-- .../domain/custom/repository/impl/CustomRepositoryImpl.java | 6 ++++-- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/server/src/main/java/org/tattour/server/domain/custom/provider/impl/CustomProviderImpl.java b/server/src/main/java/org/tattour/server/domain/custom/provider/impl/CustomProviderImpl.java index 76009b2..0c2ab81 100644 --- a/server/src/main/java/org/tattour/server/domain/custom/provider/impl/CustomProviderImpl.java +++ b/server/src/main/java/org/tattour/server/domain/custom/provider/impl/CustomProviderImpl.java @@ -41,11 +41,11 @@ public List getCustomByUserIdAfterDate(int userId, String date) { @Override public List getAllByUserIdAndIsCompleted(Integer userId) { - return customRepository.findAllByUserIdAndIsCompleted(userId); + return customRepository.findAllByUserIdAndIsCompletedOrderByLastUpdatedAt(userId); } @Override public List getAllByUserIdAndIsCompletedFalse(Integer userId) { - return customRepository.findAllByUserIdAndIsCompletedFalse(userId); + return customRepository.findAllByUserIdAndIsCompletedFalseOrderByLastUpdatedAt(userId); } } diff --git a/server/src/main/java/org/tattour/server/domain/custom/repository/custom/CustomRepositoryCustom.java b/server/src/main/java/org/tattour/server/domain/custom/repository/custom/CustomRepositoryCustom.java index 94a8f34..e036ba5 100644 --- a/server/src/main/java/org/tattour/server/domain/custom/repository/custom/CustomRepositoryCustom.java +++ b/server/src/main/java/org/tattour/server/domain/custom/repository/custom/CustomRepositoryCustom.java @@ -5,7 +5,7 @@ public interface CustomRepositoryCustom { - List findAllByUserIdAndIsCompleted(Integer userId); + List findAllByUserIdAndIsCompletedOrderByLastUpdatedAt(Integer userId); - List findAllByUserIdAndIsCompletedFalse(Integer userId); + List findAllByUserIdAndIsCompletedFalseOrderByLastUpdatedAt(Integer userId); } diff --git a/server/src/main/java/org/tattour/server/domain/custom/repository/impl/CustomRepositoryImpl.java b/server/src/main/java/org/tattour/server/domain/custom/repository/impl/CustomRepositoryImpl.java index 17d6ab8..1460c4c 100644 --- a/server/src/main/java/org/tattour/server/domain/custom/repository/impl/CustomRepositoryImpl.java +++ b/server/src/main/java/org/tattour/server/domain/custom/repository/impl/CustomRepositoryImpl.java @@ -14,20 +14,22 @@ public class CustomRepositoryImpl implements CustomRepositoryCustom { private final JPAQueryFactory queryFactory; @Override - public List findAllByUserIdAndIsCompleted(Integer userId) { + public List findAllByUserIdAndIsCompletedOrderByLastUpdatedAt(Integer userId) { return queryFactory .select(custom) .from(custom) .where(custom.user.id.eq(userId), custom.isCompleted.eq(true)) + .orderBy(custom.lastUpdatedAt.desc()) .fetch(); } @Override - public List findAllByUserIdAndIsCompletedFalse(Integer userId) { + public List findAllByUserIdAndIsCompletedFalseOrderByLastUpdatedAt(Integer userId) { return queryFactory .select(custom) .from(custom) .where(custom.user.id.eq(userId), custom.isCompleted.eq(false)) + .orderBy(custom.lastUpdatedAt.desc()) .fetch(); } }