-
Notifications
You must be signed in to change notification settings - Fork 0
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
Feat: 마이페이지 마크업 #14
Feat: 마이페이지 마크업 #14
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.
약간의 설명이 필요한 부분이 있다고 판단되어 리뷰 남겨놓았습니다!
<span className='py-2'> | ||
<SubscribeButton isSubscribed={brand.subscribed} /> | ||
</span> | ||
<DomainListItem domainData={domain} isSubscribed={domain.isSubscribed} /> |
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.
이 부분은 중복되는 UI 로직이 있어서 DomainListItem으로 뺐습니다
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.
확인해보고 싶어서 서버 켜봤는데 오류뜨는지라... ㅜ 확인이 쉽지않네요 ㅎㅎ..
나중에 다시 확인해보겠습니당
//TODO: 추후 로그인 로직 완성 후 주석 교체 | ||
const userData: UserDataType = await getUserData(); | ||
// const userData = cookies().get('userData'); | ||
|
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.
UserDataCard에서 유저의 정보(이름, 이메일, 태그 유형, 프로필사진)를 받아오기 위해
- API 호출을 해야하는가
- 저장소에서 가져와야하는가
에서 2번을 선택했는데, next의 SSR특성상 localStorage에는 접근할 수 없어서
유저 정보를 로그인하면 쿠키에 저장하고, 필요한 곳에서 쿠키를 꺼내어 쓰는거로 설계를 했는데요,
혹시 이해가 안가는 부분이나, 더 나은 방법이 있다면 말씀주세요!
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.
네이밍을 DomainListTap에서 AlternateListTap으로 변경했는데요,
ListTap이 /main
에서는 n개의 ListItem
을 가지고, 나머지에서는 1개를 가지는 공통점이 있어서
부모에서 props를 통해 tapName
과 tapCount
를 내려주는것으로 설계를 변경했습니다
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.
이 부분도 제대로 확인은 못했는데, 나중에 다시 확인해보고 답변드리겠습니다!
src/middleware.ts
Outdated
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.
Next.js공식 문서를 보고 middleware
를 사용하여 protected route
를 구현하려 합니다.
현재 로그인 로직의 설계가 어떻게 될지 트래킹을 하고 있지 않아서, 주석을 통해 간단한 설명을 적어놓긴했으나,
조금 더 자세히 설명드리기 위해 리뷰 남겨놓아요!
마이페이지 마크업을 하면서 최소 로직에 대한 구현도 같이 했는데, 위의 src/app/mypage/UserDataCard.tsx
파일의 comment에서 설명했듯, 쿠키를 통한 userData 보관 및 사용을 하도록 설계했습니다.
이를 위해 로그인이 끝나면 next/server
의 cookies
를 통해 쿠키에 user의 profile데이터를 삽입해주시면 됩니다.
이후, 어떠한 이유에 의해 (테스트/ 버그 등등...) 로그아웃을 누르지 않았지만 쿠키가 삭제되는 경우,
middleware를 통해 cookie의 값을 확인하고 만약 없다면,
- accessToken이 있다면 다시 로그인을 시도합니다.
- 1이 없거나, 로그인에 실패하는 경우 로그아웃 로직을 실행하고, 메인페이지로 쫓아냅니다
의 로직을 실행합니다.
또한, 가장 아래의 config는 matcher에 해당하는 파일에 대해서 middleware를 실행하게 되는데,
현재 테스트상으로는 MSW와 충돌하지는 않지만, MSW가 api를 가로채갈 때 middleware가 실행되는것을 5번줄을 통해 확인할 수 있었습니다.
그래서 matcher에 MSW 파일을 제거해야하나 싶었지만, 이후 api를 보낼 때 쿠키값을 확인하고자 한다면 이를 활용할 수도 있을 것 같아서 남겨놓긴했습니다.
만약 해당 기능이 필요없다고 판단되시면 matcher에 msw파일 경로도 추가해주시면 될 것 같습니다!
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.
@moong23 빠르게 마크업 작업 해주셨군요! 감사합니다👍👍
코멘트에 남겨주셨던 부분 중, 인증인가 관련한 부분에 대해 답변을 조금 길게 남길 것 같습니다.
우선 현재 서버사이드렌더를 하여 구독 관리나 프로필 UI를 띄워주고 있는데, 이 부분에서 조금 의문이 드는게 몇가지 있습니다.
1
첫 번째로, 근본적으로 이 부분을 SSR로 가져가야 하는가? 라는 의문이 들더라구요.
우선 이 페이지는 사용자가 이미 로그인을 한 뒤, 개인정보가 들어가는 페이지인지라, SEO를 고려할 이유가 없습니다.
그럼 우리가 SSR을 사용하여 얻을 수 있는 장점은 초기 fetch 시에 렌더가 되는 시간을 단축할 수 있다는 점이 가장 크지 않을까 싶습니다.
문제는 우리 백엔드가 지메일API를 쓰고 있다는 점입니다.
대충 플로우는 이렇게 될텐데, 백엔드에서도 지메일쪽 API를 거쳐서 데이터를 받아와야 하기에 결코 가벼운 작업이 아닙니다.
이렇게 되면 api응답시간이 길어질 확률이 높은데, 지금같이 SSR을 유지하게 되면 API응답 속도 자체가 느려 사용자가 아예 빈 페이지를 보는 시간이 늘어나지 않을까 하는 생각이 들더라구요.
이렇게 될거라면 차라리 클라이언트 컴포넌트로 변경해서 Suspense 묶고 로딩스피너를 띄워주는게 더 UX적으로 괜찮지 않을까? 하는 생각이 들었습니다.
프로필 가져오는 부분도 Suspense로 묶어서 같이요!
이 부분에 대해서는 어떻게 생각하시는지 궁금합니다!
2
둘째로, 유저의 정보를 받아오는 부분에 대해서도 조금 맘에 걸리는 부분이 있습니다.
실제로 저장소에 저장하여 가져오는 로직을 작성한 이유가 http트랜잭션을 한번 줄이기 위해서가 아닐까 싶습니다.
그런데 이 부분은 백엔드측에서도 user테이블에서 데이터를 가져올테니 join이 있을 수 없는 select작업일테고, 비용보다는 데이터의 무결성이 조금 더 중요하지 않을까 하는 생각이 들었습니다. (밑에서 다시 이야기했습니다)
만약 그럼에도 서버측에서 유저데이터를 받아서 저장하고 싶다면, next자체 fetch를 사용하는 방법도 있을 것 같습니다!
3
아니면 이건 저도 안해보긴 했는데, streaming HTML이라고, 페이지 단위가 아닌 컴포넌트 단위로 SSR요청을 할 수 있는게 있는 것 같더라구요.
서버 컴포넌트에 데이터 페칭이 없는 애를 먼저 만들고, 그 서버 컴포넌트 안에 suspense가 걸려있도록
하며, suspense 안에는 데이터를 페칭하는 서버 컴포넌트를 각각 주입하는 방식으로 하는 것 같더라구요!
폴백에는 로딩스피너 넣구요 ㅎㅎ
꼭 이게 좋다는건 아니니 가볍게 한번 보시면 좋을 것 같아 관련 링크 하나 남겨봅니다..! (저도 안해봤습니다 ㅋㅋ)
React 18: Streaming HTML and Selective Hydration 부분입니다
reactwg/react-18#37
4
인증인가 방식 세션방식으로 확정됐습니다..!
토큰 안할것같아용
<span className='py-2'> | ||
<SubscribeButton isSubscribed={brand.subscribed} /> | ||
</span> | ||
<DomainListItem domainData={domain} isSubscribed={domain.isSubscribed} /> |
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.
확인해보고 싶어서 서버 켜봤는데 오류뜨는지라... ㅜ 확인이 쉽지않네요 ㅎㅎ..
나중에 다시 확인해보겠습니당
//TODO: 추후 로그인 로직 완성 후 주석 교체 | ||
const userData: UserDataType = await getUserData(); | ||
// const userData = cookies().get('userData'); | ||
|
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.
이 부분도 제대로 확인은 못했는데, 나중에 다시 확인해보고 답변드리겠습니다!
src/middleware.ts
Outdated
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.
이 부분도 한번에 댓글 남길게요!
빠른 리뷰 고마워요~! 어제 구현하면서 next에 대한 이해가 조금은 부족한것 같아서 next.js의 공식 문서를 읽으면서 조금의 개선사항에 대해 생각이 든 부분을 남겨놓겠습니다! 1. SSR으로 가져가야 하는가-> 해당 부분에대해서 문제점을 느끼고 현재 jira에 error 처리용과 loading 처리용 티켓을 끊어두었습니다! 2. 유저 데이터 fetch-> (제가 내용을 제대로 이해한것인지 모르겠습니다ㅠㅠ) 우찬님께서 말씀하신 부분은
일단은 제가 API를 호출하지 않고 저장소에 저장하여 사용해야겠다고 생각한 이유는 1, 2 : 비용이 매우 작은 작업이여서 무결성을 희생할 필요가 없는것에 동의합니다. 3. Streaming HTML안그래도 오늘 공식문서 보면서 해당 게시글을 보고 이거 쌈@뽕 하구만 하고 생각을 했죠ㅎㅎㅎ 4. Session확인했습니다~! |
@dladncks1217 어제 깜빡하고 멘션을 안했네요 ㅎㅎ |
@moong23 아아 리뷰 달려있었군요! 오늘 확인해보고 다시 리뷰 남길게요~! |
사실 어찌되었든 백엔드측에서도 DB트랜잭션이 발생한느거고, 백과 클라이언트 사이에서도 http트랜잭션이 발생하는거라 비용이 엄청 작고 그런건 아니긴 합니다 ㅎㅎ... 어제 조금 급하게 리뷰하느라 말이 앞뒤가 조금 다르게 느껴지기도 하는데요, 결론적으로는 백이랑 한번 더 통신하는것과 쿠키사용을 종합적으로 비교했을때 복잡도도 복잡도지만 이 한번을 줄이기 위해 쿠키에 데이터를 저장해서 관리한다는게 어색하게 느껴졌습니다...🥹 꼭 캐시나 쿠키같은 무언가 직접 핸들링해야하는 명확한 이유가 있다거나, 그런거 없이 할 수 있는 더 편한 방법이 있을까요!?
Streaming HTML의 경우 1번에 드렸던 답변과 이어지는거로, 이런방법도 있을 것 같다고 쓰긴 한건데 저도 한번도 안해보긴 했습니다 ㅋㅋㅋㅋ 우선 마크업은 머지하고, 코드 자체는 차차 계속 개선해가는걸로 하시죠! |
쿠키와 API 둘의 장점을 모두 수용할 수 있는 것이 next의 fetch사용이라고 생각되네요! fetch를 사용하고, cache control을 하는것이 현재 생각나는 방안중에는 최선의 방법으로 생각되네요! 로직을 fetch로 바꾼다고 해도 인증인가 구현하고나면 매우 높은 확률로 해당 Fetch 로직도 변경되야할것같아서 |
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.
고생하셨습니다 👍
Why need this PR❓
마이페이지 마크업
https://inspomailclub.atlassian.net/jira/software/projects/INSPO/boards/1/timeline?selectedIssue=INSPO-46
Changes ✌️
Screenshoot 🌅 (optional)
/mypage
/mypage/subscribe