Compare commits
No commits in common. "97edb56edc7fe7e429f841438af4005241a7deca" and "6ebca8d22bfb177e590ea991e9b24b7aedf2fe0b" have entirely different histories.
97edb56edc
...
6ebca8d22b
|
@ -32,7 +32,7 @@ data class AudioContent(
|
||||||
var title: String,
|
var title: String,
|
||||||
@Column(columnDefinition = "TEXT", nullable = false)
|
@Column(columnDefinition = "TEXT", nullable = false)
|
||||||
var detail: String,
|
var detail: String,
|
||||||
var price: Int = 0,
|
val price: Int = 0,
|
||||||
var releaseDate: LocalDateTime? = null,
|
var releaseDate: LocalDateTime? = null,
|
||||||
val limited: Int? = null,
|
val limited: Int? = null,
|
||||||
var remaining: Int? = null,
|
var remaining: Int? = null,
|
||||||
|
|
|
@ -1,29 +0,0 @@
|
||||||
package kr.co.vividnext.sodalive.content
|
|
||||||
|
|
||||||
import java.time.LocalDateTime
|
|
||||||
import javax.persistence.Entity
|
|
||||||
import javax.persistence.FetchType
|
|
||||||
import javax.persistence.GeneratedValue
|
|
||||||
import javax.persistence.GenerationType
|
|
||||||
import javax.persistence.Id
|
|
||||||
import javax.persistence.JoinColumn
|
|
||||||
import javax.persistence.ManyToOne
|
|
||||||
import javax.persistence.PrePersist
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
data class ContentPriceChangeLog(
|
|
||||||
@Id
|
|
||||||
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
|
||||||
var id: Long? = null,
|
|
||||||
val prevPrice: Int,
|
|
||||||
var createdAt: LocalDateTime? = null
|
|
||||||
) {
|
|
||||||
@ManyToOne(fetch = FetchType.LAZY)
|
|
||||||
@JoinColumn(name = "content_id", nullable = false)
|
|
||||||
var audioContent: AudioContent? = null
|
|
||||||
|
|
||||||
@PrePersist
|
|
||||||
fun prePersist() {
|
|
||||||
createdAt = LocalDateTime.now()
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,5 +0,0 @@
|
||||||
package kr.co.vividnext.sodalive.content
|
|
||||||
|
|
||||||
import org.springframework.data.jpa.repository.JpaRepository
|
|
||||||
|
|
||||||
interface ContentPriceChangeLogRepository : JpaRepository<ContentPriceChangeLog, Long>
|
|
|
@ -5,8 +5,6 @@ import com.fasterxml.jackson.databind.ObjectMapper
|
||||||
import kr.co.vividnext.sodalive.aws.cloudfront.AudioContentCloudFront
|
import kr.co.vividnext.sodalive.aws.cloudfront.AudioContentCloudFront
|
||||||
import kr.co.vividnext.sodalive.aws.s3.S3Uploader
|
import kr.co.vividnext.sodalive.aws.s3.S3Uploader
|
||||||
import kr.co.vividnext.sodalive.common.SodaException
|
import kr.co.vividnext.sodalive.common.SodaException
|
||||||
import kr.co.vividnext.sodalive.content.ContentPriceChangeLog
|
|
||||||
import kr.co.vividnext.sodalive.content.ContentPriceChangeLogRepository
|
|
||||||
import kr.co.vividnext.sodalive.member.Member
|
import kr.co.vividnext.sodalive.member.Member
|
||||||
import kr.co.vividnext.sodalive.utils.generateFileName
|
import kr.co.vividnext.sodalive.utils.generateFileName
|
||||||
import org.springframework.beans.factory.annotation.Value
|
import org.springframework.beans.factory.annotation.Value
|
||||||
|
@ -18,7 +16,6 @@ import org.springframework.web.multipart.MultipartFile
|
||||||
@Service
|
@Service
|
||||||
class CreatorAdminContentService(
|
class CreatorAdminContentService(
|
||||||
private val repository: CreatorAdminContentRepository,
|
private val repository: CreatorAdminContentRepository,
|
||||||
private val contentPriceChangeLogRepository: ContentPriceChangeLogRepository,
|
|
||||||
private val audioContentCloudFront: AudioContentCloudFront,
|
private val audioContentCloudFront: AudioContentCloudFront,
|
||||||
private val objectMapper: ObjectMapper,
|
private val objectMapper: ObjectMapper,
|
||||||
private val s3Uploader: S3Uploader,
|
private val s3Uploader: S3Uploader,
|
||||||
|
@ -142,15 +139,5 @@ class CreatorAdminContentService(
|
||||||
if (request.detail != null) {
|
if (request.detail != null) {
|
||||||
audioContent.detail = request.detail
|
audioContent.detail = request.detail
|
||||||
}
|
}
|
||||||
|
|
||||||
if (request.price != null) {
|
|
||||||
if (request.price < 5) throw SodaException("콘텐츠의 최소금액은 5캔 입니다.")
|
|
||||||
|
|
||||||
val contentPriceChangeLog = ContentPriceChangeLog(prevPrice = audioContent.price)
|
|
||||||
contentPriceChangeLog.audioContent = audioContent
|
|
||||||
contentPriceChangeLogRepository.save(contentPriceChangeLog)
|
|
||||||
|
|
||||||
audioContent.price = request.price
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,6 @@ data class UpdateCreatorAdminContentRequest(
|
||||||
val id: Long,
|
val id: Long,
|
||||||
val title: String?,
|
val title: String?,
|
||||||
val detail: String?,
|
val detail: String?,
|
||||||
val price: Int?,
|
|
||||||
val isAdult: Boolean?,
|
val isAdult: Boolean?,
|
||||||
val isActive: Boolean?,
|
val isActive: Boolean?,
|
||||||
val isCommentAvailable: Boolean?
|
val isCommentAvailable: Boolean?
|
||||||
|
|
|
@ -2,7 +2,6 @@ package kr.co.vividnext.sodalive.creator.admin.signature
|
||||||
|
|
||||||
import kr.co.vividnext.sodalive.common.ApiResponse
|
import kr.co.vividnext.sodalive.common.ApiResponse
|
||||||
import kr.co.vividnext.sodalive.common.SodaException
|
import kr.co.vividnext.sodalive.common.SodaException
|
||||||
import kr.co.vividnext.sodalive.live.signature.SignatureCanSortType
|
|
||||||
import kr.co.vividnext.sodalive.member.Member
|
import kr.co.vividnext.sodalive.member.Member
|
||||||
import org.springframework.data.domain.Pageable
|
import org.springframework.data.domain.Pageable
|
||||||
import org.springframework.security.access.prepost.PreAuthorize
|
import org.springframework.security.access.prepost.PreAuthorize
|
||||||
|
@ -22,18 +21,11 @@ class CreatorAdminSignatureController(private val service: CreatorAdminSignature
|
||||||
@GetMapping
|
@GetMapping
|
||||||
fun getSignatureCanList(
|
fun getSignatureCanList(
|
||||||
pageable: Pageable,
|
pageable: Pageable,
|
||||||
@RequestParam("sort-type", required = false) sortType: SignatureCanSortType?,
|
|
||||||
@AuthenticationPrincipal(expression = "#this == 'anonymousUser' ? null : member") member: Member?
|
@AuthenticationPrincipal(expression = "#this == 'anonymousUser' ? null : member") member: Member?
|
||||||
) = run {
|
) = run {
|
||||||
if (member == null) throw SodaException("로그인 정보를 확인해주세요.")
|
if (member == null) throw SodaException("로그인 정보를 확인해주세요.")
|
||||||
|
|
||||||
ApiResponse.ok(
|
ApiResponse.ok(data = service.getSignatureList(pageable, memberId = member.id!!))
|
||||||
data = service.getSignatureList(
|
|
||||||
pageable,
|
|
||||||
sortType ?: SignatureCanSortType.NEWEST,
|
|
||||||
memberId = member.id!!
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping
|
@PostMapping
|
||||||
|
|
|
@ -3,7 +3,6 @@ package kr.co.vividnext.sodalive.creator.admin.signature
|
||||||
import com.querydsl.jpa.impl.JPAQueryFactory
|
import com.querydsl.jpa.impl.JPAQueryFactory
|
||||||
import kr.co.vividnext.sodalive.live.signature.QSignatureCan.signatureCan
|
import kr.co.vividnext.sodalive.live.signature.QSignatureCan.signatureCan
|
||||||
import kr.co.vividnext.sodalive.live.signature.SignatureCan
|
import kr.co.vividnext.sodalive.live.signature.SignatureCan
|
||||||
import kr.co.vividnext.sodalive.live.signature.SignatureCanSortType
|
|
||||||
import kr.co.vividnext.sodalive.member.QMember.member
|
import kr.co.vividnext.sodalive.member.QMember.member
|
||||||
import org.springframework.data.jpa.repository.JpaRepository
|
import org.springframework.data.jpa.repository.JpaRepository
|
||||||
|
|
||||||
|
@ -12,13 +11,7 @@ interface CreatorAdminSignatureRepository : JpaRepository<SignatureCan, Long>, C
|
||||||
interface CreatorAdminSignatureQueryRepository {
|
interface CreatorAdminSignatureQueryRepository {
|
||||||
fun getSignatureListTotalCount(memberId: Long): Int
|
fun getSignatureListTotalCount(memberId: Long): Int
|
||||||
|
|
||||||
fun getSignatureList(
|
fun getSignatureList(memberId: Long, imageHost: String, offset: Long, limit: Long): List<GetSignatureListItem>
|
||||||
memberId: Long,
|
|
||||||
sortType: SignatureCanSortType,
|
|
||||||
imageHost: String,
|
|
||||||
offset: Long,
|
|
||||||
limit: Long
|
|
||||||
): List<GetSignatureListItem>
|
|
||||||
|
|
||||||
fun findSignatureByIdOrNull(id: Long, memberId: Long): SignatureCan?
|
fun findSignatureByIdOrNull(id: Long, memberId: Long): SignatureCan?
|
||||||
}
|
}
|
||||||
|
@ -39,25 +32,10 @@ class CreatorAdminSignatureQueryRepositoryImpl(
|
||||||
|
|
||||||
override fun getSignatureList(
|
override fun getSignatureList(
|
||||||
memberId: Long,
|
memberId: Long,
|
||||||
sortType: SignatureCanSortType,
|
|
||||||
imageHost: String,
|
imageHost: String,
|
||||||
offset: Long,
|
offset: Long,
|
||||||
limit: Long
|
limit: Long
|
||||||
): List<GetSignatureListItem> {
|
): List<GetSignatureListItem> {
|
||||||
val orderBy = when (sortType) {
|
|
||||||
SignatureCanSortType.CAN_HIGH -> {
|
|
||||||
signatureCan.can.desc()
|
|
||||||
}
|
|
||||||
|
|
||||||
SignatureCanSortType.CAN_LOW -> {
|
|
||||||
signatureCan.can.asc()
|
|
||||||
}
|
|
||||||
|
|
||||||
else -> {
|
|
||||||
signatureCan.id.desc()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return queryFactory.select(
|
return queryFactory.select(
|
||||||
QGetSignatureListItem(
|
QGetSignatureListItem(
|
||||||
signatureCan.id,
|
signatureCan.id,
|
||||||
|
@ -76,7 +54,7 @@ class CreatorAdminSignatureQueryRepositoryImpl(
|
||||||
)
|
)
|
||||||
.offset(offset)
|
.offset(offset)
|
||||||
.limit(limit)
|
.limit(limit)
|
||||||
.orderBy(orderBy)
|
.orderBy(signatureCan.id.desc())
|
||||||
.fetch()
|
.fetch()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ import com.amazonaws.services.s3.model.ObjectMetadata
|
||||||
import kr.co.vividnext.sodalive.aws.s3.S3Uploader
|
import kr.co.vividnext.sodalive.aws.s3.S3Uploader
|
||||||
import kr.co.vividnext.sodalive.common.SodaException
|
import kr.co.vividnext.sodalive.common.SodaException
|
||||||
import kr.co.vividnext.sodalive.live.signature.SignatureCan
|
import kr.co.vividnext.sodalive.live.signature.SignatureCan
|
||||||
import kr.co.vividnext.sodalive.live.signature.SignatureCanSortType
|
|
||||||
import kr.co.vividnext.sodalive.member.MemberRepository
|
import kr.co.vividnext.sodalive.member.MemberRepository
|
||||||
import kr.co.vividnext.sodalive.utils.generateFileName
|
import kr.co.vividnext.sodalive.utils.generateFileName
|
||||||
import org.springframework.beans.factory.annotation.Value
|
import org.springframework.beans.factory.annotation.Value
|
||||||
|
@ -25,15 +24,10 @@ class CreatorAdminSignatureService(
|
||||||
@Value("\${cloud.aws.cloud-front.host}")
|
@Value("\${cloud.aws.cloud-front.host}")
|
||||||
private val imageHost: String
|
private val imageHost: String
|
||||||
) {
|
) {
|
||||||
fun getSignatureList(
|
fun getSignatureList(pageable: Pageable, memberId: Long): GetSignatureListResponse {
|
||||||
pageable: Pageable,
|
|
||||||
sortType: SignatureCanSortType,
|
|
||||||
memberId: Long
|
|
||||||
): GetSignatureListResponse {
|
|
||||||
val totalCount = repository.getSignatureListTotalCount(memberId = memberId)
|
val totalCount = repository.getSignatureListTotalCount(memberId = memberId)
|
||||||
val items = repository.getSignatureList(
|
val items = repository.getSignatureList(
|
||||||
memberId = memberId,
|
memberId = memberId,
|
||||||
sortType = sortType,
|
|
||||||
imageHost = imageHost,
|
imageHost = imageHost,
|
||||||
offset = pageable.offset,
|
offset = pageable.offset,
|
||||||
limit = pageable.pageSize.toLong()
|
limit = pageable.pageSize.toLong()
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
package kr.co.vividnext.sodalive.live.signature
|
|
||||||
|
|
||||||
enum class SignatureCanSortType {
|
|
||||||
NEWEST, CAN_HIGH, CAN_LOW
|
|
||||||
}
|
|
Loading…
Reference in New Issue