충전이벤트가 적용되지 않는 버그 수정

This commit is contained in:
Klaus 2023-08-27 19:13:22 +09:00
parent 3b9d8a4fcb
commit 0d56b61b2e
2 changed files with 7 additions and 12 deletions

View File

@ -10,7 +10,6 @@ import kr.co.vividnext.sodalive.common.SodaException
import kr.co.vividnext.sodalive.fcm.FcmEvent
import kr.co.vividnext.sodalive.fcm.FcmEventType
import kr.co.vividnext.sodalive.member.Member
import kr.co.vividnext.sodalive.member.MemberRepository
import kr.co.vividnext.sodalive.member.auth.AuthRepository
import org.springframework.context.ApplicationEventPublisher
import org.springframework.data.repository.findByIdOrNull
@ -23,26 +22,22 @@ import kotlin.math.round
class ChargeEventService(
private val repository: ChargeEventRepository,
private val authRepository: AuthRepository,
private val memberRepository: MemberRepository,
private val chargeRepository: ChargeRepository,
private val chargeEventRepository: ChargeEventRepository,
private val applicationEventPublisher: ApplicationEventPublisher
) {
@Transactional
fun applyChargeEvent(chargeId: Long, memberId: Long) {
fun applyChargeEvent(chargeId: Long, member: Member) {
val charge = chargeRepository.findByIdOrNull(chargeId)
?: throw SodaException("이벤트가 적용되지 않았습니다.\n고객센터에 문의해 주세요.")
val member = memberRepository.findByIdOrNull(memberId)
?: throw SodaException("이벤트가 적용되지 않았습니다.\n고객센터에 문의해 주세요.")
?: throw SodaException("이벤트가 적용되지 않았습니다.")
if (member.auth != null) {
val authDate = authRepository.getOldestCreatedAtByDi(member.auth!!.di)
val memberIds = authRepository.getMemberIdsByDi(member.auth!!.di)
var chargeCount = 0
for (id in memberIds) {
chargeCount += chargeRepository.getChargeCountAfterDate(memberId = id, authDate)
for (memberId in memberIds) {
chargeCount += chargeRepository.getChargeCountAfterDate(memberId = memberId, authDate)
}
if (chargeCount > 0) {

View File

@ -1,11 +1,11 @@
package kr.co.vividnext.sodalive.can.charge.event
import kr.co.vividnext.sodalive.member.Member
import org.springframework.context.event.EventListener
import org.springframework.scheduling.annotation.Async
import org.springframework.stereotype.Component
import org.springframework.transaction.annotation.Propagation
import org.springframework.transaction.annotation.Transactional
import org.springframework.transaction.event.TransactionalEventListener
class ChargeSpringEvent(
val chargeId: Long,
@ -17,9 +17,9 @@ class ChargeSpringEventListener(
private val chargeEventService: ChargeEventService
) {
@Async
@EventListener
@TransactionalEventListener
@Transactional(propagation = Propagation.REQUIRES_NEW)
fun applyChargeEvent(event: ChargeSpringEvent) {
chargeEventService.applyChargeEvent(event.chargeId, event.member.id!!)
chargeEventService.applyChargeEvent(event.chargeId, event.member)
}
}