-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[BE] feat: 내가 받은 리뷰 보기 기능 구현 #109
Changes from all commits
f522fd7
85ddfd2
a0ab043
b08db88
4f18dda
65a7917
a8f2528
022910c
453d1f4
92ea554
f2e1a0d
bf00a66
aa87cbd
4a491fd
6fcbc6d
010db8e
3a229bb
412523e
1499f37
bdc847b
af8cf09
1fb6465
c8e3cbe
065f752
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,7 +7,6 @@ | |
import jakarta.persistence.Id; | ||
import jakarta.persistence.JoinColumn; | ||
import jakarta.persistence.ManyToOne; | ||
import jakarta.persistence.OneToOne; | ||
import jakarta.persistence.Table; | ||
import lombok.AccessLevel; | ||
import lombok.Getter; | ||
|
@@ -22,6 +21,7 @@ public class ReviewContent { | |
|
||
private static final int MIN_ANSWER_LENGTH = 20; | ||
private static final int MAX_ANSWER_LENGTH = 1_000; | ||
private static final int REVIEW_CONTENT_PREVIEW_MAX_LENGTH = 150; | ||
|
||
@Id | ||
@GeneratedValue(strategy = GenerationType.IDENTITY) | ||
|
@@ -31,11 +31,11 @@ public class ReviewContent { | |
@JoinColumn(name = "review_id", nullable = false) | ||
private Review review; | ||
|
||
@OneToOne | ||
@ManyToOne | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 요구사항대로 잘 되었네요 👍🏻 |
||
@JoinColumn(name = "question_id", nullable = false) | ||
private Question question; | ||
|
||
@Column(name = "answer", nullable = false) | ||
@Column(name = "answer", nullable = false, length = MAX_ANSWER_LENGTH) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. DB에 글자수 조건 반영 좋네요! @Entity
public class ReviewerGroup {
@Column(name = "description", nullable = false)
private String description; There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 헉스 그런데 제가 하면 혹시라도 conflict 날까봐 리팩터링 목록에 넣어두겠습니다! |
||
private String answer; | ||
|
||
public ReviewContent(Review review, Question question, String answer) { | ||
|
@@ -52,6 +52,10 @@ private void validateAnswerLength(String answer) { | |
} | ||
} | ||
|
||
public String getAnswerPreview() { | ||
return answer.substring(0, REVIEW_CONTENT_PREVIEW_MAX_LENGTH); | ||
} | ||
|
||
public String getQuestion() { | ||
return question.getContent(); | ||
} | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
package reviewme.review.dto.response; | ||
|
||
import io.swagger.v3.oas.annotations.media.Schema; | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 위쪽에 어떤 응답인지 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 헉 속성에만 추가하고, dto 자체에는 안달아줬네요 😱 |
||
@Schema(description = "선택된 키워드 응답") | ||
public record ReceivedReviewKeywordsResponse( | ||
|
||
@Schema(description = "키워드 아이디") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 다른 곳에서는 아이디를 "ID"로 표기했던 것 같은데, "아이디" 또는 "ID"로 통일해야 할 것 같아요. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 웁스 그렇네요!! 이슈 만들었습니다 |
||
long id, | ||
|
||
@Schema(description = "키워드 내용") | ||
String content | ||
) { | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
package reviewme.review.dto.response; | ||
|
||
import io.swagger.v3.oas.annotations.media.Schema; | ||
import java.time.LocalDate; | ||
import java.util.List; | ||
|
||
@Schema(description = "리뷰 내용 응답") | ||
public record ReceivedReviewResponse( | ||
|
||
@Schema(description = "리뷰 아이디") | ||
long id, | ||
|
||
@Schema(description = "공개 여부") | ||
boolean isPublic, | ||
|
||
@Schema(description = "리뷰 작성일") | ||
LocalDate createdAt, | ||
|
||
@Schema(description = "응답 내용 미리보기") | ||
String contentPreview, | ||
|
||
@Schema(description = "리뷰어 그룹 정보") | ||
ReceivedReviewReviewerGroupResponse reviewerGroup, | ||
|
||
@Schema(description = "키워드") | ||
List<ReceivedReviewKeywordsResponse> keywords | ||
) { | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
package reviewme.review.dto.response; | ||
|
||
import io.swagger.v3.oas.annotations.media.Schema; | ||
|
||
@Schema(description = "리뷰어 그룹 정보 응답") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 리뷰어 그룹 정보를 내보내는 DTO가 많기에 "리뷰 목록의 리뷰어 그룹 정보 응답"으로 컨텍스트를 추가해주는 건 어떨까요? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 스웨거에서 볼 때 JSON 안에서 감싸져서 보여질 것이기 때문에 별도의 맥락 추가는 없어도 괜찮을 것 같아요 ㅎㅎ(귀찮은 것 아님) |
||
public record ReceivedReviewReviewerGroupResponse( | ||
|
||
@Schema(description = "리뷰어 그룹 아이디") | ||
long id, | ||
|
||
@Schema(description = "리뷰어 그룹 이름") | ||
String name, | ||
|
||
@Schema(description = "리뷰어 그룹 썸네일 이미지 URL") | ||
String thumbnailUrl | ||
) { | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
package reviewme.review.dto.response; | ||
|
||
import io.swagger.v3.oas.annotations.media.Schema; | ||
import java.util.List; | ||
|
||
@Schema(description = "내가 받은 리뷰 응답") | ||
public record ReceivedReviewsResponse( | ||
|
||
@Schema(description = "응답 개수") | ||
long size, | ||
|
||
@Schema(description = "마지막 리뷰 아이디") | ||
long lastReviewId, | ||
|
||
@Schema(description = "받은 리뷰 목록") | ||
List<ReceivedReviewResponse> reviews | ||
) { | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,16 +12,20 @@ | |
import reviewme.keyword.service.KeywordService; | ||
import reviewme.member.domain.Member; | ||
import reviewme.member.domain.ReviewerGroup; | ||
import reviewme.member.dto.response.ReviewCreationReviewerGroupResponse; | ||
import reviewme.member.repository.MemberRepository; | ||
import reviewme.member.repository.ReviewerGroupRepository; | ||
import reviewme.member.service.ReviewerGroupService; | ||
import reviewme.review.domain.Question; | ||
import reviewme.review.domain.Review; | ||
import reviewme.review.domain.ReviewContent; | ||
import reviewme.review.dto.response.ReviewCreationResponse; | ||
import reviewme.review.dto.response.QuestionResponse; | ||
import reviewme.member.dto.response.ReviewCreationReviewerGroupResponse; | ||
import reviewme.review.dto.request.CreateReviewRequest; | ||
import reviewme.review.dto.response.QuestionResponse; | ||
import reviewme.review.dto.response.ReceivedReviewKeywordsResponse; | ||
import reviewme.review.dto.response.ReceivedReviewResponse; | ||
import reviewme.review.dto.response.ReceivedReviewReviewerGroupResponse; | ||
import reviewme.review.dto.response.ReceivedReviewsResponse; | ||
import reviewme.review.dto.response.ReviewCreationResponse; | ||
import reviewme.review.dto.response.ReviewDetailResponse; | ||
import reviewme.review.dto.response.ReviewDetailReviewContentResponse; | ||
import reviewme.review.dto.response.ReviewDetailReviewerGroupResponse; | ||
|
@@ -112,9 +116,57 @@ public ReviewDetailResponse findReview(long reviewId, long memberId) { | |
|
||
@Transactional(readOnly = true) | ||
public ReviewCreationResponse findReviewCreationSetup(long reviewerGroupId) { | ||
ReviewCreationReviewerGroupResponse reviewerGroup = reviewerGroupService.findReviewCreationReviewerGroup(reviewerGroupId); | ||
ReviewCreationReviewerGroupResponse reviewerGroup = reviewerGroupService.findReviewCreationReviewerGroup( | ||
reviewerGroupId); | ||
List<QuestionResponse> questions = questionService.findAllQuestions(); | ||
List<KeywordResponse> keywords = keywordService.findAllKeywords(); | ||
return new ReviewCreationResponse(reviewerGroup, questions, keywords); | ||
} | ||
|
||
@Transactional(readOnly = true) | ||
public ReceivedReviewsResponse findMyReceivedReview(long memberId, Long lastReviewId, int size) { | ||
List<Review> reviews = reviewRepository.findLimitedReviewsWrittenForReviewee(memberId, lastReviewId, size); | ||
|
||
if (reviews.isEmpty()) { | ||
return new ReceivedReviewsResponse(0, 0, List.of()); | ||
} | ||
|
||
return new ReceivedReviewsResponse( | ||
reviews.size(), | ||
reviews.get(reviews.size() - 1).getId(), | ||
reviews.stream() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 인덴트가 많아지니 따로 변수로 뽑아도 좋겠네요! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 음 new XXXResponse 들이 다 map 안에서 사용되는 것들이라 분리한다면 함수로 분리해줘야 할 것 같네요! 일단 private 함수로 만들어주긴 했는데, 서비스 코드에서 dto 를 만들기 위해 필요한 함수가 많아져서 dto 안에 도메인 -> dto 함수를 만드는 것도 고려해볼 수 있는 시점 같아요 |
||
.map(this::createReceivedReviewResponse) | ||
.toList()); | ||
} | ||
|
||
private ReceivedReviewResponse createReceivedReviewResponse(Review review) { | ||
return new ReceivedReviewResponse( | ||
review.getId(), | ||
review.isPublic(), | ||
review.getCreatedAt().toLocalDate(), | ||
createReviewContentPreview(review), | ||
new ReceivedReviewReviewerGroupResponse( | ||
review.getReviewerGroup().getId(), | ||
review.getReviewerGroup().getGroupName(), | ||
review.getReviewerGroup().getThumbnailUrl() | ||
), | ||
createKeywordResponse(review)); | ||
} | ||
|
||
private String createReviewContentPreview(Review review) { | ||
return reviewContentRepository.findAllByReviewId(review.getId()) | ||
.get(0) | ||
.getAnswerPreview(); | ||
} | ||
|
||
private List<ReceivedReviewKeywordsResponse> createKeywordResponse(Review review) { | ||
return review.getKeywords().getKeywordIds() | ||
.stream() | ||
.map(keywordRepository::getKeywordById) | ||
.map(keyword -> new ReceivedReviewKeywordsResponse( | ||
keyword.getId(), | ||
keyword.getContent() | ||
)) | ||
.toList(); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
우선은 그냥 단순히 특정 회원의 리뷰만 조회한다고 생각하면 될까요?
(누구든지 memberId를 넣으면 다른 사람의 리뷰를 조회 가능!)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
그춍.. 사실 목표한 기능은 '내가 받은 리뷰 보기'이지만
로그인 기능이 없고, memberId 로 로그인한다고 가정하고 있는 상황이니깐요😓
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
다음 리팩터링 사항 논의 때 고려해보죠~