parent
5db181aa74
commit
a17a6a41da
|
@ -1,7 +1,9 @@
|
|||
package kr.co.vividnext.sodalive.admin.marketing
|
||||
|
||||
import kr.co.vividnext.sodalive.common.ApiResponse
|
||||
import org.springframework.data.domain.Pageable
|
||||
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.PutMapping
|
||||
import org.springframework.web.bind.annotation.RequestBody
|
||||
|
@ -21,4 +23,12 @@ class AdminAdMediaPartnerController(private val service: AdminAdMediaPartnerServ
|
|||
fun updateMediaPartner(
|
||||
@RequestBody request: UpdateAdMediaPartnerRequest
|
||||
) = 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.marketing.AdMediaPartnerRepository
|
||||
import kr.co.vividnext.sodalive.marketing.AdMediaPartnerType
|
||||
import org.springframework.data.repository.findByIdOrNull
|
||||
import org.springframework.stereotype.Service
|
||||
import org.springframework.transaction.annotation.Transactional
|
||||
import java.net.URLEncoder
|
||||
|
||||
@Service
|
||||
class AdminAdMediaPartnerService(private val repository: AdMediaPartnerRepository) {
|
||||
|
@ -47,4 +49,37 @@ class AdminAdMediaPartnerService(private val repository: AdMediaPartnerRepositor
|
|||
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
|
||||
|
||||
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 kr.co.vividnext.sodalive.admin.marketing.GetAdminAdMediaPartnerResponse
|
||||
import kr.co.vividnext.sodalive.admin.marketing.QGetAdminAdMediaPartnerResponse
|
||||
import kr.co.vividnext.sodalive.marketing.QAdMediaPartner.adMediaPartner
|
||||
import org.springframework.data.jpa.repository.JpaRepository
|
||||
import org.springframework.stereotype.Repository
|
||||
import java.time.LocalDateTime
|
||||
|
||||
interface AdMediaPartnerRepository : JpaRepository<AdMediaPartner, Long>, AdMediaPartnerQueryRepository
|
||||
|
||||
interface AdMediaPartnerQueryRepository {
|
||||
fun findByPid(pid: String): AdMediaPartner?
|
||||
fun getMediaPartnerList(offset: Long, limit: Long): List<GetAdminAdMediaPartnerResponse>
|
||||
}
|
||||
|
||||
@Repository
|
||||
|
@ -19,4 +26,41 @@ class AdMediaPartnerQueryRepositoryImpl(private val queryFactory: JPAQueryFactor
|
|||
.where(adMediaPartner.pid.eq(pid), adMediaPartner.isActive.isTrue)
|
||||
.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