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.
70 lines
2.5 KiB
Scala
70 lines
2.5 KiB
Scala
package com.twitter.follow_recommendations.common.candidate_sources.geo
|
|
|
|
import com.google.inject.Singleton
|
|
import com.google.inject.name.Named
|
|
import com.twitter.conversions.DurationOps._
|
|
import com.twitter.finagle.stats.StatsReceiver
|
|
import com.twitter.follow_recommendations.common.candidate_sources.base.CachedCandidateSource
|
|
import com.twitter.follow_recommendations.common.candidate_sources.base.StratoFetcherWithUnitViewSource
|
|
import com.twitter.follow_recommendations.common.constants.GuiceNamedConstants
|
|
import com.twitter.follow_recommendations.common.models.AccountProof
|
|
import com.twitter.follow_recommendations.common.models.CandidateUser
|
|
import com.twitter.follow_recommendations.common.models.PopularInGeoProof
|
|
import com.twitter.follow_recommendations.common.models.Reason
|
|
import com.twitter.hermit.pop_geo.thriftscala.PopUsersInPlace
|
|
import com.twitter.product_mixer.core.model.common.identifier.CandidateSourceIdentifier
|
|
import com.twitter.strato.client.Fetcher
|
|
import com.twitter.util.Duration
|
|
import javax.inject.Inject
|
|
|
|
@Singleton
|
|
class BasePopGeoSource @Inject() (
|
|
@Named(GuiceNamedConstants.POP_USERS_IN_PLACE_FETCHER) fetcher: Fetcher[
|
|
String,
|
|
Unit,
|
|
PopUsersInPlace
|
|
]) extends StratoFetcherWithUnitViewSource[String, PopUsersInPlace](
|
|
fetcher,
|
|
BasePopGeoSource.Identifier) {
|
|
|
|
override def map(target: String, candidates: PopUsersInPlace): Seq[CandidateUser] =
|
|
BasePopGeoSource.map(target, candidates)
|
|
}
|
|
|
|
object BasePopGeoSource {
|
|
val Identifier: CandidateSourceIdentifier = CandidateSourceIdentifier("BasePopGeoSource")
|
|
val MaxResults = 200
|
|
|
|
def map(target: String, candidates: PopUsersInPlace): Seq[CandidateUser] =
|
|
candidates.popUsers.sortBy(-_.score).take(BasePopGeoSource.MaxResults).view.map { candidate =>
|
|
CandidateUser(
|
|
id = candidate.userId,
|
|
score = Some(candidate.score),
|
|
reason = Some(
|
|
Reason(
|
|
Some(
|
|
AccountProof(
|
|
popularInGeoProof = Some(PopularInGeoProof(location = candidates.place))
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
}
|
|
}
|
|
|
|
@Singleton
|
|
class PopGeoSource @Inject() (basePopGeoSource: BasePopGeoSource, statsReceiver: StatsReceiver)
|
|
extends CachedCandidateSource[String, CandidateUser](
|
|
basePopGeoSource,
|
|
PopGeoSource.MaxCacheSize,
|
|
PopGeoSource.CacheTTL,
|
|
statsReceiver,
|
|
PopGeoSource.Identifier)
|
|
|
|
object PopGeoSource {
|
|
val Identifier: CandidateSourceIdentifier = CandidateSourceIdentifier("PopGeoSource")
|
|
val MaxCacheSize = 20000
|
|
val CacheTTL: Duration = 1.hours
|
|
}
|