mirror of
https://github.com/twitter/the-algorithm.git
synced 2024-06-01 08:48:46 +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.
33 lines
1.3 KiB
Scala
33 lines
1.3 KiB
Scala
package com.twitter.cr_mixer.module
|
|
|
|
import com.google.inject.Provides
|
|
import com.google.inject.Singleton
|
|
import com.twitter.bijection.scrooge.BinaryScalaCodec
|
|
import com.twitter.conversions.DurationOps._
|
|
import com.twitter.cr_mixer.model.ModuleNames
|
|
import com.twitter.cr_mixer.thriftscala.CrMixerTweetResponse
|
|
import com.twitter.finagle.memcached.{Client => MemcachedClient}
|
|
import com.twitter.finagle.stats.StatsReceiver
|
|
import com.twitter.inject.TwitterModule
|
|
import com.twitter.hermit.store.common.ReadableWritableStore
|
|
import com.twitter.hermit.store.common.ObservedReadableWritableMemcacheStore
|
|
import com.twitter.simclusters_v2.common.UserId
|
|
import javax.inject.Named
|
|
|
|
object TweetRecommendationResultsStoreModule extends TwitterModule {
|
|
@Provides
|
|
@Singleton
|
|
def providesTweetRecommendationResultsStore(
|
|
@Named(ModuleNames.TweetRecommendationResultsCache) tweetRecommendationResultsCacheClient: MemcachedClient,
|
|
statsReceiver: StatsReceiver
|
|
): ReadableWritableStore[UserId, CrMixerTweetResponse] = {
|
|
ObservedReadableWritableMemcacheStore.fromCacheClient(
|
|
cacheClient = tweetRecommendationResultsCacheClient,
|
|
ttl = 24.hours)(
|
|
valueInjection = BinaryScalaCodec(CrMixerTweetResponse),
|
|
statsReceiver = statsReceiver.scope("TweetRecommendationResultsMemcacheStore"),
|
|
keyToString = { k: UserId => k.toString }
|
|
)
|
|
}
|
|
}
|