Commit eedc112
authored
feat: 학교 이메일 인증으로 HomeUniversity 자동 매핑
* feat: 학교별 이메일 인증으로 HomeUniversity 자동 매핑 (#751)
- HomeUniversity에 emailDomain 컬럼 추가 (V50 마이그레이션)
- HomeUniversityRepository에 findByEmailDomain 메서드 추가
- EmailService 구현 (JavaMailSender 기반 인증 코드 발송)
- SchoolEmailService 구현 (인증 코드 발급/확인, Redis TTL 5분)
- SiteUser.verifySchool() 도메인 메서드 추가
- MyPageController에 POST /my/school-email, POST /my/school-email/confirm 엔드포인트 추가
- 어드민 HomeUniversity DTO에 emailDomain 필드 반영
* refactor: EmailService를 common/mail/MailService로 이동
email 발송은 공통 인프라 관심사이므로 별도 email 패키지 대신
common/mail 패키지로 이동
* refactor: 학교 이메일 인증 API 응답 body 제거
클라이언트가 이미 알고 있는 이메일을 응답으로 돌려줄 필요가 없으므로
SchoolEmailResponse 제거 및 반환 타입을 void로 변경
* refactor: Redis 저장 실패 시 CustomException으로 처리
RuntimeException 대신 SCHOOL_EMAIL_VERIFICATION_INFO_SAVE_FAILED
ErrorCode를 사용하여 예외 처리를 명확하게 표현
* refactor: Redis 인증 정보 역직렬화 실패 시 CORRUPTED 예외로 처리
데이터가 존재하지만 파싱 실패인 경우 REQUEST_NOT_FOUND 대신
SCHOOL_EMAIL_VERIFICATION_INFO_CORRUPTED로 명확하게 구분
* test: 학교 이메일 인증 테스트를 인하대학교(inha.edu) 기반으로 변경
* style: 테스트 Given-When-Then 주석 소문자로 통일
* feat: data.sql에 HomeUniversity email_domain 데이터 추가
* fix: CodeRabbit 리뷰 반영 - emailDomain 검증 강화 및 트랜잭션 범위 축소
- V50 마이그레이션에 기존 대학 email_domain 백필 UPDATE 추가
- AdminHomeUniversityService에 emailDomain 중복 검증 추가
- SchoolEmailService에서 이메일 발송 실패 시 Redis 보상 삭제 추가
- requestSchoolEmailVerification에서 불필요한 @transactional 제거
- extractEmailDomain에서 도메인 소문자 정규화 적용
- AdminHomeUniversity DTO의 emailDomain 검증을 @pattern으로 강화
* revert: V50 마이그레이션에서 DML 제거
* refactor: @Email 검증으로 보장된 중복 atIndex 검사 제거
* refactor: develop rebase 충돌 해결 및 테스트 코드 적용
* fix: emailDomain @SiZe 검증 추가1 parent 1bb075c commit eedc112
22 files changed
Lines changed: 462 additions & 20 deletions
File tree
- src
- main
- java/com/example/solidconnection
- admin/university
- dto
- service
- common
- exception
- mail
- siteuser
- controller
- domain
- dto
- service
- university
- domain
- repository
- resources
- db/migration
- test
- java/com/example/solidconnection
- admin/university/service
- siteuser/service
- university/fixture
- resources
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
65 | 65 | | |
66 | 66 | | |
67 | 67 | | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
68 | 71 | | |
69 | 72 | | |
70 | 73 | | |
| |||
Lines changed: 9 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| 5 | + | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
| |||
10 | 11 | | |
11 | 12 | | |
12 | 13 | | |
13 | | - | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
14 | 22 | | |
15 | 23 | | |
16 | 24 | | |
Lines changed: 4 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
8 | | - | |
| 8 | + | |
| 9 | + | |
9 | 10 | | |
10 | 11 | | |
11 | 12 | | |
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
15 | | - | |
| 16 | + | |
| 17 | + | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
Lines changed: 10 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| 5 | + | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
| |||
10 | 11 | | |
11 | 12 | | |
12 | 13 | | |
13 | | - | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
14 | 23 | | |
15 | 24 | | |
16 | 25 | | |
src/main/java/com/example/solidconnection/admin/university/service/AdminHomeUniversityService.java
Lines changed: 27 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
| |||
48 | 49 | | |
49 | 50 | | |
50 | 51 | | |
51 | | - | |
| 52 | + | |
| 53 | + | |
52 | 54 | | |
53 | 55 | | |
54 | 56 | | |
| |||
59 | 61 | | |
60 | 62 | | |
61 | 63 | | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
62 | 74 | | |
63 | 75 | | |
64 | 76 | | |
| |||
69 | 81 | | |
70 | 82 | | |
71 | 83 | | |
72 | | - | |
| 84 | + | |
| 85 | + | |
73 | 86 | | |
74 | 87 | | |
75 | 88 | | |
| |||
82 | 95 | | |
83 | 96 | | |
84 | 97 | | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
85 | 110 | | |
86 | 111 | | |
87 | 112 | | |
| |||
Lines changed: 9 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
47 | 47 | | |
48 | 48 | | |
49 | 49 | | |
| 50 | + | |
50 | 51 | | |
51 | 52 | | |
52 | 53 | | |
| |||
78 | 79 | | |
79 | 80 | | |
80 | 81 | | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
81 | 90 | | |
82 | 91 | | |
83 | 92 | | |
| |||
Lines changed: 21 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
Lines changed: 23 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
| 9 | + | |
8 | 10 | | |
| 11 | + | |
9 | 12 | | |
10 | 13 | | |
11 | 14 | | |
12 | 15 | | |
13 | 16 | | |
| 17 | + | |
14 | 18 | | |
15 | 19 | | |
16 | 20 | | |
| |||
23 | 27 | | |
24 | 28 | | |
25 | 29 | | |
| 30 | + | |
26 | 31 | | |
27 | 32 | | |
28 | 33 | | |
| |||
59 | 64 | | |
60 | 65 | | |
61 | 66 | | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
62 | 85 | | |
Lines changed: 4 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
159 | 159 | | |
160 | 160 | | |
161 | 161 | | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
162 | 166 | | |
163 | 167 | | |
164 | 168 | | |
| |||
Lines changed: 10 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
0 commit comments