the-algorithm/product-mixer/component-library/src/main/scala/com/twitter/product_mixer/component_library/module/TimelineRankerClientModule.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

48 lines
1.6 KiB
Scala

package com.twitter.product_mixer.component_library.module
import com.twitter.conversions.DurationOps._
import com.twitter.finagle.ThriftMux
import com.twitter.finagle.mtls.authentication.ServiceIdentifier
import com.twitter.finagle.mtls.client.MtlsStackClient._
import com.twitter.finagle.thriftmux.MethodBuilder
import com.twitter.finatra.mtls.thriftmux.modules.MtlsClient
import com.twitter.inject.Injector
import com.twitter.inject.thrift.modules.ThriftMethodBuilderClientModule
import com.twitter.timelineranker.{thriftscala => t}
import com.twitter.util.Duration
import org.apache.thrift.protocol.TCompactProtocol
object TimelineRankerClientModule
extends ThriftMethodBuilderClientModule[
t.TimelineRanker.ServicePerEndpoint,
t.TimelineRanker.MethodPerEndpoint
]
with MtlsClient {
override val label = "timeline-ranker"
override val dest = "/s/timelineranker/timelineranker:compactthrift"
override protected def configureMethodBuilder(
injector: Injector,
methodBuilder: MethodBuilder
): MethodBuilder = {
methodBuilder
.withTimeoutPerRequest(750.millis)
.withTimeoutTotal(750.millis)
}
override def configureThriftMuxClient(
injector: Injector,
client: ThriftMux.Client
): ThriftMux.Client = {
val serviceIdentifier = injector.instance[ServiceIdentifier]
super
.configureThriftMuxClient(injector, client)
.withProtocolFactory(new TCompactProtocol.Factory())
.withMutualTls(serviceIdentifier)
.withPerEndpointStats
}
override protected def sessionAcquisitionTimeout: Duration = 500.milliseconds
}