Conversation
Summary of ChangesHello @AlphaBs, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed! 이 PR은 코드베이스의 전반적인 리팩토링을 목표로 합니다. 특히, 관리자 및 개발용 API의 설명을 명확히 하고, Google OAuth 인증 흐름의 로직을 서비스 계층으로 이동하여 컨트롤러의 역할을 간소화했습니다. 또한, 개발용 인증 컨트롤러의 기능을 재구성하여 테스트 사용자 관리 및 토큰 발급 과정을 보다 체계적으로 만들었습니다. 이러한 변경사항은 코드의 가독성, 유지보수성 및 책임 분리를 개선하는 데 기여합니다. Highlights
Using Gemini Code AssistThe full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips. Invoking Gemini You can request assistance from Gemini at any point by creating a comment using either
Customization To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a Limitations & Feedback Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here. You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension. Footnotes
|
| @RequestMapping("/auth/dev") | ||
| @RequiredArgsConstructor | ||
| @ConditionalOnProperty(name = "app.dev-auth.enabled", havingValue = "true", matchIfMissing = false) | ||
| public class DevAuthController { |
There was a problem hiding this comment.
@ConditionalOnProperty 애노테이션이 제거되어 DevAuthController가 항상 활성화되도록 변경되었습니다. 이 컨트롤러는 테스트용 계정 생성 및 토큰 발급과 같은 개발용 기능을 제공하므로, 프로덕션 환경에 배포될 경우 심각한 보안 취약점이 될 수 있습니다. 프로덕션 환경에서는 이 컨트롤러가 비활성화되도록 app.dev-auth.enabled 프로퍼티를 사용하여 조건부로 활성화하는 기존 로직을 복원하는 것을 강력히 권장합니다.
| public class DevAuthController { | |
| @ConditionalOnProperty(name = "app.dev-auth.enabled", havingValue = "true", matchIfMissing = false) | |
| public class DevAuthController { |
| }); | ||
| isNewUser = user.getId() == null; | ||
| } | ||
| @RequestParam(required = false) Long userId) { |
There was a problem hiding this comment.
issueDevToken 메소드의 userId 파라미터가 @RequestParam(required = false)로 설정되어 있어 선택적으로 전달할 수 있습니다. 하지만 userId가 전달되지 않으면 findExistingDevUser 메소드에서 MEMBER_NOT_FOUND 예외가 발생합니다. 이 API의 목적이 "존재하는 userId로 JWT 토큰을 발급"하는 것이므로, userId는 필수 파라미터로 변경하는 것이 논리적으로 맞습니다. 이렇게 하면 API 사용자가 파라미터를 누락했을 때 더 명확한 에러 메시지를 받을 수 있습니다.
| @RequestParam(required = false) Long userId) { | |
| @RequestParam Long userId) { |
| private User createTestUser() { | ||
| User testUser = User.builder() | ||
| .googleId("dev-test-user") | ||
| .email("test@dev.local") | ||
| .googleId("dev-test-user-" + UUID.randomUUID()) | ||
| .email("test" + UUID.randomUUID() + "@dev.local") | ||
| .name("테스트유저") | ||
| .profileImage(null) | ||
| .role(role) | ||
| .role(Role.USER) | ||
| .build(); | ||
| return userRepository.save(testUser); | ||
| } |
There was a problem hiding this comment.
createTestUser 메소드에서 UUID.randomUUID()가 두 번 호출되어 googleId와 email에 서로 다른 UUID가 사용됩니다. 이는 기능적으로 큰 문제는 아니지만, 일관성을 위해 하나의 UUID를 생성하여 두 필드에 모두 사용하는 것이 좋습니다.
| private User createTestUser() { | |
| User testUser = User.builder() | |
| .googleId("dev-test-user") | |
| .email("test@dev.local") | |
| .googleId("dev-test-user-" + UUID.randomUUID()) | |
| .email("test" + UUID.randomUUID() + "@dev.local") | |
| .name("테스트유저") | |
| .profileImage(null) | |
| .role(role) | |
| .role(Role.USER) | |
| .build(); | |
| return userRepository.save(testUser); | |
| } | |
| private User createTestUser() { | |
| String uniqueId = UUID.randomUUID().toString(); | |
| User testUser = User.builder() | |
| .googleId("dev-test-user-" + uniqueId) | |
| .email("test" + uniqueId + "@dev.local") | |
| .name("테스트유저") | |
| .profileImage(null) | |
| .role(Role.USER) | |
| .build(); | |
| return userRepository.save(testUser); | |
| } |
작업 내용
변경 사항
관련 이슈
closes #