Compare commits

..

No commits in common. "656fd9a1fa6515d3d85bf41c945a5a932f069d2d" and "ebb9e5f4ae1b8ac3bce4f53e57ec065dd9eefd02" have entirely different histories.

3 changed files with 18 additions and 52 deletions

View File

@ -15,15 +15,7 @@ import org.springframework.web.bind.annotation.RestController
@RequestMapping("/admin/audio-content") @RequestMapping("/admin/audio-content")
class AdminContentController(private val service: AdminContentService) { class AdminContentController(private val service: AdminContentService) {
@GetMapping("/list") @GetMapping("/list")
fun getAudioContentList( fun getAudioContentList(pageable: Pageable) = ApiResponse.ok(service.getAudioContentList(pageable))
@RequestParam(value = "status", required = false) status: ContentReleaseStatus?,
pageable: Pageable
) = ApiResponse.ok(
service.getAudioContentList(
status = status ?: ContentReleaseStatus.OPEN,
pageable
)
)
@GetMapping("/search") @GetMapping("/search")
fun searchAudioContent( fun searchAudioContent(
@ -36,11 +28,3 @@ class AdminContentController(private val service: AdminContentService) {
@RequestBody request: UpdateAdminContentRequest @RequestBody request: UpdateAdminContentRequest
) = ApiResponse.ok(service.updateAudioContent(request)) ) = ApiResponse.ok(service.updateAudioContent(request))
} }
enum class ContentReleaseStatus {
// 콘텐츠가 공개된 상태
OPEN,
// 예약된 콘텐츠, 아직 공개되지 않은 상태
SCHEDULED
}

View File

@ -10,7 +10,6 @@ import kr.co.vividnext.sodalive.content.hashtag.QAudioContentHashTag.audioConten
import kr.co.vividnext.sodalive.content.hashtag.QHashTag.hashTag import kr.co.vividnext.sodalive.content.hashtag.QHashTag.hashTag
import kr.co.vividnext.sodalive.content.main.curation.QAudioContentCuration.audioContentCuration import kr.co.vividnext.sodalive.content.main.curation.QAudioContentCuration.audioContentCuration
import kr.co.vividnext.sodalive.content.theme.QAudioContentTheme.audioContentTheme import kr.co.vividnext.sodalive.content.theme.QAudioContentTheme.audioContentTheme
import org.springframework.beans.factory.annotation.Value
import org.springframework.data.jpa.repository.JpaRepository import org.springframework.data.jpa.repository.JpaRepository
import org.springframework.stereotype.Repository import org.springframework.stereotype.Repository
import java.time.LocalDateTime import java.time.LocalDateTime
@ -19,13 +18,9 @@ import java.time.LocalDateTime
interface AdminContentRepository : JpaRepository<AudioContent, Long>, AdminAudioContentQueryRepository interface AdminContentRepository : JpaRepository<AudioContent, Long>, AdminAudioContentQueryRepository
interface AdminAudioContentQueryRepository { interface AdminAudioContentQueryRepository {
fun getAudioContentTotalCount( fun getAudioContentTotalCount(searchWord: String = ""): Int
searchWord: String = "",
status: ContentReleaseStatus = ContentReleaseStatus.OPEN
): Int
fun getAudioContentList( fun getAudioContentList(
status: ContentReleaseStatus = ContentReleaseStatus.OPEN, imageHost: String,
offset: Long, offset: Long,
limit: Long, limit: Long,
searchWord: String = "" searchWord: String = ""
@ -35,17 +30,9 @@ interface AdminAudioContentQueryRepository {
} }
class AdminAudioContentQueryRepositoryImpl( class AdminAudioContentQueryRepositoryImpl(
private val queryFactory: JPAQueryFactory, private val queryFactory: JPAQueryFactory
@Value("\${cloud.aws.cloud-front.host}")
private val imageHost: String
) : AdminAudioContentQueryRepository { ) : AdminAudioContentQueryRepository {
override fun getAudioContentTotalCount( override fun getAudioContentTotalCount(searchWord: String): Int {
searchWord: String,
status: ContentReleaseStatus
): Int {
val now = LocalDateTime.now()
var where = audioContent.duration.isNotNull var where = audioContent.duration.isNotNull
.and(audioContent.member.isNotNull) .and(audioContent.member.isNotNull)
.and(audioContent.isActive.isTrue.or(audioContent.releaseDate.isNotNull)) .and(audioContent.isActive.isTrue.or(audioContent.releaseDate.isNotNull))
@ -57,12 +44,6 @@ class AdminAudioContentQueryRepositoryImpl(
) )
} }
where = if (status == ContentReleaseStatus.SCHEDULED) {
where.and(audioContent.releaseDate.after(now))
} else {
where.and(audioContent.releaseDate.before(now))
}
return queryFactory return queryFactory
.select(audioContent.id) .select(audioContent.id)
.from(audioContent) .from(audioContent)
@ -72,13 +53,11 @@ class AdminAudioContentQueryRepositoryImpl(
} }
override fun getAudioContentList( override fun getAudioContentList(
status: ContentReleaseStatus, imageHost: String,
offset: Long, offset: Long,
limit: Long, limit: Long,
searchWord: String searchWord: String
): List<GetAdminContentListItem> { ): List<GetAdminContentListItem> {
val now = LocalDateTime.now()
var where = audioContent.duration.isNotNull var where = audioContent.duration.isNotNull
.and(audioContent.member.isNotNull) .and(audioContent.member.isNotNull)
.and(audioContent.isActive.isTrue.or(audioContent.releaseDate.isNotNull)) .and(audioContent.isActive.isTrue.or(audioContent.releaseDate.isNotNull))
@ -90,12 +69,6 @@ class AdminAudioContentQueryRepositoryImpl(
) )
} }
where = if (status == ContentReleaseStatus.SCHEDULED) {
where.and(audioContent.releaseDate.after(now))
} else {
where.and(audioContent.releaseDate.before(now))
}
return queryFactory return queryFactory
.select( .select(
QGetAdminContentListItem( QGetAdminContentListItem(

View File

@ -4,6 +4,7 @@ import kr.co.vividnext.sodalive.admin.content.curation.AdminContentCurationRepos
import kr.co.vividnext.sodalive.admin.content.theme.AdminContentThemeRepository import kr.co.vividnext.sodalive.admin.content.theme.AdminContentThemeRepository
import kr.co.vividnext.sodalive.aws.cloudfront.AudioContentCloudFront import kr.co.vividnext.sodalive.aws.cloudfront.AudioContentCloudFront
import kr.co.vividnext.sodalive.common.SodaException import kr.co.vividnext.sodalive.common.SodaException
import org.springframework.beans.factory.annotation.Value
import org.springframework.data.domain.Pageable import org.springframework.data.domain.Pageable
import org.springframework.data.repository.findByIdOrNull import org.springframework.data.repository.findByIdOrNull
import org.springframework.stereotype.Service import org.springframework.stereotype.Service
@ -14,17 +15,21 @@ class AdminContentService(
private val repository: AdminContentRepository, private val repository: AdminContentRepository,
private val themeRepository: AdminContentThemeRepository, private val themeRepository: AdminContentThemeRepository,
private val audioContentCloudFront: AudioContentCloudFront, private val audioContentCloudFront: AudioContentCloudFront,
private val curationRepository: AdminContentCurationRepository private val curationRepository: AdminContentCurationRepository,
@Value("\${cloud.aws.cloud-front.host}")
private val coverImageHost: String
) { ) {
fun getAudioContentList(status: ContentReleaseStatus, pageable: Pageable): GetAdminContentListResponse { fun getAudioContentList(pageable: Pageable): GetAdminContentListResponse {
val totalCount = repository.getAudioContentTotalCount() val totalCount = repository.getAudioContentTotalCount()
val audioContentAndThemeList = repository.getAudioContentList( val audioContentAndThemeList = repository.getAudioContentList(
status = status, imageHost = coverImageHost,
offset = pageable.offset, offset = pageable.offset,
limit = pageable.pageSize.toLong() limit = pageable.pageSize.toLong()
) )
val audioContentList = audioContentAndThemeList val audioContentList = audioContentAndThemeList
.asSequence()
.map { .map {
val tags = repository val tags = repository
.getHashTagList(audioContentId = it.audioContentId) .getHashTagList(audioContentId = it.audioContentId)
@ -39,6 +44,7 @@ class AdminContentService(
) )
it it
} }
.toList()
return GetAdminContentListResponse(totalCount, audioContentList) return GetAdminContentListResponse(totalCount, audioContentList)
} }
@ -47,12 +53,14 @@ class AdminContentService(
if (searchWord.length < 2) throw SodaException("2글자 이상 입력하세요.") if (searchWord.length < 2) throw SodaException("2글자 이상 입력하세요.")
val totalCount = repository.getAudioContentTotalCount(searchWord) val totalCount = repository.getAudioContentTotalCount(searchWord)
val audioContentAndThemeList = repository.getAudioContentList( val audioContentAndThemeList = repository.getAudioContentList(
imageHost = coverImageHost,
offset = pageable.offset, offset = pageable.offset,
limit = pageable.pageSize.toLong(), limit = pageable.pageSize.toLong(),
searchWord = searchWord searchWord = searchWord
) )
val audioContentList = audioContentAndThemeList val audioContentList = audioContentAndThemeList
.asSequence()
.map { .map {
val tags = repository val tags = repository
.getHashTagList(audioContentId = it.audioContentId) .getHashTagList(audioContentId = it.audioContentId)
@ -67,6 +75,7 @@ class AdminContentService(
) )
it it
} }
.toList()
return GetAdminContentListResponse(totalCount, audioContentList) return GetAdminContentListResponse(totalCount, audioContentList)
} }