4.2 KiB
4.2 KiB
- 요구사항/기존 패턴 확정: 크리에이터 커뮤니티 댓글 등록 시점에 푸시 발송 + 알림 리스트 저장 경로를 기존 FCM 이벤트 파이프라인으로 연결한다.
- QA:
CreatorCommunityService#createCommunityPostComment,FcmEvent,FcmSendListener,PushNotificationService흐름을 코드로 확인한다.
- QA:
- 딥링크 규칙 확정: 댓글 알림의 딥링크를
voiceon://community/{creatorId}?postId={postId}(테스트 환경은voiceon-test://community/{creatorId}?postId={postId})로 생성되도록 이벤트 메타를 설정한다.- QA:
FcmService.buildDeepLink(serverEnv, deepLinkValue, deepLinkId, deepLinkCommentPostId)규칙과creatorId/postId매핑을 확인한다.
- QA:
- 댓글 등록 시 알림 이벤트 구현: 댓글 작성자가 크리에이터 본인이 아닌 경우에만 크리에이터 대상
INDIVIDUAL이벤트를 발행한다.- QA: 이벤트에
category=COMMUNITY,deepLinkValue=COMMUNITY,deepLinkId=creatorId,deepLinkCommentPostId=postId,recipients=[creatorId]가 포함되는지 확인한다.
- QA: 이벤트에
- 알림 문구 메시지 키 추가: 크리에이터 커뮤니티 댓글 알림용 다국어 키를
SodaMessageSource에 추가한다.- QA: KO/EN/JA 값이 모두 존재하고
messageKey로 조회 가능해야 한다.
- QA: KO/EN/JA 값이 모두 존재하고
- 검증 실행: 수정 파일 LSP 진단, 관련 테스트, 전체 빌드 실행 후 결과를 기록한다.
- QA:
./gradlew test,./gradlew build성공.
- QA:
완료 기준 (Acceptance Criteria)
- 댓글 등록 API 호출 후(작성자 != 크리에이터)
FcmEvent가 발행되어 크리에이터에게 푸시 전송 대상이 생성된다. - 동일 이벤트로 저장되는 알림 리스트의
deepLink값이 푸시 payloaddeep_link와 동일 규칙으로 생성된다. - 댓글 알림 딥링크는 커뮤니티 전체보기 진입 경로(
community/{creatorId})를 유지하면서 대상 게시글 식별자(postId)를 포함한다. - 기존 커뮤니티 새 글 알림 및 다른 도메인 푸시 딥링크 동작에 회귀 영향이 없다.
검증 기록
1차 구현
- 무엇을:
CreatorCommunityService#createCommunityPostComment에 댓글 등록 직후 크리에이터 대상FcmEventType.INDIVIDUAL이벤트 발행 로직을 추가했다. 이벤트에는category=COMMUNITY,messageKey=creator.community.fcm.new_comment,deepLinkValue=COMMUNITY,deepLinkId=creatorId,recipients=[creatorId]를 설정했고, 크리에이터 본인 댓글은 알림을 발행하지 않도록 제외했다. 또한SodaMessageSource에creator.community.fcm.new_comment다국어 메시지를 추가했다. - 왜: 댓글 알림 수신자가 푸시 터치/알림 리스트 터치 시 동일 딥링크(
community/{creatorId})로 이동하도록, 기존 FCM 이벤트-알림 저장 공통 경로를 그대로 재사용하기 위해서다. - 어떻게:
lsp_diagnostics실행 시도: Kotlin LSP 미구성으로 실행 불가(환경 한계)./gradlew test --tests "*CreatorCommunityServiceTest"실행(성공)./gradlew test실행(성공)./gradlew build실행(성공)
2차 수정
- 무엇을: 커뮤니티 댓글 알림 딥링크에
postId를 함께 전달하도록FcmEvent에deepLinkCommentPostId를 추가하고,FcmService.buildDeepLink에서 커뮤니티 딥링크일 때?postId={postId}를 붙이도록 수정했다. 이에 맞춰CreatorCommunityService에서 댓글 등록 이벤트 발행 시deepLinkCommentPostId = postId를 설정했고,PushNotificationService도 동일 딥링크 문자열을 알림 리스트에 저장하도록 반영했다. 테스트는CreatorCommunityServiceTest,PushNotificationServiceTest를 보강했다. - 왜: 기존
community/{creatorId}만으로는 어떤 게시글의 댓글 리스트를 열어야 하는지 식별할 수 없어, 커뮤니티 전체보기 진입은 유지하면서 대상 게시글 식별자를 함께 전달하기 위해서다. - 어떻게:
lsp_diagnostics실행 시도: Kotlin LSP 미구성으로 실행 불가(환경 한계)./gradlew test --tests "*CreatorCommunityServiceTest" --tests "*PushNotificationServiceTest"실행(성공)./gradlew test실행(성공)./gradlew build실행(성공)