From e61ccd1ee4e30ecef1448429bb16274d65184603 Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 18:54:06 +0900 Subject: [PATCH 1/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EB=A9=98=ED=86=A0?= =?UTF-8?q?=EB=A7=81=20=EC=A0=95=EB=B3=B4=20=EC=A1=B0=ED=9A=8C=20Status?= =?UTF-8?q?=EB=B6=84=EB=A5=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../application/dto/res/AuthUserResponse.java | 2 - ...toringInfo.java => DoneMentoringInfo.java} | 6 +- .../dto/ExpectedMentoringInfo.java | 41 ++++++++++ .../application/dto/WaitingMentoringInfo.java | 19 +++++ .../dto/res/AppliedMentoringResponse.java | 3 +- .../usecase/MentoringInfoUseCase.java | 78 +++++++++++-------- 6 files changed, 111 insertions(+), 38 deletions(-) rename src/main/java/com/postgraduate/domain/mentoring/application/dto/{AppliedMentoringInfo.java => DoneMentoringInfo.java} (75%) create mode 100644 src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java create mode 100644 src/main/java/com/postgraduate/domain/mentoring/application/dto/WaitingMentoringInfo.java diff --git a/src/main/java/com/postgraduate/domain/auth/application/dto/res/AuthUserResponse.java b/src/main/java/com/postgraduate/domain/auth/application/dto/res/AuthUserResponse.java index 8535bf9b..a2b86c2d 100644 --- a/src/main/java/com/postgraduate/domain/auth/application/dto/res/AuthUserResponse.java +++ b/src/main/java/com/postgraduate/domain/auth/application/dto/res/AuthUserResponse.java @@ -4,13 +4,11 @@ import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Getter; -import lombok.NoArgsConstructor; import java.util.Optional; @Builder @Getter -@NoArgsConstructor @AllArgsConstructor public class AuthUserResponse { private Optional user; diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/AppliedMentoringInfo.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/DoneMentoringInfo.java similarity index 75% rename from src/main/java/com/postgraduate/domain/mentoring/application/dto/AppliedMentoringInfo.java rename to src/main/java/com/postgraduate/domain/mentoring/application/dto/DoneMentoringInfo.java index 95076682..9148f9cc 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/dto/AppliedMentoringInfo.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/DoneMentoringInfo.java @@ -1,5 +1,6 @@ package com.postgraduate.domain.mentoring.application.dto; +import com.fasterxml.jackson.annotation.JsonInclude; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Getter; @@ -8,14 +9,13 @@ @Getter @Builder @AllArgsConstructor -public class AppliedMentoringInfo { +public class DoneMentoringInfo { Long mentoringId; Long seniorId; String nickName; String postgradu; String field; String professor; - String[] dates; + String date; int term; - String chatLink; } \ No newline at end of file diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java new file mode 100644 index 00000000..73130394 --- /dev/null +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java @@ -0,0 +1,41 @@ +package com.postgraduate.domain.mentoring.application.dto; + +import com.fasterxml.jackson.annotation.JsonInclude; +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; + + +@Getter +@Builder +@AllArgsConstructor +public class ExpectedMentoringInfo { + Long mentoringId; + Long seniorId; + String nickName; + String postgradu; + String field; + String professor; + String date; + int term; + String chatLink; +} + +/** + * 2. 진행예정 탭: <확정대기> 탭에 있던 멘토링 중, 대학원생 선배가 멘토링을 수락한 것이 <진행예정> 탭으로 이동. + * 다음은 멘토링 리스트 각각에 들어가는 항목임. + * + * 1) 멘토링 정보 노출: 대학원생 선배 정보 - [대학원생 선배 닉네임], [대학원], [연구실분야], [교수님], [대학원생 선배가 선택한 멘토링 시간], [멘토링 가능한 시간 옵션 - 1차 배포에서는 40분으로 고정] 텍스트 형태로 노출. + * * 정보 노출 형태 + * 닉네임: 000 선배와 멘토링 + * 대학원 | 연구실분야 | 교수님 + * 대학원생 선배가 선택한 멘토링 시간: 0000년 00월 00일 00시 + * + * 2) 대학원 선배 오픈채팅방 링크 + 복사 기능 + * 대학원 선배 오픈채팅방 링크가 텍스트 형태로 적혀 있고, 그 옆에 [복사] 버튼이 있음. [복사] 버튼을 누르면 오픈채팅방 링크가 복사됨. + * + * 3) [멘토링 진행 완료하기] 버튼 + * 해당 버튼을 누르면 <진행예정> 탭에 있던 멘토링이 <완료> 탭으로 이동. 해당 버튼은 사전에 예정된 멘토링 시간이 지나면 새롭게 생겨남. + * + * 4) 대학원생 선배 프로필 연결 링크 + */ \ No newline at end of file diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/WaitingMentoringInfo.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/WaitingMentoringInfo.java new file mode 100644 index 00000000..c97bf989 --- /dev/null +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/WaitingMentoringInfo.java @@ -0,0 +1,19 @@ +package com.postgraduate.domain.mentoring.application.dto; + +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; + + +@Getter +@Builder +@AllArgsConstructor +public class WaitingMentoringInfo { + Long mentoringId; + Long seniorId; + String nickName; + String postgradu; + String field; + String major; + int term; +} \ No newline at end of file diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java index fed717fd..b7b6d459 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java @@ -1,6 +1,5 @@ package com.postgraduate.domain.mentoring.application.dto.res; -import com.postgraduate.domain.mentoring.application.dto.AppliedMentoringInfo; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Getter; @@ -11,5 +10,5 @@ @Builder @AllArgsConstructor public class AppliedMentoringResponse { - List appliedMentoringInfos; + List waitingMentoringInfos; } diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/usecase/MentoringInfoUseCase.java b/src/main/java/com/postgraduate/domain/mentoring/application/usecase/MentoringInfoUseCase.java index d7ace4c9..5f11e4d6 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/usecase/MentoringInfoUseCase.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/usecase/MentoringInfoUseCase.java @@ -1,6 +1,8 @@ package com.postgraduate.domain.mentoring.application.usecase; -import com.postgraduate.domain.mentoring.application.dto.AppliedMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.DoneMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.ExpectedMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.WaitingMentoringInfo; import com.postgraduate.domain.mentoring.application.dto.res.AppliedMentoringDetailResponse; import com.postgraduate.domain.mentoring.application.dto.res.AppliedMentoringResponse; import com.postgraduate.domain.mentoring.application.dto.res.SeniorMentoringDetailResponse; @@ -22,8 +24,7 @@ import java.util.List; import java.util.stream.Collectors; -import static com.postgraduate.domain.mentoring.domain.entity.constant.Status.DONE; -import static com.postgraduate.domain.mentoring.domain.entity.constant.Status.WAITING; +import static com.postgraduate.domain.mentoring.domain.entity.constant.Status.*; @Service @Transactional @@ -33,9 +34,21 @@ public class MentoringInfoUseCase { private final CheckIsMyMentoringUseCase checkIsMyMentoringUseCase; private final SeniorGetService seniorGetService; - public AppliedMentoringResponse getMentorings(Status status, User user) { - List mentorings = mentoringGetService.mentoringByUser(user, status); - return getCategories(status, mentorings); + + public AppliedMentoringDetailResponse getMentoringDetail(User user, Long mentoringId) { + Mentoring mentoring = checkIsMyMentoringUseCase.byUser(user, mentoringId); + if (mentoring.getStatus() != WAITING) { + throw new MentoringNotWaitingException(); + } + return MentoringMapper.mapToAppliedDetailInfo(mentoring); + } + + public SeniorMentoringDetailResponse getSeniorMentoringDetail(User user, Long mentoringId) { + Mentoring mentoring = checkIsMyMentoringUseCase.bySenior(user, mentoringId); + if (mentoring.getStatus() == DONE) { + throw new MentoringDoneException(); + } + return MentoringMapper.mapToSeniorMentoringDetail(mentoring); } public List getSeniorMentorings(Status status, User user) { @@ -45,39 +58,42 @@ public List getSeniorMentorings(Status status, User use return mentorings.stream().map(MentoringMapper::mapToSeniorMentoring).collect(Collectors.toList()); } - private AppliedMentoringResponse getCategories(Status status, List mentorings) { - List appliedMentoringInfos = new ArrayList<>(); + public AppliedMentoringResponse getMentorings(Status status, User user) { + List mentorings = mentoringGetService.mentoringByUser(user, status); + return getCategories(status, mentorings); + } - switch (status) { - case WAITING, DONE -> { - for (Mentoring mentoring : mentorings) { - appliedMentoringInfos.add(MentoringMapper.mapToWaitingOrDoneAppliedInfo(mentoring)); - } - return new AppliedMentoringResponse(appliedMentoringInfos); - } + private AppliedMentoringResponse getCategories(Status status, List mentorings) { + if (status == WAITING) { + return getWaiting(mentorings); + } + if (status == EXPECTED) { + return getExpected(mentorings); + } + return getDone(mentorings); + } - default -> { - for (Mentoring mentoring : mentorings) { - appliedMentoringInfos.add(MentoringMapper.mapToExpectedAppliedInfo(mentoring)); - } - return new AppliedMentoringResponse(appliedMentoringInfos); - } + private AppliedMentoringResponse getWaiting(List mentorings) { + List waitingMentoringInfos = new ArrayList<>(); + for (Mentoring mentoring : mentorings) { + waitingMentoringInfos.add(MentoringMapper.mapToWaitingInfo(mentoring)); } + return new AppliedMentoringResponse(waitingMentoringInfos); } - public AppliedMentoringDetailResponse getMentoringDetail(User user, Long mentoringId) { - Mentoring mentoring = checkIsMyMentoringUseCase.byUser(user, mentoringId); - if (mentoring.getStatus() != WAITING) { - throw new MentoringNotWaitingException(); + private AppliedMentoringResponse getExpected(List mentorings) { + List expectedMentoringInfos = new ArrayList<>(); + for (Mentoring mentoring : mentorings) { + expectedMentoringInfos.add(MentoringMapper.mapToExpectedInfo(mentoring)); } - return MentoringMapper.mapToAppliedDetailInfo(mentoring); + return new AppliedMentoringResponse(expectedMentoringInfos); } - public SeniorMentoringDetailResponse getSeniorMentoringDetail(User user, Long mentoringId) { - Mentoring mentoring = checkIsMyMentoringUseCase.bySenior(user, mentoringId); - if (mentoring.getStatus() == DONE) { - throw new MentoringDoneException(); + private AppliedMentoringResponse getDone(List mentorings) { + List doneMentoringInfos = new ArrayList<>(); + for (Mentoring mentoring : mentorings) { + doneMentoringInfos.add(MentoringMapper.mapToDoneInfo(mentoring)); } - return MentoringMapper.mapToSeniorMentoringDetail(mentoring); + return new AppliedMentoringResponse(doneMentoringInfos); } } From c8ee56ef7e7ac1ef89f2a72205b855c3917282e8 Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 18:54:13 +0900 Subject: [PATCH 2/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EB=A9=98=ED=86=A0?= =?UTF-8?q?=EB=A7=81=20=EC=A0=95=EB=B3=B4=20=EC=A1=B0=ED=9A=8C=20Status?= =?UTF-8?q?=EB=B6=84=EB=A5=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../application/mapper/MentoringMapper.java | 35 +++++++++++++------ 1 file changed, 25 insertions(+), 10 deletions(-) diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/mapper/MentoringMapper.java b/src/main/java/com/postgraduate/domain/mentoring/application/mapper/MentoringMapper.java index 1bf7af76..3a59e2a3 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/mapper/MentoringMapper.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/mapper/MentoringMapper.java @@ -1,6 +1,8 @@ package com.postgraduate.domain.mentoring.application.mapper; -import com.postgraduate.domain.mentoring.application.dto.AppliedMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.DoneMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.ExpectedMentoringInfo; +import com.postgraduate.domain.mentoring.application.dto.WaitingMentoringInfo; import com.postgraduate.domain.mentoring.application.dto.req.MentoringApplyRequest; import com.postgraduate.domain.mentoring.application.dto.res.AppliedMentoringDetailResponse; import com.postgraduate.domain.mentoring.application.dto.res.SeniorMentoringDetailResponse; @@ -13,32 +15,45 @@ import java.util.stream.Stream; public class MentoringMapper { - public static AppliedMentoringInfo mapToExpectedAppliedInfo(Mentoring mentoring) { + public static ExpectedMentoringInfo mapToExpectedInfo(Mentoring mentoring) { Senior senior = mentoring.getSenior(); - String[] dates = mentoring.getDate().split(","); - return AppliedMentoringInfo.builder() + return ExpectedMentoringInfo.builder() .mentoringId(mentoring.getMentoringId()) - .dates(dates) .seniorId(senior.getSeniorId()) .nickName(senior.getUser().getNickName()) .postgradu(senior.getInfo().getPostgradu()) .professor(senior.getInfo().getProfessor()) .field(senior.getInfo().getField()) + .term(senior.getProfile().getTerm()) + .date(mentoring.getDate()) .chatLink(senior.getProfile().getChatLink()) .build(); } - public static AppliedMentoringInfo mapToWaitingOrDoneAppliedInfo(Mentoring mentoring) { + + public static DoneMentoringInfo mapToDoneInfo(Mentoring mentoring) { Senior senior = mentoring.getSenior(); - String[] dates = mentoring.getDate().split(","); - return AppliedMentoringInfo.builder() + return DoneMentoringInfo.builder() .mentoringId(mentoring.getMentoringId()) - .dates(dates) - .term(senior.getProfile().getTerm()) .seniorId(senior.getSeniorId()) .nickName(senior.getUser().getNickName()) .postgradu(senior.getInfo().getPostgradu()) .professor(senior.getInfo().getProfessor()) .field(senior.getInfo().getField()) + .term(senior.getProfile().getTerm()) + .date(mentoring.getDate()) + .build(); + } + + public static WaitingMentoringInfo mapToWaitingInfo(Mentoring mentoring) { + Senior senior = mentoring.getSenior(); + return WaitingMentoringInfo.builder() + .mentoringId(mentoring.getMentoringId()) + .term(senior.getProfile().getTerm()) + .seniorId(senior.getSeniorId()) + .nickName(senior.getUser().getNickName()) + .postgradu(senior.getInfo().getPostgradu()) + .major(senior.getInfo().getMajor()) + .field(senior.getInfo().getField()) .build(); } public static AppliedMentoringDetailResponse mapToAppliedDetailInfo(Mentoring mentoring) { From 8789645866da1440e3d13383f8e4c9d687c25cb3 Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 18:55:01 +0900 Subject: [PATCH 3/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EC=84=A0=EB=B0=B0?= =?UTF-8?q?=20=EC=BB=AC=EB=9F=BC=20=EC=B6=94=EA=B0=80=20=EB=B0=8F=20?= =?UTF-8?q?=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../domain/auth/application/dto/req/SignUpRequest.java | 2 ++ .../dto/req/SeniorProfileAndAccountRequest.java | 4 ++++ .../senior/application/dto/req/SeniorProfileRequest.java | 4 ++++ .../domain/senior/application/mapper/SeniorMapper.java | 4 ++++ .../senior/application/usecase/SeniorSignUpUseCase.java | 1 - .../postgraduate/domain/senior/domain/entity/Profile.java | 7 ++++++- 6 files changed, 20 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/postgraduate/domain/auth/application/dto/req/SignUpRequest.java b/src/main/java/com/postgraduate/domain/auth/application/dto/req/SignUpRequest.java index 01805319..364051e3 100644 --- a/src/main/java/com/postgraduate/domain/auth/application/dto/req/SignUpRequest.java +++ b/src/main/java/com/postgraduate/domain/auth/application/dto/req/SignUpRequest.java @@ -12,5 +12,7 @@ public class SignUpRequest { @NotNull private Long socialId; @NotNull + private String phoneNumber; + @NotNull private String nickName; } diff --git a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java index 9ca7266a..e79d8b5a 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java +++ b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java @@ -18,6 +18,10 @@ public class SeniorProfileAndAccountRequest { @NotNull private String time; @NotNull + private String oneLiner; + @NotNull + private String keyword; + @NotNull private String account; @NotNull private String bank; diff --git a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileRequest.java b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileRequest.java index 6fc8e61e..dfa4ef5d 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileRequest.java +++ b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileRequest.java @@ -17,4 +17,8 @@ public class SeniorProfileRequest { private String chatLink; @NotNull private String time; + @NotNull + private String oneLiner; + @NotNull + private String keyword; } diff --git a/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java b/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java index 31a54f67..bd5c670f 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java +++ b/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java @@ -56,6 +56,8 @@ public static Profile mapToProfile(SeniorProfileAndAccountRequest profileAndAcco .chatLink(profileAndAccountPageRequest.getChatLink()) .target(profileAndAccountPageRequest.getTarget()) .time(profileAndAccountPageRequest.getTime()) + .oneLiner(profileAndAccountPageRequest.getOneLiner()) + .keyword(profileAndAccountPageRequest.getKeyword()) .build(); } @@ -63,6 +65,8 @@ public static Profile mapToProfile(SeniorProfileRequest profileRequest) { return Profile.builder() .info(profileRequest.getInfo()) .chatLink(profileRequest.getChatLink()) + .oneLiner(profileRequest.getOneLiner()) + .keyword(profileRequest.getKeyword()) .target(profileRequest.getTarget()) .time(profileRequest.getTime()) .build(); diff --git a/src/main/java/com/postgraduate/domain/senior/application/usecase/SeniorSignUpUseCase.java b/src/main/java/com/postgraduate/domain/senior/application/usecase/SeniorSignUpUseCase.java index 1f060040..a6d0971b 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/usecase/SeniorSignUpUseCase.java +++ b/src/main/java/com/postgraduate/domain/senior/application/usecase/SeniorSignUpUseCase.java @@ -11,7 +11,6 @@ import com.postgraduate.domain.user.domain.entity.User; import com.postgraduate.domain.user.domain.entity.constant.Role; import com.postgraduate.domain.user.domain.service.UserUpdateService; -import com.postgraduate.global.config.security.util.SecurityUtils; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; diff --git a/src/main/java/com/postgraduate/domain/senior/domain/entity/Profile.java b/src/main/java/com/postgraduate/domain/senior/domain/entity/Profile.java index 41fd4a33..936027ca 100644 --- a/src/main/java/com/postgraduate/domain/senior/domain/entity/Profile.java +++ b/src/main/java/com/postgraduate/domain/senior/domain/entity/Profile.java @@ -14,11 +14,16 @@ public class Profile { private String info; + private String oneLiner; + + private String keyword; + private String target; private String chatLink; private String time; - private Integer term; + @Builder.Default + private Integer term = 40; } From 3543749e0c3c7936fc3033e159f8ad826834ceb5 Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 18:56:44 +0900 Subject: [PATCH 4/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EB=8C=80=ED=95=99?= =?UTF-8?q?=EC=83=9D=20=ED=9D=AC=EB=A7=9D=20=ED=95=99=EA=B3=BC,=20?= =?UTF-8?q?=EB=B6=84=EC=95=BC=20=EC=BB=AC=EB=9F=BC=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../application/dto/req/UserHopeRequest.java | 12 +++++++++++ .../user/application/mapper/UserMapper.java | 12 +++++++++++ .../usecase/UserMyPageUseCase.java | 7 +++++++ .../domain/user/domain/entity/Hope.java | 20 +++++++++++++++++++ .../domain/user/domain/entity/User.java | 11 +++++++++- .../domain/service/UserUpdateService.java | 6 ++++++ .../user/presentation/UserController.java | 8 ++++++++ 7 files changed, 75 insertions(+), 1 deletion(-) create mode 100644 src/main/java/com/postgraduate/domain/user/application/dto/req/UserHopeRequest.java create mode 100644 src/main/java/com/postgraduate/domain/user/domain/entity/Hope.java diff --git a/src/main/java/com/postgraduate/domain/user/application/dto/req/UserHopeRequest.java b/src/main/java/com/postgraduate/domain/user/application/dto/req/UserHopeRequest.java new file mode 100644 index 00000000..913076f2 --- /dev/null +++ b/src/main/java/com/postgraduate/domain/user/application/dto/req/UserHopeRequest.java @@ -0,0 +1,12 @@ +package com.postgraduate.domain.user.application.dto.req; + +import lombok.AllArgsConstructor; +import lombok.Getter; + +@Getter +@AllArgsConstructor +public class UserHopeRequest { + private String major; + private String field; + private boolean receive; +} diff --git a/src/main/java/com/postgraduate/domain/user/application/mapper/UserMapper.java b/src/main/java/com/postgraduate/domain/user/application/mapper/UserMapper.java index 8c50b8ba..a2780e2c 100644 --- a/src/main/java/com/postgraduate/domain/user/application/mapper/UserMapper.java +++ b/src/main/java/com/postgraduate/domain/user/application/mapper/UserMapper.java @@ -1,7 +1,9 @@ package com.postgraduate.domain.user.application.mapper; import com.postgraduate.domain.auth.application.dto.req.SignUpRequest; +import com.postgraduate.domain.user.application.dto.req.UserHopeRequest; import com.postgraduate.domain.user.application.dto.res.UserInfoResponse; +import com.postgraduate.domain.user.domain.entity.Hope; import com.postgraduate.domain.user.domain.entity.User; public class UserMapper { @@ -17,6 +19,16 @@ public static User mapToUser(SignUpRequest request) { return User.builder() .socialId(request.getSocialId()) .nickName(request.getNickName()) + .phoneNumber(request.getPhoneNumber()) + .hope(new Hope()) + .build(); + } + + public static Hope mapToHope(UserHopeRequest hopeRequest) { + return Hope.builder() + .major(hopeRequest.getMajor()) + .field(hopeRequest.getField()) + .receive(hopeRequest.isReceive()) .build(); } } diff --git a/src/main/java/com/postgraduate/domain/user/application/usecase/UserMyPageUseCase.java b/src/main/java/com/postgraduate/domain/user/application/usecase/UserMyPageUseCase.java index 0023bae5..296c9056 100644 --- a/src/main/java/com/postgraduate/domain/user/application/usecase/UserMyPageUseCase.java +++ b/src/main/java/com/postgraduate/domain/user/application/usecase/UserMyPageUseCase.java @@ -1,7 +1,9 @@ package com.postgraduate.domain.user.application.usecase; +import com.postgraduate.domain.user.application.dto.req.UserHopeRequest; import com.postgraduate.domain.user.application.dto.res.UserInfoResponse; import com.postgraduate.domain.user.application.mapper.UserMapper; +import com.postgraduate.domain.user.domain.entity.Hope; import com.postgraduate.domain.user.domain.entity.User; import com.postgraduate.domain.user.domain.service.UserGetService; import com.postgraduate.domain.user.domain.service.UserUpdateService; @@ -28,6 +30,11 @@ public void updateProfile(User user, String profile) { userUpdateService.updateProfile(user.getUserId(), profile); } + public void updateHope(User user, UserHopeRequest hopeRequest) { + Hope hope = UserMapper.mapToHope(hopeRequest); + userUpdateService.updateHope(user.getUserId(), hope); + } + public boolean duplicatedNickName(String nickName) { return userGetService.byNickName(nickName).isEmpty(); } diff --git a/src/main/java/com/postgraduate/domain/user/domain/entity/Hope.java b/src/main/java/com/postgraduate/domain/user/domain/entity/Hope.java new file mode 100644 index 00000000..7f1942e9 --- /dev/null +++ b/src/main/java/com/postgraduate/domain/user/domain/entity/Hope.java @@ -0,0 +1,20 @@ +package com.postgraduate.domain.user.domain.entity; + +import jakarta.persistence.Embeddable; +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; + +@AllArgsConstructor +@Builder +@Getter +@Embeddable +public class Hope { + private String major; + private String field; + private Boolean receive; + + public Hope() { + this.receive = false; + } +} diff --git a/src/main/java/com/postgraduate/domain/user/domain/entity/User.java b/src/main/java/com/postgraduate/domain/user/domain/entity/User.java index 4844c03d..1cbe56a8 100644 --- a/src/main/java/com/postgraduate/domain/user/domain/entity/User.java +++ b/src/main/java/com/postgraduate/domain/user/domain/entity/User.java @@ -23,12 +23,14 @@ public class User { @Column(nullable = false, unique = true) private Long socialId; -// @Column(unique = true) email은 여러 소셜을 사용하면 unique가 깨질 수 있음 private String email; @Column(nullable = false, unique = true) private String nickName; + @Column(nullable = false) + private String phoneNumber; + @Column(nullable = false) @Builder.Default //이후에 기본 이미지 생기면 수정이 필요할 듯 private String profile = "default"; @@ -41,6 +43,9 @@ public class User { @Builder.Default private Role role = Role.USER; + @Embedded + private Hope hope; + @Column(nullable = false) @CreationTimestamp private LocalDate createdAt; @@ -59,4 +64,8 @@ public void updateRole(Role role) { public void updateProfile(String profile) { this.profile = profile; } + + public void updateHope(Hope hope) { + this.hope = hope; + } } diff --git a/src/main/java/com/postgraduate/domain/user/domain/service/UserUpdateService.java b/src/main/java/com/postgraduate/domain/user/domain/service/UserUpdateService.java index 00865680..0c153547 100644 --- a/src/main/java/com/postgraduate/domain/user/domain/service/UserUpdateService.java +++ b/src/main/java/com/postgraduate/domain/user/domain/service/UserUpdateService.java @@ -1,5 +1,6 @@ package com.postgraduate.domain.user.domain.service; +import com.postgraduate.domain.user.domain.entity.Hope; import com.postgraduate.domain.user.domain.entity.User; import com.postgraduate.domain.user.domain.entity.constant.Role; import com.postgraduate.domain.user.domain.repository.UserRepository; @@ -25,4 +26,9 @@ public void updateProfile(Long userId, String profile) { User user = userRepository.findById(userId).get(); user.updateProfile(profile); } + + public void updateHope(Long userId, Hope hope) { + User user = userRepository.findById(userId).get(); + user.updateHope(hope); + } } diff --git a/src/main/java/com/postgraduate/domain/user/presentation/UserController.java b/src/main/java/com/postgraduate/domain/user/presentation/UserController.java index 273c4905..9c7862fe 100644 --- a/src/main/java/com/postgraduate/domain/user/presentation/UserController.java +++ b/src/main/java/com/postgraduate/domain/user/presentation/UserController.java @@ -1,5 +1,6 @@ package com.postgraduate.domain.user.presentation; +import com.postgraduate.domain.user.application.dto.req.UserHopeRequest; import com.postgraduate.domain.user.application.dto.req.UserNickNameRequest; import com.postgraduate.domain.user.application.dto.req.UserProfileRequest; import com.postgraduate.domain.user.application.dto.res.UserInfoResponse; @@ -50,4 +51,11 @@ public ResponseDto updateProfile(@AuthenticationPrincipal User user, @RequestBod myPageUseCase.updateProfile(user, userProfileRequest.getProfile()); return ResponseDto.create(USER_UPDATE.getCode(), UPDATE_USER_INFO.getMessage()); } + + @PatchMapping("/hope") + @Operation(description = "대학생 희망 학과, 분야 및 수신 동의 업데이트") + public ResponseDto updateHope(@AuthenticationPrincipal User user, @RequestBody UserHopeRequest userHopeRequest) { + myPageUseCase.updateHope(user, userHopeRequest); + return ResponseDto.create(USER_UPDATE.getCode(), UPDATE_USER_INFO.getMessage()); + } } From 0d5629d18024e35ac2a6e17c560f302f85f1f29c Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 19:02:26 +0900 Subject: [PATCH 5/8] =?UTF-8?q?RAC-146=20style=20:=20=EC=A3=BC=EC=84=9D=20?= =?UTF-8?q?=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../dto/ExpectedMentoringInfo.java | 21 +------------------ 1 file changed, 1 insertion(+), 20 deletions(-) diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java index 73130394..97a33994 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/ExpectedMentoringInfo.java @@ -19,23 +19,4 @@ public class ExpectedMentoringInfo { String date; int term; String chatLink; -} - -/** - * 2. 진행예정 탭: <확정대기> 탭에 있던 멘토링 중, 대학원생 선배가 멘토링을 수락한 것이 <진행예정> 탭으로 이동. - * 다음은 멘토링 리스트 각각에 들어가는 항목임. - * - * 1) 멘토링 정보 노출: 대학원생 선배 정보 - [대학원생 선배 닉네임], [대학원], [연구실분야], [교수님], [대학원생 선배가 선택한 멘토링 시간], [멘토링 가능한 시간 옵션 - 1차 배포에서는 40분으로 고정] 텍스트 형태로 노출. - * * 정보 노출 형태 - * 닉네임: 000 선배와 멘토링 - * 대학원 | 연구실분야 | 교수님 - * 대학원생 선배가 선택한 멘토링 시간: 0000년 00월 00일 00시 - * - * 2) 대학원 선배 오픈채팅방 링크 + 복사 기능 - * 대학원 선배 오픈채팅방 링크가 텍스트 형태로 적혀 있고, 그 옆에 [복사] 버튼이 있음. [복사] 버튼을 누르면 오픈채팅방 링크가 복사됨. - * - * 3) [멘토링 진행 완료하기] 버튼 - * 해당 버튼을 누르면 <진행예정> 탭에 있던 멘토링이 <완료> 탭으로 이동. 해당 버튼은 사전에 예정된 멘토링 시간이 지나면 새롭게 생겨남. - * - * 4) 대학원생 선배 프로필 연결 링크 - */ \ No newline at end of file +} \ No newline at end of file From a3568441ef53887b84e7038b6372920e29d2a99f Mon Sep 17 00:00:00 2001 From: yang Date: Sat, 11 Nov 2023 19:17:32 +0900 Subject: [PATCH 6/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EC=84=A0=EB=B0=B0?= =?UTF-8?q?=20=ED=94=84=EB=A1=9C=ED=95=84=20=EC=A0=95=EB=B3=B4=20=EC=88=98?= =?UTF-8?q?=EC=A0=95=20=EB=A6=AC=ED=8C=A9=ED=86=A0=EB=A7=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../application/dto/req/SeniorProfileAndAccountRequest.java | 2 -- .../domain/senior/application/mapper/SeniorMapper.java | 1 - .../postgraduate/domain/senior/domain/entity/Account.java | 5 +++++ .../com/postgraduate/domain/senior/domain/entity/Senior.java | 2 +- .../senior/presentation/constant/SeniorResponseMessage.java | 2 +- 5 files changed, 7 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java index e79d8b5a..2aeb7c19 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java +++ b/src/main/java/com/postgraduate/domain/senior/application/dto/req/SeniorProfileAndAccountRequest.java @@ -25,6 +25,4 @@ public class SeniorProfileAndAccountRequest { private String account; @NotNull private String bank; - @NotNull - private String rrn; } diff --git a/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java b/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java index bd5c670f..6affd8bc 100644 --- a/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java +++ b/src/main/java/com/postgraduate/domain/senior/application/mapper/SeniorMapper.java @@ -46,7 +46,6 @@ public static Account mapToAccount(SeniorProfileAndAccountRequest profileAndAcco return Account.builder() .bank(profileAndAccountPageRequest.getBank()) .account(profileAndAccountPageRequest.getAccount()) - .rrn(profileAndAccountPageRequest.getRrn()) .build(); } diff --git a/src/main/java/com/postgraduate/domain/senior/domain/entity/Account.java b/src/main/java/com/postgraduate/domain/senior/domain/entity/Account.java index 80e1ef48..9ae638f1 100644 --- a/src/main/java/com/postgraduate/domain/senior/domain/entity/Account.java +++ b/src/main/java/com/postgraduate/domain/senior/domain/entity/Account.java @@ -21,4 +21,9 @@ public class Account { @Column(nullable = false) private String rrn; + + public void updateAccount(Account account) { + this.account = account.getAccount(); + this.bank = account.getBank(); + } } diff --git a/src/main/java/com/postgraduate/domain/senior/domain/entity/Senior.java b/src/main/java/com/postgraduate/domain/senior/domain/entity/Senior.java index 35bf55b6..c1ae9e96 100644 --- a/src/main/java/com/postgraduate/domain/senior/domain/entity/Senior.java +++ b/src/main/java/com/postgraduate/domain/senior/domain/entity/Senior.java @@ -51,7 +51,7 @@ public void updateProfile(Profile profile) { public void updateProfileAndAccount(Profile profile, Account account) { this.profile = profile; - this.account = account; + account.updateAccount(account); } public void updateCertification(String certification) { diff --git a/src/main/java/com/postgraduate/domain/senior/presentation/constant/SeniorResponseMessage.java b/src/main/java/com/postgraduate/domain/senior/presentation/constant/SeniorResponseMessage.java index 654f4108..60322dfe 100644 --- a/src/main/java/com/postgraduate/domain/senior/presentation/constant/SeniorResponseMessage.java +++ b/src/main/java/com/postgraduate/domain/senior/presentation/constant/SeniorResponseMessage.java @@ -7,7 +7,7 @@ @RequiredArgsConstructor public enum SeniorResponseMessage { CREATE_SENIOR("대학원생 가입에 성공하였습니다."), - UPDATE_PROFILE("대학원생 프로필 등록에 성공하였습니다"), + UPDATE_PROFILE("대학원생 프로필 수정에 성공하였습니다"), GET_SENIOR_INFO("대학원생 정보 조회에 성공하였습니다"), GET_SENIOR_PROFILE("대학원생 프로필 조회에 성공하였습니다"), UPDATE_CERTIFICATION("대학원생 인증사진 업로드에 성공하였습니다"), From b6d2f7ed877a79c83ae32aedcc337610adffb242 Mon Sep 17 00:00:00 2001 From: yang Date: Sun, 12 Nov 2023 16:31:07 +0900 Subject: [PATCH 7/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EB=B3=80=EC=88=98?= =?UTF-8?q?=EB=AA=85=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../mentoring/application/dto/res/AppliedMentoringResponse.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java index b7b6d459..e32b6d93 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java @@ -10,5 +10,5 @@ @Builder @AllArgsConstructor public class AppliedMentoringResponse { - List waitingMentoringInfos; + List mentoringInfos; } From 5ddf4183dd11c0842338c53231f8e89a55058e8f Mon Sep 17 00:00:00 2001 From: yang Date: Sun, 12 Nov 2023 16:31:50 +0900 Subject: [PATCH 8/8] =?UTF-8?q?RAC-146=20refactor=20:=20=EB=B3=80=EC=88=98?= =?UTF-8?q?=EB=AA=85=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../mentoring/application/dto/res/AppliedMentoringResponse.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java index e32b6d93..b1dc08aa 100644 --- a/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java +++ b/src/main/java/com/postgraduate/domain/mentoring/application/dto/res/AppliedMentoringResponse.java @@ -10,5 +10,5 @@ @Builder @AllArgsConstructor public class AppliedMentoringResponse { - List mentoringInfos; + List appliedMentoringInfos; }