Skip to content
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: fcm 푸시 알림 스케줄러에 등록 #89

Merged
merged 16 commits into from
Nov 10, 2024
Merged

Conversation

kimyu0218
Copy link
Collaborator

@kimyu0218 kimyu0218 commented Nov 7, 2024

Issue Number

close: #

작업 개요

(#84 구현중)
스케줄러가 필요한 푸시 알림 구현

작업 사항

  • job이 많아져서 job 로깅 로직을 aop에 구현했습니다
  • 푸시 관련 job들을 정의했습니다
    • 미션 시작 예고 MissionReadyPushJob
    • 미션 취소 예고 MissionCancellationWarningPushJob
    • 미션 인증 MissionVerificationPushJob
    • 미션 인증 마감 예고 MissionVerificationWarningPushJob

고민한 점들(필수 X)

  • 미션 독려 알림(미션 종료 7일 후)은 아직 어떻게 구현할지 고민중입니다.
  • hasEnoughMember 함수를 중복해서 정의하고 있는데 어떻게 개선할지 고민입니다.

스크린샷(필수 X)

@kimyu0218 kimyu0218 requested a review from songyi00 as a code owner November 7, 2024 09:39
@kimyu0218 kimyu0218 changed the title Feat/#84 fcm push feat: fcm 푸시 알림 스케줄러에 등록 Nov 7, 2024
@@ -21,6 +22,7 @@ public interface MissionMemberRepository extends JpaRepository<MissionMember, Lo
@Query("SELECT mm FROM MissionMember mm JOIN FETCH mm.mission WHERE mm.member.id = :memberId")
List<MissionMember> findAllWithMissionByMemberId(final Long memberId);

@Lock(LockModeType.PESSIMISTIC_WRITE)
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

미션 인증 2번 가능한 문제 해결하려고 lock 걸었습니다..!

    @Transactional
    public void createVerification(final CreateMissionVerificationCommand command) {
        MissionMember missionMember = missionMemberRepository.getMissionMember(command.memberId(), command.missionId());

        missionVerificationValidator.validate(missionMember);

        String imageUrl = objectStorageClient.uploadFile(command.imageFile());
        missionMember.verify();
        missionVerificationRepository.save(new MissionVerification(missionMember.getMember(), missionMember.getMission(), imageUrl, missionMember.getVerificationCount()));
    }

커넥션이 여러 개라서 2개 이상의 커넥션이 같은 상태의 missionMember 레코드를 읽는 게 원인인 것 같습니다 (그래서 유효성 검사를 해도 insert가 되는,,,)

더 나은 방법이나 오류 사항이 있으면 편하게 말씀해주세요 🙏

Copy link
Member

@songyi00 songyi00 Nov 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

우리 Redis 쓰고 있으니까 레디스 락 걸어보는 것도 괜찮을 것 같앙
추후에 계속해서 사용될 수 있는 쿼리 같아서 DB 락 보다는 필요한 곳에 레디스 락 거는게 조금 더 가볍지 않을까 생각하는데 지금 당장 중요한 부분은 아니라 백로그로 남겨도 좋을 것 같아!

Copy link
Member

@songyi00 songyi00 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

고생 많았습니다 ⭐️👍⭐️

@kimyu0218 kimyu0218 merged commit 4b91204 into develop Nov 10, 2024
1 check passed
@kimyu0218 kimyu0218 deleted the feat/#84-fcm-push branch November 10, 2024 12:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants