the-algorithm/home-mixer/server/src/main/scala/com/twitter/home_mixer/product/scored_tweets/query_transformer/earlybird/EarlybirdInNetworkQueryTransformer.scala

69 lines
2.7 KiB
Scala

package com.twitter.home_mixer.product.scored_tweets.query_transformer.earlybird
import com.twitter.conversions.DurationOps._
import com.twitter.core_workflows.user_model.{thriftscala => um}
import com.twitter.home_mixer.model.HomeFeatures.UserStateFeature
import com.twitter.home_mixer.model.request.HasDeviceContext
import com.twitter.home_mixer.product.scored_tweets.query_transformer.earlybird.EarlybirdInNetworkQueryTransformer._
import com.twitter.product_mixer.component_library.feature_hydrator.query.social_graph.SGSFollowedUsersFeature
import com.twitter.product_mixer.core.functional_component.transformer.CandidatePipelineQueryTransformer
import com.twitter.product_mixer.core.model.common.identifier.CandidatePipelineIdentifier
import com.twitter.product_mixer.core.pipeline.PipelineQuery
import com.twitter.product_mixer.core.quality_factor.HasQualityFactorStatus
import com.twitter.search.earlybird.{thriftscala => eb}
import com.twitter.timelines.common.model.TweetKindOption
object EarlybirdInNetworkQueryTransformer {
private val DefaultSinceDuration = 24.hours
private val ExpandedSinceDuration = 48.hours
private val MaxTweetsToFetch = 600
private val TensorflowModel = Some("timelines_recap_replica")
private val TweetKindOptions: TweetKindOption.ValueSet = TweetKindOption(
includeReplies = true,
includeRetweets = true,
includeOriginalTweetsAndQuotes = true,
includeExtendedReplies = true
)
private val UserStatesForExtendedSinceDuration: Set[um.UserState] = Set(
um.UserState.Light,
um.UserState.MediumNonTweeter,
um.UserState.MediumTweeter,
um.UserState.NearZero,
um.UserState.New,
um.UserState.VeryLight
)
}
case class EarlybirdInNetworkQueryTransformer[
Query <: PipelineQuery with HasQualityFactorStatus with HasDeviceContext
](
candidatePipelineIdentifier: CandidatePipelineIdentifier,
override val clientId: Option[String])
extends CandidatePipelineQueryTransformer[Query, eb.EarlybirdRequest]
with EarlybirdQueryTransformer[Query] {
override val tweetKindOptions: TweetKindOption.ValueSet = TweetKindOptions
override val maxTweetsToFetch: Int = MaxTweetsToFetch
override val tensorflowModel: Option[String] = TensorflowModel
override def transform(query: Query): eb.EarlybirdRequest = {
val userState = query.features.get.getOrElse(UserStateFeature, None)
val sinceDuration =
if (userState.exists(UserStatesForExtendedSinceDuration.contains)) ExpandedSinceDuration
else DefaultSinceDuration
val followedUserIds =
query.features
.map(
_.getOrElse(
SGSFollowedUsersFeature,
Seq.empty)).toSeq.flatten.toSet + query.getRequiredUserId
buildEarlybirdQuery(query, sinceDuration, followedUserIds)
}
}