-
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] docs: GitHub 연동, 자신이 만든 리뷰 그룹 목록 조회 API 문서 작성 #1014
base: develop
Are you sure you want to change the base?
Conversation
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.
아루를 위한 보충 설명
backend/src/main/java/reviewme/auth/controller/AuthController.java
Outdated
Show resolved
Hide resolved
backend/src/main/java/reviewme/member/controller/MemberController.java
Outdated
Show resolved
Hide resolved
backend/src/main/java/reviewme/reviewgroup/controller/ReviewGroupController.java
Outdated
Show resolved
Hide resolved
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.
아루 산쵸 몇개 질문 남겨요~~🔎
backend/src/main/java/reviewme/reviewgroup/service/dto/ReviewGroupDetailResponse.java
Outdated
Show resolved
Hide resolved
backend/src/main/java/reviewme/auth/controller/AuthController.java
Outdated
Show resolved
Hide resolved
backend/src/main/java/reviewme/reviewgroup/service/dto/ReviewGroupListResponse.java
Outdated
Show resolved
Hide resolved
@PostMapping("/v2/auth/github") | ||
public ResponseEntity<Void> authWithGithub( | ||
@Valid @RequestBody GithubCodeRequest request, | ||
HttpServletRequest httpRequest | ||
) { | ||
return ResponseEntity.ok().build(); | ||
} |
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.
산초가 올려준 디스커션의 인증 과정중 아래의 1~3번을 이 메서드에서 모두 하는것인지 궁금해요!(아직 구현이 안해서 헷갈려서 물어봅니당)
- auth code를 받음
- 그걸로 깃헙에 accessToken을 요청함
- 받은 accessToken으로 깃헙에 사용자의 정보를 요청해서 세션을 설정해 응답함
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.
네 맞아요👍
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.
혹시 이때 사용자 정보나 로그인 정보같은 것은 안내려줘도 괜찮나요?
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.
@Kimprodp
사용자 정보를 따로 넘겨주기보다, 클라이언트와는 JSESSION_ID로만 로그인한 사용자에 대한 통신을 하면 된다 생각해요!
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.
정보를 1회성으로 내려주는 게 좋을까요, 프론트에서 정보를 확인할 수 있는 API를 뚫어두는 게 좋을까요?
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.
- 1회성이라는 건: 어떤 뜻인지 잘 모르겠어요
- 프론트에서 정보를 확인할 수 있는 API: 사용자 세션을 갖고 프로필 api를 찌르게 하는 것
을 말하는 게 맞을까요? 그렇다면 저는 2번을 생각했었어요~
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.
리뷰 몇 개 남깁니다!
backend/src/main/java/reviewme/member/controller/MemberController.java
Outdated
Show resolved
Hide resolved
backend/src/main/java/reviewme/reviewgroup/service/dto/ReviewGroupListResponse.java
Outdated
Show resolved
Hide resolved
String projectName, | ||
LocalDate createdAt, | ||
String reviewRequestCode | ||
) { |
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.
프로젝트 목록에서 해당 프로젝트에 리뷰가 몇 개 작성되어있는지도 같이 제공하면 어떨까요?
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.
오~ 괜찮은데요? 이건 프론트 분들이랑 이야기를 해봐야 할 것 같아요!
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.
리뷰 확인 및 추가 코멘트 남겼어요 확인 부탁합니다(__)
backend/src/main/java/reviewme/reviewgroup/service/dto/ReviewGroupListResponse.java
Outdated
Show resolved
Hide resolved
|
||
import java.util.List; | ||
|
||
public record ReviewGroupListResponse( |
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 필드에 추가하는 건 어떻게 생각하시나요?
#1017 (comment)
저희가 작업한 dto와 같은 이유입니다~
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.
음 이거에 대해서 다시 생각해봤는데, 불필요한 응답 같다고 다시 생각을 바꾸게 되었어요///😔
#1017 (comment)
여기에 코멘트 달아놨습니다!
@PostMapping("/v2/auth/github") | ||
public ResponseEntity<Void> authWithGithub( | ||
@Valid @RequestBody GithubCodeRequest request, | ||
HttpServletRequest httpRequest | ||
) { | ||
return ResponseEntity.ok().build(); | ||
} |
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.
혹시 이때 사용자 정보나 로그인 정보같은 것은 안내려줘도 괜찮나요?
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.
이전에 수정한 케이스랑 동일한게 있어서 하나만 더 확인해주십쇼
@@ -48,4 +49,11 @@ public ResponseEntity<Void> checkGroupAccessCode( | |||
session.setAttribute("reviewRequestCode", request.reviewRequestCode()); | |||
return ResponseEntity.noContent().build(); | |||
} | |||
|
|||
@GetMapping("/v2/groups/mine") | |||
public ResponseEntity<ReviewGroupPageResponse> getMyReviewGroups() { |
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.
#1014 (comment)
같은 이유입니다~
getReviewGroupSummary의 api를 /groups/summary
로 하고,
여기에는 mine을 빼고 /groups
까지만 하는 것이 괜찮아 보입니다.
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.
GET /groups
는 그룹 자체에 대한 정보에 더 가깝다고 생각합니다.
'내가 만든 리뷰 그룹'을 나타내기에는 조금 부족하다는 생각이 드는데,
/v2/groups/authored
는 어떤가요?
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.
GET /groups 복수 이기 때문에 목록에 대한 의미가 더 가깝지 않나요?
만약 개별 그룹 자체에 대한 의미라면 GET /groups/{id} 형식이 된다고 생각해요.
그리고 그룹 목록을 조회하는데 /groups/authored 까지 하면 불필요하게 뎁스가 하나 더 추가 된다고 생각해요.
세션을 통해 로그인 사용자는 식별되니 /groups 만으로 충분하다 생각합니다.
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.
현재는 내가 만든 리뷰 그룹밖에 없는데 리뷰 그룹과 관련한 다른 api가 추가될지 몰라요. (예: 내가 참여한 리뷰 그룹)
그렇다면 기존 api uri까지 바꿔야하는 상황(이번에 내가 받은 리뷰만 있었는데 내가 작성한 리뷰가 생겨서 기존 api의 uri도 바뀜)을 지양하려면 구체적인 맥락을 uri에 추가해줘야한다고 생각해요
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.
커비 의견에 완전 동의하구요! 덧붙이자면 내가 작성한 리뷰를 /reviews/authored 로 하면, 내가 생성란 리뷰도 /groups/authored 가져가는게 더 통일감있다 느껴집니다.
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.
api를 한 번 정하면 수정할 때 많은 협의가 필요하니 신중하네요..
사실 현재 구조들은 자원의 계층을 나타내는 것이 아니라, 동일한 자원에 대해 조건에 따라서 뎁스가 붙는 경우라서 옳은 방식인지 조금 헷갈려요. 구체적인 맥락이 중요하다면 지금 방식이 아니라 자원의 계층적 구조를 더 명확하게 해서 /me/authored/reviews
와 같은 형식으로 하는 것이 맞지 않나? 생각도 듭니다.
예를 들면 현재 구조는 세션을 통해서 검증하고는 있지만, 세션은 권한에 대한 인증 방법이고 api 자체로는 어떤 자원의 리소스를 호출하는지 모르기 때문에 현재 로그인된 사용자뿐만 아니라 다른 사용자의 데이터를 처리할 수도 있을 것 같다는 생각이 들어요.
무튼, 이미 다른 api들이 이렇게 되어있으니 일단은 통일성 있게 가져가는 것을 우선시 할게요.
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.
동감해요. 리소스 측면에서 바라보면 /groups가 그룹들을 가져올 것을 이미 충분히 기대할 수 있다고 생각해요. 더 specific한 건 쿼리 파라미터로 나타내면 되고요.
@@ -48,4 +49,11 @@ public ResponseEntity<Void> checkGroupAccessCode( | |||
session.setAttribute("reviewRequestCode", request.reviewRequestCode()); | |||
return ResponseEntity.noContent().build(); | |||
} | |||
|
|||
@GetMapping("/v2/groups/mine") | |||
public ResponseEntity<ReviewGroupPageResponse> getMyReviewGroups() { |
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.
GET /groups 복수 이기 때문에 목록에 대한 의미가 더 가깝지 않나요?
만약 개별 그룹 자체에 대한 의미라면 GET /groups/{id} 형식이 된다고 생각해요.
그리고 그룹 목록을 조회하는데 /groups/authored 까지 하면 불필요하게 뎁스가 하나 더 추가 된다고 생각해요.
세션을 통해 로그인 사용자는 식별되니 /groups 만으로 충분하다 생각합니다.
아직 안 됐습니다~
우선 나의 리뷰 그룹 목록 보기만 만들어두었어요
🚀 어떤 기능을 구현했나요 ?
📝 어떤 부분에 집중해서 리뷰해야 할까요?