mirror of
https://github.com/twitter/the-algorithm.git
synced 2024-06-30 23:16:08 +02:00
ef4c5eb65e
Please note we have force-pushed a new initial commit in order to remove some publicly-available Twitter user information. Note that this process may be required in the future.
50 lines
2.0 KiB
Scala
50 lines
2.0 KiB
Scala
package com.twitter.home_mixer.functional_component.feature_hydrator
|
|
|
|
import com.google.inject.name.Named
|
|
import com.twitter.finagle.stats.StatsReceiver
|
|
import com.twitter.home_mixer.param.HomeMixerInjectionNames.RealTimeInteractionGraphUserVertexCache
|
|
import com.twitter.home_mixer.util.ObservedKeyValueResultHandler
|
|
import com.twitter.product_mixer.core.feature.Feature
|
|
import com.twitter.product_mixer.core.feature.featuremap.FeatureMap
|
|
import com.twitter.product_mixer.core.feature.featuremap.FeatureMapBuilder
|
|
import com.twitter.product_mixer.core.functional_component.feature_hydrator.QueryFeatureHydrator
|
|
import com.twitter.product_mixer.core.model.common.identifier.FeatureHydratorIdentifier
|
|
import com.twitter.product_mixer.core.pipeline.PipelineQuery
|
|
import com.twitter.servo.cache.ReadCache
|
|
import com.twitter.stitch.Stitch
|
|
import com.twitter.wtf.real_time_interaction_graph.{thriftscala => ig}
|
|
|
|
import javax.inject.Inject
|
|
import javax.inject.Singleton
|
|
|
|
object RealTimeInteractionGraphUserVertexQueryFeature
|
|
extends Feature[PipelineQuery, Option[ig.UserVertex]]
|
|
|
|
@Singleton
|
|
class RealTimeInteractionGraphUserVertexQueryFeatureHydrator @Inject() (
|
|
@Named(RealTimeInteractionGraphUserVertexCache) client: ReadCache[Long, ig.UserVertex],
|
|
override val statsReceiver: StatsReceiver)
|
|
extends QueryFeatureHydrator[PipelineQuery]
|
|
with ObservedKeyValueResultHandler {
|
|
|
|
override val identifier: FeatureHydratorIdentifier =
|
|
FeatureHydratorIdentifier("RealTimeInteractionGraphUserVertex")
|
|
|
|
override val features: Set[Feature[_, _]] = Set(RealTimeInteractionGraphUserVertexQueryFeature)
|
|
|
|
override val statScope: String = identifier.toString
|
|
|
|
override def hydrate(query: PipelineQuery): Stitch[FeatureMap] = {
|
|
val userId = query.getRequiredUserId
|
|
|
|
Stitch.callFuture(
|
|
client.get(Seq(userId)).map { results =>
|
|
val feature = observedGet(key = Some(userId), keyValueResult = results)
|
|
FeatureMapBuilder()
|
|
.add(RealTimeInteractionGraphUserVertexQueryFeature, feature)
|
|
.build()
|
|
}
|
|
)
|
|
}
|
|
}
|