parent
5db181aa74
commit
a17a6a41da
|
@ -1,7 +1,9 @@
|
||||||
package kr.co.vividnext.sodalive.admin.marketing
|
package kr.co.vividnext.sodalive.admin.marketing
|
||||||
|
|
||||||
import kr.co.vividnext.sodalive.common.ApiResponse
|
import kr.co.vividnext.sodalive.common.ApiResponse
|
||||||
|
import org.springframework.data.domain.Pageable
|
||||||
import org.springframework.security.access.prepost.PreAuthorize
|
import org.springframework.security.access.prepost.PreAuthorize
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping
|
||||||
import org.springframework.web.bind.annotation.PostMapping
|
import org.springframework.web.bind.annotation.PostMapping
|
||||||
import org.springframework.web.bind.annotation.PutMapping
|
import org.springframework.web.bind.annotation.PutMapping
|
||||||
import org.springframework.web.bind.annotation.RequestBody
|
import org.springframework.web.bind.annotation.RequestBody
|
||||||
|
@ -21,4 +23,12 @@ class AdminAdMediaPartnerController(private val service: AdminAdMediaPartnerServ
|
||||||
fun updateMediaPartner(
|
fun updateMediaPartner(
|
||||||
@RequestBody request: UpdateAdMediaPartnerRequest
|
@RequestBody request: UpdateAdMediaPartnerRequest
|
||||||
) = ApiResponse.ok(service.updateMediaPartner(request))
|
) = ApiResponse.ok(service.updateMediaPartner(request))
|
||||||
|
|
||||||
|
@GetMapping
|
||||||
|
fun getMediaPartnerList(pageable: Pageable) = ApiResponse.ok(
|
||||||
|
service.getMediaPartnerList(
|
||||||
|
offset = pageable.offset,
|
||||||
|
limit = pageable.pageSize.toLong()
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,9 +2,11 @@ package kr.co.vividnext.sodalive.admin.marketing
|
||||||
|
|
||||||
import kr.co.vividnext.sodalive.common.SodaException
|
import kr.co.vividnext.sodalive.common.SodaException
|
||||||
import kr.co.vividnext.sodalive.marketing.AdMediaPartnerRepository
|
import kr.co.vividnext.sodalive.marketing.AdMediaPartnerRepository
|
||||||
|
import kr.co.vividnext.sodalive.marketing.AdMediaPartnerType
|
||||||
import org.springframework.data.repository.findByIdOrNull
|
import org.springframework.data.repository.findByIdOrNull
|
||||||
import org.springframework.stereotype.Service
|
import org.springframework.stereotype.Service
|
||||||
import org.springframework.transaction.annotation.Transactional
|
import org.springframework.transaction.annotation.Transactional
|
||||||
|
import java.net.URLEncoder
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
class AdminAdMediaPartnerService(private val repository: AdMediaPartnerRepository) {
|
class AdminAdMediaPartnerService(private val repository: AdMediaPartnerRepository) {
|
||||||
|
@ -47,4 +49,37 @@ class AdminAdMediaPartnerService(private val repository: AdMediaPartnerRepositor
|
||||||
entity.isActive = request.isActive
|
entity.isActive = request.isActive
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun getMediaPartnerList(offset: Long, limit: Long): List<GetAdminAdMediaPartnerResponse> {
|
||||||
|
return repository.getMediaPartnerList(offset, limit)
|
||||||
|
.map {
|
||||||
|
val deepLinkValue = when (it.type) {
|
||||||
|
AdMediaPartnerType.SERIES -> "series"
|
||||||
|
AdMediaPartnerType.CONTENT -> "content"
|
||||||
|
AdMediaPartnerType.LIVE -> "live"
|
||||||
|
AdMediaPartnerType.CHANNEL -> "channel"
|
||||||
|
AdMediaPartnerType.MAIN -> "main"
|
||||||
|
}
|
||||||
|
|
||||||
|
val link = URLEncoder.encode(
|
||||||
|
"$oneLinkHost?af_dp=voiceon%3A%2F%2F" +
|
||||||
|
"&deep_link_value=$deepLinkValue" +
|
||||||
|
"&deep_link_sub1=${it.pid}" +
|
||||||
|
"&deep_link_sub2=${it.utmSource}" +
|
||||||
|
"&deep_link_sub3=${it.utmMedium}" +
|
||||||
|
"&deep_link_sub4=${it.pidName}" +
|
||||||
|
"&utm_source=${it.utmSource}" +
|
||||||
|
"&utm_medium=${it.utmMedium}" +
|
||||||
|
"&utm_campaign=${it.pidName}",
|
||||||
|
"UTF-8"
|
||||||
|
)
|
||||||
|
|
||||||
|
it.link = link
|
||||||
|
it
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
private val oneLinkHost = "https://voiceon.onelink.me/RkTm"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,17 @@
|
||||||
|
package kr.co.vividnext.sodalive.admin.marketing
|
||||||
|
|
||||||
|
import com.querydsl.core.annotations.QueryProjection
|
||||||
|
import kr.co.vividnext.sodalive.marketing.AdMediaPartnerType
|
||||||
|
|
||||||
|
data class GetAdminAdMediaPartnerResponse @QueryProjection constructor(
|
||||||
|
val id: Long,
|
||||||
|
val mediaGroup: String,
|
||||||
|
val pid: String,
|
||||||
|
val pidName: String,
|
||||||
|
val type: AdMediaPartnerType,
|
||||||
|
val utmSource: String,
|
||||||
|
val utmMedium: String,
|
||||||
|
val isActive: Boolean,
|
||||||
|
val createdAt: String,
|
||||||
|
var link: String
|
||||||
|
)
|
|
@ -1,14 +1,21 @@
|
||||||
package kr.co.vividnext.sodalive.marketing
|
package kr.co.vividnext.sodalive.marketing
|
||||||
|
|
||||||
|
import com.querydsl.core.types.dsl.DateTimePath
|
||||||
|
import com.querydsl.core.types.dsl.Expressions
|
||||||
|
import com.querydsl.core.types.dsl.StringTemplate
|
||||||
import com.querydsl.jpa.impl.JPAQueryFactory
|
import com.querydsl.jpa.impl.JPAQueryFactory
|
||||||
|
import kr.co.vividnext.sodalive.admin.marketing.GetAdminAdMediaPartnerResponse
|
||||||
|
import kr.co.vividnext.sodalive.admin.marketing.QGetAdminAdMediaPartnerResponse
|
||||||
import kr.co.vividnext.sodalive.marketing.QAdMediaPartner.adMediaPartner
|
import kr.co.vividnext.sodalive.marketing.QAdMediaPartner.adMediaPartner
|
||||||
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
|
||||||
|
|
||||||
interface AdMediaPartnerRepository : JpaRepository<AdMediaPartner, Long>, AdMediaPartnerQueryRepository
|
interface AdMediaPartnerRepository : JpaRepository<AdMediaPartner, Long>, AdMediaPartnerQueryRepository
|
||||||
|
|
||||||
interface AdMediaPartnerQueryRepository {
|
interface AdMediaPartnerQueryRepository {
|
||||||
fun findByPid(pid: String): AdMediaPartner?
|
fun findByPid(pid: String): AdMediaPartner?
|
||||||
|
fun getMediaPartnerList(offset: Long, limit: Long): List<GetAdminAdMediaPartnerResponse>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
|
@ -19,4 +26,41 @@ class AdMediaPartnerQueryRepositoryImpl(private val queryFactory: JPAQueryFactor
|
||||||
.where(adMediaPartner.pid.eq(pid), adMediaPartner.isActive.isTrue)
|
.where(adMediaPartner.pid.eq(pid), adMediaPartner.isActive.isTrue)
|
||||||
.fetchFirst()
|
.fetchFirst()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun getMediaPartnerList(offset: Long, limit: Long): List<GetAdminAdMediaPartnerResponse> {
|
||||||
|
return queryFactory
|
||||||
|
.select(
|
||||||
|
QGetAdminAdMediaPartnerResponse(
|
||||||
|
adMediaPartner.id,
|
||||||
|
adMediaPartner.mediaGroup,
|
||||||
|
adMediaPartner.pid,
|
||||||
|
adMediaPartner.pidName,
|
||||||
|
adMediaPartner.type,
|
||||||
|
adMediaPartner.utmSource,
|
||||||
|
adMediaPartner.utmMedium,
|
||||||
|
adMediaPartner.isActive,
|
||||||
|
getFormattedDate(adMediaPartner.createdAt),
|
||||||
|
Expressions.constant("")
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.from(adMediaPartner)
|
||||||
|
.orderBy(adMediaPartner.isActive.desc(), adMediaPartner.id.asc())
|
||||||
|
.offset(offset)
|
||||||
|
.limit(limit)
|
||||||
|
.fetch()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getFormattedDate(dateTimePath: DateTimePath<LocalDateTime>): StringTemplate {
|
||||||
|
return Expressions.stringTemplate(
|
||||||
|
"DATE_FORMAT({0}, {1})",
|
||||||
|
Expressions.dateTimeTemplate(
|
||||||
|
LocalDateTime::class.java,
|
||||||
|
"CONVERT_TZ({0},{1},{2})",
|
||||||
|
dateTimePath,
|
||||||
|
"UTC",
|
||||||
|
"Asia/Seoul"
|
||||||
|
),
|
||||||
|
"%Y-%m-%d %H:%i:%s"
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue