Compare commits
No commits in common. "54c0322398c0580c0842f4609a60c61cef8cfe8b" and "7055bb987227f00778ce30169dc3081c7255d887" have entirely different histories.
54c0322398
...
7055bb9872
|
@ -5,7 +5,6 @@ import kr.co.bootpay.Bootpay
|
||||||
import kr.co.vividnext.sodalive.can.CanRepository
|
import kr.co.vividnext.sodalive.can.CanRepository
|
||||||
import kr.co.vividnext.sodalive.can.charge.event.ChargeSpringEvent
|
import kr.co.vividnext.sodalive.can.charge.event.ChargeSpringEvent
|
||||||
import kr.co.vividnext.sodalive.can.coupon.CanCouponNumberRepository
|
import kr.co.vividnext.sodalive.can.coupon.CanCouponNumberRepository
|
||||||
import kr.co.vividnext.sodalive.can.coupon.CouponType
|
|
||||||
import kr.co.vividnext.sodalive.can.payment.Payment
|
import kr.co.vividnext.sodalive.can.payment.Payment
|
||||||
import kr.co.vividnext.sodalive.can.payment.PaymentGateway
|
import kr.co.vividnext.sodalive.can.payment.PaymentGateway
|
||||||
import kr.co.vividnext.sodalive.can.payment.PaymentStatus
|
import kr.co.vividnext.sodalive.can.payment.PaymentStatus
|
||||||
|
@ -13,11 +12,6 @@ import kr.co.vividnext.sodalive.common.SodaException
|
||||||
import kr.co.vividnext.sodalive.google.GooglePlayService
|
import kr.co.vividnext.sodalive.google.GooglePlayService
|
||||||
import kr.co.vividnext.sodalive.member.Member
|
import kr.co.vividnext.sodalive.member.Member
|
||||||
import kr.co.vividnext.sodalive.member.MemberRepository
|
import kr.co.vividnext.sodalive.member.MemberRepository
|
||||||
import kr.co.vividnext.sodalive.point.MemberPoint
|
|
||||||
import kr.co.vividnext.sodalive.point.MemberPointRepository
|
|
||||||
import kr.co.vividnext.sodalive.point.PointGrantLog
|
|
||||||
import kr.co.vividnext.sodalive.point.PointGrantLogRepository
|
|
||||||
import kr.co.vividnext.sodalive.useraction.ActionType
|
|
||||||
import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
||||||
import okhttp3.OkHttpClient
|
import okhttp3.OkHttpClient
|
||||||
import okhttp3.Request
|
import okhttp3.Request
|
||||||
|
@ -33,7 +27,6 @@ import org.springframework.stereotype.Service
|
||||||
import org.springframework.transaction.annotation.Transactional
|
import org.springframework.transaction.annotation.Transactional
|
||||||
import java.math.BigDecimal
|
import java.math.BigDecimal
|
||||||
import java.math.RoundingMode
|
import java.math.RoundingMode
|
||||||
import java.time.LocalDateTime
|
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
@Transactional(readOnly = true)
|
@Transactional(readOnly = true)
|
||||||
|
@ -43,9 +36,6 @@ class ChargeService(
|
||||||
private val memberRepository: MemberRepository,
|
private val memberRepository: MemberRepository,
|
||||||
private val couponNumberRepository: CanCouponNumberRepository,
|
private val couponNumberRepository: CanCouponNumberRepository,
|
||||||
|
|
||||||
private val grantLogRepository: PointGrantLogRepository,
|
|
||||||
private val memberPointRepository: MemberPointRepository,
|
|
||||||
|
|
||||||
private val objectMapper: ObjectMapper,
|
private val objectMapper: ObjectMapper,
|
||||||
private val okHttpClient: OkHttpClient,
|
private val okHttpClient: OkHttpClient,
|
||||||
private val applicationEventPublisher: ApplicationEventPublisher,
|
private val applicationEventPublisher: ApplicationEventPublisher,
|
||||||
|
@ -74,12 +64,10 @@ class ChargeService(
|
||||||
if (canCouponNumber.member != null) {
|
if (canCouponNumber.member != null) {
|
||||||
throw SodaException("이미 사용한 쿠폰번호 입니다.")
|
throw SodaException("이미 사용한 쿠폰번호 입니다.")
|
||||||
}
|
}
|
||||||
|
|
||||||
canCouponNumber.member = member
|
canCouponNumber.member = member
|
||||||
|
|
||||||
val coupon = canCouponNumber.canCoupon!!
|
val coupon = canCouponNumber.canCoupon!!
|
||||||
|
|
||||||
when (coupon.couponType) {
|
|
||||||
CouponType.CAN -> {
|
|
||||||
val couponCharge = Charge(0, coupon.can, status = ChargeStatus.COUPON)
|
val couponCharge = Charge(0, coupon.can, status = ChargeStatus.COUPON)
|
||||||
couponCharge.title = "${coupon.can} 캔"
|
couponCharge.title = "${coupon.can} 캔"
|
||||||
couponCharge.member = member
|
couponCharge.member = member
|
||||||
|
@ -95,34 +83,6 @@ class ChargeService(
|
||||||
member.charge(0, coupon.can, "pg")
|
member.charge(0, coupon.can, "pg")
|
||||||
}
|
}
|
||||||
|
|
||||||
CouponType.POINT -> {
|
|
||||||
val memberId = member.id!!
|
|
||||||
val point = coupon.can
|
|
||||||
val actionType = ActionType.COUPON
|
|
||||||
|
|
||||||
grantLogRepository.save(
|
|
||||||
PointGrantLog(
|
|
||||||
memberId = memberId,
|
|
||||||
point = point,
|
|
||||||
actionType = actionType,
|
|
||||||
policyId = null,
|
|
||||||
orderId = null,
|
|
||||||
couponName = coupon.couponName
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
memberPointRepository.save(
|
|
||||||
MemberPoint(
|
|
||||||
memberId = memberId,
|
|
||||||
point = point,
|
|
||||||
actionType = actionType,
|
|
||||||
expiresAt = LocalDateTime.now().plusDays(3)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Transactional
|
@Transactional
|
||||||
fun charge(member: Member, request: ChargeRequest): ChargeResponse {
|
fun charge(member: Member, request: ChargeRequest): ChargeResponse {
|
||||||
val can = canRepository.findByIdOrNull(request.canId)
|
val can = canRepository.findByIdOrNull(request.canId)
|
||||||
|
|
|
@ -3,21 +3,13 @@ package kr.co.vividnext.sodalive.can.coupon
|
||||||
import kr.co.vividnext.sodalive.common.BaseEntity
|
import kr.co.vividnext.sodalive.common.BaseEntity
|
||||||
import java.time.LocalDateTime
|
import java.time.LocalDateTime
|
||||||
import javax.persistence.Entity
|
import javax.persistence.Entity
|
||||||
import javax.persistence.EnumType
|
|
||||||
import javax.persistence.Enumerated
|
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
data class CanCoupon(
|
data class CanCoupon(
|
||||||
val couponName: String,
|
val couponName: String,
|
||||||
@Enumerated(EnumType.STRING)
|
|
||||||
val couponType: CouponType,
|
|
||||||
val can: Int,
|
val can: Int,
|
||||||
val couponCount: Int,
|
val couponCount: Int,
|
||||||
var validity: LocalDateTime,
|
var validity: LocalDateTime,
|
||||||
var isActive: Boolean,
|
var isActive: Boolean,
|
||||||
var isMultipleUse: Boolean
|
var isMultipleUse: Boolean
|
||||||
) : BaseEntity()
|
) : BaseEntity()
|
||||||
|
|
||||||
enum class CouponType {
|
|
||||||
CAN, POINT
|
|
||||||
}
|
|
||||||
|
|
|
@ -79,7 +79,6 @@ class CanCouponNumberQueryRepositoryImpl(private val queryFactory: JPAQueryFacto
|
||||||
override fun findByCouponNumber(couponNumber: String): CanCouponNumber? {
|
override fun findByCouponNumber(couponNumber: String): CanCouponNumber? {
|
||||||
return queryFactory
|
return queryFactory
|
||||||
.selectFrom(canCouponNumber)
|
.selectFrom(canCouponNumber)
|
||||||
.innerJoin(canCouponNumber.canCoupon, canCoupon)
|
|
||||||
.where(canCouponNumber.couponNumber.eq(couponNumber))
|
.where(canCouponNumber.couponNumber.eq(couponNumber))
|
||||||
.fetchFirst()
|
.fetchFirst()
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package kr.co.vividnext.sodalive.can.coupon
|
package kr.co.vividnext.sodalive.can.coupon
|
||||||
|
|
||||||
import com.querydsl.core.types.dsl.CaseBuilder
|
|
||||||
import com.querydsl.core.types.dsl.DateTimePath
|
import com.querydsl.core.types.dsl.DateTimePath
|
||||||
import com.querydsl.core.types.dsl.Expressions
|
import com.querydsl.core.types.dsl.Expressions
|
||||||
import com.querydsl.core.types.dsl.StringTemplate
|
import com.querydsl.core.types.dsl.StringTemplate
|
||||||
|
@ -31,9 +30,6 @@ class CanCouponQueryRepositoryImpl(private val queryFactory: JPAQueryFactory) :
|
||||||
QGetCouponListItemResponse(
|
QGetCouponListItemResponse(
|
||||||
canCoupon.id,
|
canCoupon.id,
|
||||||
canCoupon.couponName,
|
canCoupon.couponName,
|
||||||
CaseBuilder()
|
|
||||||
.`when`(canCoupon.couponType.eq(CouponType.POINT)).then("포인트 쿠폰")
|
|
||||||
.otherwise("캔 쿠폰"),
|
|
||||||
canCoupon.can,
|
canCoupon.can,
|
||||||
canCoupon.couponCount,
|
canCoupon.couponCount,
|
||||||
Expressions.ZERO,
|
Expressions.ZERO,
|
||||||
|
|
|
@ -68,12 +68,15 @@ class CanCouponService(
|
||||||
|
|
||||||
fun getCouponList(offset: Long, limit: Long): GetCouponListResponse {
|
fun getCouponList(offset: Long, limit: Long): GetCouponListResponse {
|
||||||
val totalCount = repository.getCouponTotalCount()
|
val totalCount = repository.getCouponTotalCount()
|
||||||
|
|
||||||
val items = repository.getCouponList(offset = offset, limit = limit)
|
val items = repository.getCouponList(offset = offset, limit = limit)
|
||||||
|
.asSequence()
|
||||||
.map {
|
.map {
|
||||||
val useCouponCount = couponNumberRepository.getUseCouponCount(id = it.id)
|
val useCouponCount = couponNumberRepository.getUseCouponCount(id = it.id)
|
||||||
it.useCouponCount = useCouponCount
|
it.useCouponCount = useCouponCount
|
||||||
it
|
it
|
||||||
}
|
}
|
||||||
|
.toList()
|
||||||
|
|
||||||
return GetCouponListResponse(totalCount, items)
|
return GetCouponListResponse(totalCount, items)
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,6 @@ import com.fasterxml.jackson.annotation.JsonProperty
|
||||||
|
|
||||||
data class GenerateCanCouponRequest(
|
data class GenerateCanCouponRequest(
|
||||||
@JsonProperty("couponName") val couponName: String,
|
@JsonProperty("couponName") val couponName: String,
|
||||||
@JsonProperty("couponType") val couponType: CouponType,
|
|
||||||
@JsonProperty("can") val can: Int,
|
@JsonProperty("can") val can: Int,
|
||||||
@JsonProperty("validity") val validity: String,
|
@JsonProperty("validity") val validity: String,
|
||||||
@JsonProperty("isMultipleUse") val isMultipleUse: Boolean,
|
@JsonProperty("isMultipleUse") val isMultipleUse: Boolean,
|
||||||
|
|
|
@ -10,7 +10,6 @@ data class GetCouponListResponse(
|
||||||
data class GetCouponListItemResponse @QueryProjection constructor(
|
data class GetCouponListItemResponse @QueryProjection constructor(
|
||||||
val id: Long,
|
val id: Long,
|
||||||
val couponName: String,
|
val couponName: String,
|
||||||
val couponType: String,
|
|
||||||
val can: Int,
|
val can: Int,
|
||||||
val couponCount: Int,
|
val couponCount: Int,
|
||||||
var useCouponCount: Int,
|
var useCouponCount: Int,
|
||||||
|
|
|
@ -13,6 +13,5 @@ data class PointGrantLog(
|
||||||
@Enumerated(EnumType.STRING)
|
@Enumerated(EnumType.STRING)
|
||||||
val actionType: ActionType,
|
val actionType: ActionType,
|
||||||
val policyId: Long?,
|
val policyId: Long?,
|
||||||
val orderId: Long?,
|
val orderId: Long?
|
||||||
val couponName: String? = null
|
|
||||||
) : BaseEntity()
|
) : BaseEntity()
|
||||||
|
|
|
@ -5,6 +5,5 @@ enum class ActionType(val displayName: String) {
|
||||||
USER_AUTHENTICATION("본인인증"),
|
USER_AUTHENTICATION("본인인증"),
|
||||||
CONTENT_COMMENT("콘텐츠 댓글"),
|
CONTENT_COMMENT("콘텐츠 댓글"),
|
||||||
ORDER_CONTENT_COMMENT("구매한 콘텐츠 댓글"),
|
ORDER_CONTENT_COMMENT("구매한 콘텐츠 댓글"),
|
||||||
LIVE_CONTINUOUS_LISTEN_30("라이브 연속 청취 30분"),
|
LIVE_CONTINUOUS_LISTEN_30("라이브 연속 청취 30분")
|
||||||
COUPON("쿠폰")
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue