From 1f4c208420d1b97702d6ac6b3ce9873ccacf360d Mon Sep 17 00:00:00 2001 From: Kang Dong Hyeon Date: Wed, 3 Jul 2024 23:36:34 +0900 Subject: [PATCH 1/2] =?UTF-8?q?refactor=20:=20entity=EC=A1=B0=ED=9A=8C?= =?UTF-8?q?=EB=A5=BC=20dto=20=EC=A1=B0=ED=9A=8C=EB=A1=9C=20=EC=88=98?= =?UTF-8?q?=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../PropensityAnalysisController.java | 2 +- .../PropensityAnalysisService.java | 19 +++---------------- .../webti/domain}/dto/file/ImageDto.java | 6 +++--- .../PropensityProfileResponseDto.java | 14 +++++++------- .../WebDeveloperProfileRepository.java | 11 ++++++++++- 5 files changed, 24 insertions(+), 28 deletions(-) rename {api/src/main/java/org/meotppo/webti => domain/src/main/java/org/meotppo/webti/domain}/dto/file/ImageDto.java (68%) rename {api/src/main/java/org/meotppo/webti => domain/src/main/java/org/meotppo/webti/domain}/dto/propensityanalysis/PropensityProfileResponseDto.java (63%) diff --git a/api/src/main/java/org/meotppo/webti/controller/propensityanalysis/PropensityAnalysisController.java b/api/src/main/java/org/meotppo/webti/controller/propensityanalysis/PropensityAnalysisController.java index a829d60..26ebf1a 100644 --- a/api/src/main/java/org/meotppo/webti/controller/propensityanalysis/PropensityAnalysisController.java +++ b/api/src/main/java/org/meotppo/webti/controller/propensityanalysis/PropensityAnalysisController.java @@ -5,7 +5,7 @@ import java.util.List; import org.meotppo.webti.dto.propensityanalysis.PropensityAnalysisDto; -import org.meotppo.webti.dto.propensityanalysis.PropensityProfileResponseDto; +import org.meotppo.webti.domain.dto.propensityanalysis.PropensityProfileResponseDto; import org.meotppo.webti.dto.propensityanalysis.PropensityQuestionDto; import org.meotppo.webti.response.ResponseBody; import org.meotppo.webti.service.propensityanalysis.PropensityAnalysisService; diff --git a/api/src/main/java/org/meotppo/webti/service/propensityanalysis/PropensityAnalysisService.java b/api/src/main/java/org/meotppo/webti/service/propensityanalysis/PropensityAnalysisService.java index 62a0f79..9ffdb42 100644 --- a/api/src/main/java/org/meotppo/webti/service/propensityanalysis/PropensityAnalysisService.java +++ b/api/src/main/java/org/meotppo/webti/service/propensityanalysis/PropensityAnalysisService.java @@ -3,16 +3,14 @@ import java.util.List; import java.util.stream.Collectors; -import org.meotppo.webti.domain.entity.jpa.developerprofile.WebDeveloperProfile; import org.meotppo.webti.domain.entity.jpa.question.Option; import org.meotppo.webti.domain.entity.jpa.question.Question; import org.meotppo.webti.domain.entity.type.MbtiType; import org.meotppo.webti.domain.repository.jpa.developertype.WebDeveloperProfileRepository; import org.meotppo.webti.domain.repository.jpa.question.QuestionRepository; -import org.meotppo.webti.dto.file.ImageDto; import org.meotppo.webti.dto.propensityanalysis.PropensityAnalysisDto; import org.meotppo.webti.dto.propensityanalysis.PropensityOptionDto; -import org.meotppo.webti.dto.propensityanalysis.PropensityProfileResponseDto; +import org.meotppo.webti.domain.dto.propensityanalysis.PropensityProfileResponseDto; import org.meotppo.webti.dto.propensityanalysis.PropensityQuestionDto; import org.meotppo.webti.response.exception.common.WebDeveloperProfileNotFoundException; import org.springframework.stereotype.Service; @@ -35,21 +33,10 @@ public PropensityProfileResponseDto analyzeType(PropensityAnalysisDto propensity type.append(propensityAnalysisDto.getTHINKING() > propensityAnalysisDto.getFEELING() ? "T" : "F"); type.append(propensityAnalysisDto.getJUDGING() > propensityAnalysisDto.getPERCEIVING() ? "J" : "P"); - WebDeveloperProfile developerProfile = webDeveloperProfileRepository.findByMbtiType(MbtiType.valueOf(type.toString())) + PropensityProfileResponseDto developerProfile = webDeveloperProfileRepository.findProfileByMbtiType(MbtiType.valueOf(type.toString())) .orElseThrow(() -> new WebDeveloperProfileNotFoundException()); - ImageDto imageDto = ImageDto.builder() - .url(developerProfile.getImage().getUrl()) - .build(); - - PropensityProfileResponseDto responseDto = PropensityProfileResponseDto.builder() - .result(developerProfile.getResult()) - .description(developerProfile.getDescription()) - .mbtiType(developerProfile.getMbtiType()) - .imageDto(imageDto) - .build(); - - return responseDto; + return developerProfile; } public List getPropensityQuestions() { diff --git a/api/src/main/java/org/meotppo/webti/dto/file/ImageDto.java b/domain/src/main/java/org/meotppo/webti/domain/dto/file/ImageDto.java similarity index 68% rename from api/src/main/java/org/meotppo/webti/dto/file/ImageDto.java rename to domain/src/main/java/org/meotppo/webti/domain/dto/file/ImageDto.java index ec4ecb0..5ed31ff 100644 --- a/api/src/main/java/org/meotppo/webti/dto/file/ImageDto.java +++ b/domain/src/main/java/org/meotppo/webti/domain/dto/file/ImageDto.java @@ -1,9 +1,9 @@ -package org.meotppo.webti.dto.file; +package org.meotppo.webti.domain.dto.file; import lombok.Builder; -import lombok.Getter; +import lombok.Data; -@Getter +@Data public class ImageDto { private String url; diff --git a/api/src/main/java/org/meotppo/webti/dto/propensityanalysis/PropensityProfileResponseDto.java b/domain/src/main/java/org/meotppo/webti/domain/dto/propensityanalysis/PropensityProfileResponseDto.java similarity index 63% rename from api/src/main/java/org/meotppo/webti/dto/propensityanalysis/PropensityProfileResponseDto.java rename to domain/src/main/java/org/meotppo/webti/domain/dto/propensityanalysis/PropensityProfileResponseDto.java index a3b5cf0..590d20a 100644 --- a/api/src/main/java/org/meotppo/webti/dto/propensityanalysis/PropensityProfileResponseDto.java +++ b/domain/src/main/java/org/meotppo/webti/domain/dto/propensityanalysis/PropensityProfileResponseDto.java @@ -1,12 +1,12 @@ -package org.meotppo.webti.dto.propensityanalysis; +package org.meotppo.webti.domain.dto.propensityanalysis; +import lombok.Data; +import org.meotppo.webti.domain.dto.file.ImageDto; import org.meotppo.webti.domain.entity.type.MbtiType; -import org.meotppo.webti.dto.file.ImageDto; import lombok.Builder; -import lombok.Getter; -@Getter +@Data public class PropensityProfileResponseDto { private String result; private String description; @@ -14,10 +14,10 @@ public class PropensityProfileResponseDto { private ImageDto imageDto; @Builder - public PropensityProfileResponseDto(String result, String description, MbtiType mbtiType, ImageDto imageDto) { + public PropensityProfileResponseDto(String result, String description, MbtiType mbtiType, String imageUrl) { this.result = result; this.description = description; this.mbtiType = mbtiType; - this.imageDto = imageDto; + this.imageDto = ImageDto.builder().url(imageUrl).build(); } -} +} \ No newline at end of file diff --git a/domain/src/main/java/org/meotppo/webti/domain/repository/jpa/developertype/WebDeveloperProfileRepository.java b/domain/src/main/java/org/meotppo/webti/domain/repository/jpa/developertype/WebDeveloperProfileRepository.java index 2a9abf3..9f8c39b 100644 --- a/domain/src/main/java/org/meotppo/webti/domain/repository/jpa/developertype/WebDeveloperProfileRepository.java +++ b/domain/src/main/java/org/meotppo/webti/domain/repository/jpa/developertype/WebDeveloperProfileRepository.java @@ -2,10 +2,19 @@ import java.util.Optional; +import org.meotppo.webti.domain.dto.propensityanalysis.PropensityProfileResponseDto; import org.meotppo.webti.domain.entity.jpa.developerprofile.WebDeveloperProfile; import org.meotppo.webti.domain.entity.type.MbtiType; import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.data.jpa.repository.Query; + public interface WebDeveloperProfileRepository extends JpaRepository{ Optional findByMbtiType(MbtiType mbtiType); -} + + @Query("SELECT new org.meotppo.webti.domain.dto.propensityanalysis.PropensityProfileResponseDto(wdp.result, wdp.description, wdp.mbtiType, img.url) " + + "FROM WebDeveloperProfile wdp " + + "JOIN wdp.image img " + + "WHERE wdp.mbtiType = :mbtiType") + Optional findProfileByMbtiType(MbtiType mbtiType); +} \ No newline at end of file From af2d5f0ab5685a1bf77688f74a5087a3b572510e Mon Sep 17 00:00:00 2001 From: Kang Dong Hyeon Date: Thu, 4 Jul 2024 00:26:24 +0900 Subject: [PATCH 2/2] =?UTF-8?q?chore=20:=20=EA=B2=B0=EA=B3=BC=20=EC=9D=B4?= =?UTF-8?q?=EB=AF=B8=EC=A7=80=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/org/meotppo/webti/InitData.java | 49 ++++++++++++------- 1 file changed, 32 insertions(+), 17 deletions(-) diff --git a/api/src/main/java/org/meotppo/webti/InitData.java b/api/src/main/java/org/meotppo/webti/InitData.java index b615f67..ffafd36 100644 --- a/api/src/main/java/org/meotppo/webti/InitData.java +++ b/api/src/main/java/org/meotppo/webti/InitData.java @@ -33,7 +33,22 @@ public class InitData { @EventListener(ApplicationReadyEvent.class) @Transactional public void initData() { - String exampleImageUrl = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/karina.jpg"; // TODO. 테스트 용 이미지 수정 필요 + String ENFJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ENFJ.webp"; + String ENFPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ENFP.webp"; + String ENTJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ENTJ.webp"; + String ENTPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ENTP.webp"; + String ESFJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ESFJ.webp"; + String ESFPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ESFP.webp"; + String ESTJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ESFJ.webp"; + String ESTPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ESTP.webp"; + String INFJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/INFJ.webp"; + String INFPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/INFP.webp"; + String INTJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/INTJ.webp"; + String INTPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/INTP.webp"; + String ISFJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ISFJ.webp"; + String ISFPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ISFP.webp"; + String ISTJImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ISTJ.webp"; + String ISTPImage = "https://webti-imagebucket.s3.eu-north-1.amazonaws.com/ISTP.webp"; List profileData = Arrays.asList( WebDeveloperProfile.builder() @@ -41,7 +56,7 @@ public void initData() { .result("철저한 데이터 관리형 백엔드 개발자") .description("데이터의 정확성과 안정성을 최우선으로 하는 당신은 백엔드 개발의 수호자! 체계적이고 신뢰할 수 있는 방식으로 데이터를 관리하며, 버그는 당신에게 있어 전설 속 이야기일 뿐입니다. 당신의 코드는 그야말로 철옹성!") .image(Image.builder() - .url(exampleImageUrl) + .url(ISTJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -49,7 +64,7 @@ public void initData() { .result("전략적 시스템 설계형 백엔드 개발자") .description("소프트웨어 개발의 체스 그랜드마스터인 당신은, 몇 수 앞을 내다보는 전략가! 시스템 아키텍처를 전략적으로 설계하고, 최적의 경로를 찾아내는 당신의 코드는 예술 작품과 같습니다. 복잡한 문제도 순식간에 해결하는 능력자!") .image(Image.builder() - .url(exampleImageUrl) + .url(INTJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -57,7 +72,7 @@ public void initData() { .result("효율적인 문제 해결형 백엔드 개발자") .description("프로그래밍 세계의 맥가이버, 당신! 실용적이고 논리적인 사고로 문제를 해결하며, 시스템 최적화와 효율적인 코드 작성에 탁월한 재능을 보입니다. 종이 클립 하나로도 문제를 해결할 수 있을 것 같은 당신의 능력은 그야말로 경이롭습니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(ISTPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -65,7 +80,7 @@ public void initData() { .result("혁신적인 알고리즘 전문가 백엔드 개발자") .description("코드의 아인슈타인인 당신은, 복잡한 알고리즘과 데이터 구조 설계에서 빛을 발합니다. 끊임없이 새로운 아이디어가 떠오르는 당신의 머릿속은 혁신으로 가득 차 있으며, 논리적이고 분석적인 사고로 누구도 해결하지 못하는 문제를 해결합니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(INTPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -73,7 +88,7 @@ public void initData() { .result("실행력 강한 관리자형 백엔드 개발자") .description("당신은 체계적이고 조직적인 접근 방식을 통해 백엔드 시스템을 효율적으로 관리합니다. 철저한 계획과 규칙을 중시하며, 팀을 이끌어 프로젝트를 성공적으로 완수합니다. 당신의 코드는 언제나 깔끔하고 명확하며, 시스템의 신뢰성을 보장합니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(ESTJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -81,7 +96,7 @@ public void initData() { .result("섬세한 사용자 경험 디자이너형 프론트 엔드 개발자") .description("사용자의 마음을 읽는 텔레파시 능력을 가진 당신은 UI/UX 디자인의 귀재! 세심하고 헌신적으로 사용자 경험을 중시하며, 직감적으로 사용자가 원하는 인터페이스를 설계합니다. 당신의 작업물은 언제나 사용자의 기대를 넘어서죠!") .image(Image.builder() - .url(exampleImageUrl) + .url(ISFJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -89,7 +104,7 @@ public void initData() { .result("창의적인 인터페이스 디자이너형 프론트엔드 개발자") .description("프론트엔드 세계의 예술가인 당신은 사교적이고 에너제틱하며, 사용자와의 상호작용을 즐깁니다. 반응형 웹 디자인에 강점을 발휘하며, 당신의 작업물은 언제나 화려하고 눈길을 사로잡습니다. 당신의 웹 페이지는 마치 예술 작품과 같습니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(ESFPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -97,7 +112,7 @@ public void initData() { .result("혁신적인 UX/UI 전문가형 프론트엔드 개발자") .description("창의성과 열정의 화신인 당신은 새로운 아이디어와 혁신적인 디자인으로 사용자 경험을 극대화합니다. 사람들과의 상호작용을 즐기며, 당신의 작업은 언제나 신선하고 놀라운 요소들로 가득합니다. 당신의 웹사이트 탐험은 마치 모험과도 같죠!") .image(Image.builder() - .url(exampleImageUrl) + .url(ENFPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -105,7 +120,7 @@ public void initData() { .result("디테일에 강한 시각 예술가형 프론트엔드 개발자") .description("당신은 섬세하고 창의적인 디자인 감각으로 사용자 인터페이스를 아름답게 구현합니다. 세밀한 부분까지 놓치지 않으며, 사용자가 시각적으로 즐길 수 있는 웹사이트를 만듭니다. 당신의 작업물은 예술 작품처럼 정교하고 매력적입니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(ISFPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -113,7 +128,7 @@ public void initData() { .result("공감하는 이야기꾼형 프론트엔드 개발자") .description("사용자 경험에 깊은 공감을 가지고 디자인하는 당신은, 감성적이고 창의적인 방식으로 웹 페이지를 만듭니다. 사용자와의 상호작용에서 진정성을 발휘하며, 웹사이트를 통해 따뜻한 이야기를 전합니다. 당신의 작업물은 사용자의 마음을 움직입니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(INFPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -121,7 +136,7 @@ public void initData() { .result("사용자 중심 인터페이스 개발자형 프론트엔드 개발자") .description("사용자 중심의 접근 방식을 중시하는 당신은 사용자 인터페이스 디자인과 고객 요구 사항 반영에 탁월한 능력을 보입니다. 사용자가 원하는 모든 것을 제공하며 편안함을 줍니다. 당신의 작업물은 언제나 사용자에게 편안함을 줍니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(ESFJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -129,7 +144,7 @@ public void initData() { .result("전체 비전을 갖춘 개발자형 풀스택 개발자") .description("창의적이고 통찰력 있는 당신은 전체적인 비전을 가지고 프로젝트를 추진합니다. 백엔드와 프론트엔드를 모두 이해하며, 사용자와 시스템 간의 조화를 고려하는 능력을 지니고 있습니다. 당신의 프로젝트는 시처럼 아름답게 완성됩니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(INFJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -137,7 +152,7 @@ public void initData() { .result("다양한 기술을 아우르는 문제 해결사형 풀스택 개발자") .description("새로운 기술을 빠르게 습득하고 다양한 문제를 해결할 수 있는 당신은 프로그래밍의 만능 해결사! 혁신적인 접근 방식과 도전 정신으로 프로젝트를 성공적으로 이끕니다. 당신의 프로젝트는 항상 혁신적입니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(ENTPImage) .build()) .build(), WebDeveloperProfile.builder() @@ -145,7 +160,7 @@ public void initData() { .result("협력과 조정을 이끄는 개발자형 풀스택 개발자") .description("팀의 리더이자 조정자인 당신은 카리스마 있고 협력적이며, 사람들을 이끄는 능력이 뛰어납니다. 팀의 비전을 공유하고 협력하여 목표를 달성하는 데 주력합니다. 당신이 이끄는 프로젝트는 언제나 성공적입니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(ENFJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -153,7 +168,7 @@ public void initData() { .result("전략적 프로젝트 리더형 풀스택 개발자") .description("전략적이고 리더십이 뛰어난 당신은 장기적인 목표와 전략을 세워 프로젝트를 이끌며, 논리적이고 효율적인 접근 방식을 사용합니다. 프로젝트를 마치 군대처럼 철저히 계획하고 성공적으로 수행합니다. 당신의 프로젝트는 항상 성공적입니다!") .image(Image.builder() - .url(exampleImageUrl) + .url(ENTJImage) .build()) .build(), WebDeveloperProfile.builder() @@ -161,7 +176,7 @@ public void initData() { .result("유연하고 즉흥적인 개발자형 풀스택 개발자") .description("당신은 변화와 도전에 강하며, 문제를 해결하는 데 있어 유연하고 즉흥적인 접근 방식을 취합니다. 실용적이고 효율적인 방법을 선호하며, 빠른 결단력으로 프로젝트를 성공적으로 이끌어갑니다. 당신의 작업은 항상 실용적이고 동적입니다.") .image(Image.builder() - .url(exampleImageUrl) + .url(ESTPImage) .build()) .build() );