the-algorithm/product-mixer/component-library/src/main/scala/com/twitter/product_mixer/component_library/premarshaller/urt/builder/MarkUnreadInstructionBuilder.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

33 lines
1.2 KiB
Scala

package com.twitter.product_mixer.component_library.premarshaller.urt.builder
import com.twitter.product_mixer.core.model.marshalling.response.urt.MarkEntriesUnreadInstruction
import com.twitter.product_mixer.core.model.marshalling.response.urt.TimelineEntry
import com.twitter.product_mixer.core.pipeline.PipelineQuery
import com.twitter.product_mixer.core.model.marshalling.response.urt.metadata.MarkUnreadableEntry
/**
* Build a MarkUnreadEntries instruction
*
* Note that this implementation currently supports top-level entries, but not module item entries.
*/
case class MarkUnreadInstructionBuilder[Query <: PipelineQuery](
override val includeInstruction: IncludeInstruction[Query] = AlwaysInclude)
extends UrtInstructionBuilder[Query, MarkEntriesUnreadInstruction] {
override def build(
query: Query,
entries: Seq[TimelineEntry]
): Seq[MarkEntriesUnreadInstruction] = {
if (includeInstruction(query, entries)) {
val filteredEntries = entries.collect {
case entry: MarkUnreadableEntry if entry.isMarkUnread.contains(true) =>
entry.entryIdentifier
}
if (filteredEntries.nonEmpty) Seq(MarkEntriesUnreadInstruction(filteredEntries))
else Seq.empty
} else {
Seq.empty
}
}
}