test #165

Merged
klaus merged 11 commits from test into main 2024-04-18 10:02:46 +00:00
3 changed files with 26 additions and 0 deletions
Showing only changes of commit 0185c09d55 - Show all commits

View File

@ -3,6 +3,7 @@ package kr.co.vividnext.sodalive.creator.admin.content.series
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.creator.admin.content.series.content.AddingContentToTheSeriesRequest import kr.co.vividnext.sodalive.creator.admin.content.series.content.AddingContentToTheSeriesRequest
import kr.co.vividnext.sodalive.creator.admin.content.series.content.RemoveContentToTheSeriesRequest
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.lang.Nullable import org.springframework.lang.Nullable
@ -102,4 +103,17 @@ class CreatorAdminContentSeriesController(private val service: CreatorAdminConte
"콘텐츠가 추가되었습니다." "콘텐츠가 추가되었습니다."
) )
} }
@PutMapping("/remove/content")
fun removeContentInTheSeries(
@RequestBody request: RemoveContentToTheSeriesRequest,
@AuthenticationPrincipal(expression = "#this == 'anonymousUser' ? null : member") member: Member?
) = run {
if (member == null) throw SodaException("로그인 정보를 확인해주세요.")
ApiResponse.ok(
service.removeContentInTheSeries(request, memberId = member.id!!),
"콘텐츠를 삭제하였습니다."
)
}
} }

View File

@ -8,6 +8,7 @@ import kr.co.vividnext.sodalive.content.AudioContentRepository
import kr.co.vividnext.sodalive.content.hashtag.HashTag import kr.co.vividnext.sodalive.content.hashtag.HashTag
import kr.co.vividnext.sodalive.content.hashtag.HashTagRepository import kr.co.vividnext.sodalive.content.hashtag.HashTagRepository
import kr.co.vividnext.sodalive.creator.admin.content.series.content.AddingContentToTheSeriesRequest import kr.co.vividnext.sodalive.creator.admin.content.series.content.AddingContentToTheSeriesRequest
import kr.co.vividnext.sodalive.creator.admin.content.series.content.RemoveContentToTheSeriesRequest
import kr.co.vividnext.sodalive.creator.admin.content.series.genre.CreatorAdminContentSeriesGenreRepository import kr.co.vividnext.sodalive.creator.admin.content.series.genre.CreatorAdminContentSeriesGenreRepository
import kr.co.vividnext.sodalive.creator.admin.content.series.keyword.SeriesKeyword import kr.co.vividnext.sodalive.creator.admin.content.series.keyword.SeriesKeyword
import kr.co.vividnext.sodalive.member.Member import kr.co.vividnext.sodalive.member.Member
@ -222,4 +223,12 @@ class CreatorAdminContentSeriesService(
throw SodaException("추가된 콘텐츠가 없습니다.") throw SodaException("추가된 콘텐츠가 없습니다.")
} }
} }
@Transactional
fun removeContentInTheSeries(request: RemoveContentToTheSeriesRequest, memberId: Long) {
val series = repository.findByIdAndCreatorId(id = request.seriesId, creatorId = memberId)
?: throw SodaException("잘못된 접근입니다.")
series.contentList.removeIf { it.content!!.id == request.contentId }
}
} }

View File

@ -0,0 +1,3 @@
package kr.co.vividnext.sodalive.creator.admin.content.series.content
data class RemoveContentToTheSeriesRequest(val seriesId: Long, val contentId: Long)