the-algorithm/product-mixer/component-library/src/main/scala/com/twitter/product_mixer/component_library/feature/featurestorev1/FeatureStoreV1QueryUserIdTweetCandidateAuthorIdFeature.scala
twitter-team ef4c5eb65e Twitter Recommendation Algorithm
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.
2023-03-31 17:36:31 -05:00

69 lines
2.8 KiB
Scala

package com.twitter.product_mixer.component_library.feature.featurestorev1
import com.twitter.ml.api.transform.FeatureRenameTransform
import com.twitter.ml.featurestore.catalog.entities
import com.twitter.ml.featurestore.lib.EdgeEntityId
import com.twitter.ml.featurestore.lib.EntityId
import com.twitter.ml.featurestore.lib.UserId
import com.twitter.ml.featurestore.lib.entity.Entity
import com.twitter.ml.featurestore.lib.entity.EntityWithId
import com.twitter.ml.featurestore.lib.feature.TimelinesAggregationFrameworkFeatureGroup
import com.twitter.ml.featurestore.lib.feature.{Feature => FSv1Feature}
import com.twitter.product_mixer.component_library.model.candidate.TweetAuthorIdFeature
import com.twitter.product_mixer.component_library.model.candidate.TweetCandidate
import com.twitter.product_mixer.core.feature.featuremap.FeatureMap
import com.twitter.product_mixer.core.feature.featurestorev1._
import com.twitter.product_mixer.core.pipeline.PipelineQuery
import com.twitter.timelines.configapi.FSParam
import scala.reflect.ClassTag
object FeatureStoreV1QueryUserIdTweetCandidateAuthorIdFeature {
def apply[Query <: PipelineQuery, Value](
feature: FSv1Feature[EdgeEntityId[UserId, UserId], Value],
legacyName: Option[String] = None,
defaultValue: Option[Value] = None,
enabledParam: Option[FSParam[Boolean]] = None
): FeatureStoreV1CandidateFeature[Query, TweetCandidate, _ <: EntityId, Value] =
FeatureStoreV1CandidateFeature(
feature,
QueryUserIdTweetCandidateAuthorIdEntity,
legacyName,
defaultValue,
enabledParam)
}
object FeatureStoreV1QueryUserIdTweetCandidateAuthorIdAggregateFeature {
def apply[Query <: PipelineQuery](
featureGroup: TimelinesAggregationFrameworkFeatureGroup[EdgeEntityId[UserId, UserId]],
enabledParam: Option[FSParam[Boolean]] = None,
keepLegacyNames: Boolean = false,
featureNameTransform: Option[FeatureRenameTransform] = None
): FeatureStoreV1CandidateFeatureGroup[Query, TweetCandidate, _ <: EntityId] =
FeatureStoreV1CandidateFeatureGroup(
featureGroup,
QueryUserIdTweetCandidateAuthorIdEntity,
enabledParam,
keepLegacyNames,
featureNameTransform
)(implicitly[ClassTag[EdgeEntityId[UserId, UserId]]])
}
object QueryUserIdTweetCandidateAuthorIdEntity
extends FeatureStoreV1CandidateEntity[
PipelineQuery,
TweetCandidate,
EdgeEntityId[UserId, UserId]
] {
override val entity: Entity[EdgeEntityId[UserId, UserId]] = entities.core.UserAuthor
override def entityWithId(
query: PipelineQuery,
tweet: TweetCandidate,
existingFeatures: FeatureMap
): EntityWithId[EdgeEntityId[UserId, UserId]] =
entity.withId(
EdgeEntityId(
UserId(query.getUserIdLoggedOutSupport),
UserId(existingFeatures.get(TweetAuthorIdFeature))))
}