the-algorithm/follow-recommendations-service/common/src/main/scala/com/twitter/follow_recommendations/common/candidate_sources/sims/SimsExperimentalStore.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

37 lines
1.4 KiB
Scala

package com.twitter.follow_recommendations.common.candidate_sources.sims
import com.google.inject.Singleton
import com.twitter.finagle.stats.StatsReceiver
import com.twitter.hermit.model.Algorithm
import com.twitter.product_mixer.core.model.common.identifier.CandidateSourceIdentifier
import com.twitter.strato.generated.client.recommendations.similarity.SimilarUsersBySimsExperimentalOnUserClientColumn
import com.twitter.util.Duration
import javax.inject.Inject
@Singleton
class SimsExperimentalStore @Inject() (
simsExperimentalOnUserClientColumn: SimilarUsersBySimsExperimentalOnUserClientColumn)
extends StratoBasedSimsCandidateSourceWithUnitView(
fetcher = simsExperimentalOnUserClientColumn.fetcher,
identifier = SimsExperimentalStore.Identifier
)
@Singleton
class CachedSimsExperimentalStore @Inject() (
simsExperimentalOnUserClientColumn: SimilarUsersBySimsExperimentalOnUserClientColumn,
statsReceiver: StatsReceiver)
extends CacheBasedSimsStore(
id = SimsExperimentalStore.Identifier,
fetcher = simsExperimentalOnUserClientColumn.fetcher,
maxCacheSize = SimsExperimentalStore.MaxCacheSize,
cacheTtl = SimsExperimentalStore.CacheTTL,
statsReceiver = statsReceiver.scope("CachedSimsExperimentalStore", "cache")
)
object SimsExperimentalStore {
val Identifier = CandidateSourceIdentifier(Algorithm.Sims.toString)
val MaxCacheSize = 1000
val CacheTTL: Duration = Duration.fromHours(12)
}