the-algorithm/recos-injector/server/src/main/scala/com/twitter/recosinjector/edges/UnifiedUserActionToUserAdGraphBuilder.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

45 lines
1.4 KiB
Scala

package com.twitter.recosinjector.edges
import com.twitter.finagle.stats.StatsReceiver
import com.twitter.recos.util.Action
import com.twitter.recosinjector.util.UuaEngagementEventDetails
import com.twitter.util.Future
class UnifiedUserActionToUserAdGraphBuilder(
userTweetEntityEdgeBuilder: UserTweetEntityEdgeBuilder
)(
override implicit val statsReceiver: StatsReceiver)
extends EventToMessageBuilder[UuaEngagementEventDetails, UserTweetEntityEdge] {
override def shouldProcessEvent(event: UuaEngagementEventDetails): Future[Boolean] = {
event.userTweetEngagement.action match {
case Action.Click | Action.VideoPlayback75 | Action.Favorite => Future(true)
case _ => Future(false)
}
}
override def buildEdges(details: UuaEngagementEventDetails): Future[Seq[UserTweetEntityEdge]] = {
val engagement = details.userTweetEngagement
val tweetDetails = engagement.tweetDetails
Future.value(
Seq(
UserTweetEntityEdge(
sourceUser = engagement.engageUserId,
targetTweet = engagement.tweetId,
action = engagement.action,
metadata = engagement.engagementTimeMillis,
cardInfo = engagement.tweetDetails.map(_.cardInfo.toByte),
entitiesMap = None,
tweetDetails = tweetDetails
)))
}
override def filterEdges(
event: UuaEngagementEventDetails,
edges: Seq[UserTweetEntityEdge]
): Future[Seq[UserTweetEntityEdge]] = {
Future(edges)
}
}