mirror of
https://github.com/twitter/the-algorithm.git
synced 2025-01-07 01:48:16 +01:00
Merge ab82629574
into 72eda9a24f
This commit is contained in:
commit
6555342918
@ -7,56 +7,51 @@ import com.twitter.geoduck.common.thriftscala.TransactionLocation
|
|||||||
import com.twitter.geoduck.common.thriftscala.UserLocationRequest
|
import com.twitter.geoduck.common.thriftscala.UserLocationRequest
|
||||||
import com.twitter.geoduck.thriftscala.LocationService
|
import com.twitter.geoduck.thriftscala.LocationService
|
||||||
import com.twitter.stitch.Stitch
|
import com.twitter.stitch.Stitch
|
||||||
import javax.inject.Inject
|
import javax.inject.{Inject, Singleton}
|
||||||
import javax.inject.Singleton
|
|
||||||
|
|
||||||
@Singleton
|
@Singleton
|
||||||
class LocationServiceClient @Inject() (locationService: LocationService.MethodPerEndpoint) {
|
class LocationServiceClient @Inject() (locationService: LocationService.MethodPerEndpoint) {
|
||||||
def getGeohashAndCountryCode(userId: Long): Stitch[GeohashAndCountryCode] = {
|
def getGeohashAndCountryCode(userId: Long): Stitch[GeohashAndCountryCode] = {
|
||||||
Stitch
|
val request = UserLocationRequest(
|
||||||
.callFuture {
|
|
||||||
locationService
|
|
||||||
.userLocation(
|
|
||||||
UserLocationRequest(
|
|
||||||
Seq(userId),
|
Seq(userId),
|
||||||
Some(PlaceQuery(allPlaceTypes = Some(true))),
|
Some(PlaceQuery(allPlaceTypes = Some(true))),
|
||||||
simpleReverseGeocode = true))
|
simpleReverseGeocode = true
|
||||||
.map(_.found.get(userId)).map { transactionLocationOpt =>
|
)
|
||||||
val geohashOpt = transactionLocationOpt.flatMap(getGeohashFromTransactionLocation)
|
|
||||||
val countryCodeOpt =
|
for {
|
||||||
transactionLocationOpt.flatMap(_.simpleRgcResult.flatMap(_.countryCodeAlpha2))
|
transactionLocation <- locationService.userLocation(request).map(_.found(userId))
|
||||||
GeohashAndCountryCode(geohashOpt, countryCodeOpt)
|
geohashOpt <- getGeohashFromTransactionLocation(transactionLocation)
|
||||||
}
|
countryCodeOpt = transactionLocation.simpleRgcResult.flatMap(_.countryCodeAlpha2)
|
||||||
}
|
} yield GeohashAndCountryCode(geohashOpt, countryCodeOpt)
|
||||||
}
|
}
|
||||||
|
|
||||||
private[this] def getGeohashFromTransactionLocation(
|
private[this] def getGeohashFromTransactionLocation(
|
||||||
transactionLocation: TransactionLocation
|
transactionLocation: TransactionLocation
|
||||||
): Option[String] = {
|
): Stitch[Option[String]] = Stitch.from {
|
||||||
transactionLocation.geohash.flatMap { geohash =>
|
transactionLocation.geohash match {
|
||||||
|
case Some(geohash) =>
|
||||||
val geohashPrefixLength = transactionLocation.locationSource match {
|
val geohashPrefixLength = transactionLocation.locationSource match {
|
||||||
// if location source is logical, keep the first 4 chars in geohash
|
|
||||||
case Some(LocationSource.Logical) => Some(4)
|
case Some(LocationSource.Logical) => Some(4)
|
||||||
// if location source is physical, keep the prefix according to accuracy
|
|
||||||
// accuracy is the accuracy of GPS readings in the unit of meter
|
|
||||||
case Some(LocationSource.Physical) =>
|
case Some(LocationSource.Physical) =>
|
||||||
transactionLocation.coordinate.flatMap { coordinate =>
|
transactionLocation.coordinate.flatMap { coordinate =>
|
||||||
coordinate.accuracy match {
|
coordinate.accuracy match {
|
||||||
case Some(accuracy) if (accuracy < 50) => Some(7)
|
case Some(accuracy) if accuracy < 50 => Some(7)
|
||||||
case Some(accuracy) if (accuracy < 200) => Some(6)
|
case Some(accuracy) if accuracy < 200 => Some(6)
|
||||||
case Some(accuracy) if (accuracy < 1000) => Some(5)
|
case Some(accuracy) if accuracy < 1000 => Some(5)
|
||||||
case Some(accuracy) if (accuracy < 50000) => Some(4)
|
case Some(accuracy) if accuracy < 50000 => Some(4)
|
||||||
case Some(accuracy) if (accuracy < 100000) => Some(3)
|
case Some(accuracy) if accuracy < 100000 => Some(3)
|
||||||
case _ => None
|
case _ => None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case Some(LocationSource.Model) => Some(4)
|
case Some(LocationSource.Model) => Some(4)
|
||||||
case _ => None
|
case _ => None
|
||||||
}
|
}
|
||||||
|
|
||||||
geohashPrefixLength match {
|
geohashPrefixLength match {
|
||||||
case Some(l: Int) => geohash.stringGeohash.map(_.take(l))
|
case Some(l: Int) => Stitch.value(Some(geohash.stringGeohash.take(l)))
|
||||||
case _ => None
|
case _ => Stitch.value(None)
|
||||||
}
|
}
|
||||||
|
case _ => Stitch.value(None)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user