Class TracingHttpRequesterFilter
- All Implemented Interfaces:
HttpExecutionStrategyInfluencer,StreamingHttpClientFilterFactory,StreamingHttpConnectionFilterFactory,ExecutionStrategyInfluencer<HttpExecutionStrategy>
Append this filter before others that are expected to to see Scope for this request/response. Filters
appended after this filter that use operators with the after* prefix on
response meta data or the
StreamingHttpResponse.transformMessageBody(UnaryOperator) response message body}
(e.g. Publisher.afterFinally(Runnable)) will execute after this filter invokes Scope.close() and
therefore will not see the Span for the current request/response.
-
Constructor Summary
ConstructorsConstructorDescriptionTracingHttpRequesterFilter(io.opentracing.Tracer tracer, io.opentracing.propagation.Format<io.opentracing.propagation.TextMap> format, String componentName) Create a new instance.TracingHttpRequesterFilter(io.opentracing.Tracer tracer, String componentName) Create a new instance.TracingHttpRequesterFilter(io.opentracing.Tracer tracer, String componentName, boolean validateTraceKeyFormat) Create a new instance.TracingHttpRequesterFilter(io.opentracing.Tracer tracer, String componentName, io.opentracing.propagation.Format<HttpHeaders> format) Create a new instance. -
Method Summary
Modifier and TypeMethodDescriptioncreate(FilterableStreamingHttpClient client) Creates aStreamingHttpClientFilterusing the providedStreamingHttpClientFilter.create(FilterableStreamingHttpConnection connection) Create aStreamingHttpConnectionFilterusing the providedFilterableStreamingHttpConnection.Return anExecutionStrategythat describes the offloads required by the influencer.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.servicetalk.http.api.HttpExecutionStrategyInfluencer
influenceStrategy
-
Constructor Details
-
TracingHttpRequesterFilter
Create a new instance.- Parameters:
tracer- TheTracer.componentName- The component name used during building new spans.
-
TracingHttpRequesterFilter
public TracingHttpRequesterFilter(io.opentracing.Tracer tracer, String componentName, boolean validateTraceKeyFormat) Create a new instance.- Parameters:
tracer- TheTracer.componentName- The component name used during building new spans.validateTraceKeyFormat-trueto validate the contents of the trace ids.
-
TracingHttpRequesterFilter
public TracingHttpRequesterFilter(io.opentracing.Tracer tracer, String componentName, io.opentracing.propagation.Format<HttpHeaders> format) Create a new instance.- Parameters:
tracer- TheTracer.componentName- The component name used during building new spans.format- theFormatto use to inject/extract trace info to/fromHttpHeaders.
-
TracingHttpRequesterFilter
public TracingHttpRequesterFilter(io.opentracing.Tracer tracer, io.opentracing.propagation.Format<io.opentracing.propagation.TextMap> format, String componentName) Create a new instance.- Parameters:
tracer- TheTracer.format- theFormatto use to inject/extract trace info to/fromTextMap.componentName- The component name used during building new spans.
-
-
Method Details
-
create
Description copied from interface:StreamingHttpClientFilterFactoryCreates aStreamingHttpClientFilterusing the providedStreamingHttpClientFilter.- Specified by:
createin interfaceStreamingHttpClientFilterFactory- Parameters:
client-FilterableStreamingHttpClientto filter- Returns:
StreamingHttpClientFilterusing the providedStreamingHttpClientFilter.
-
create
Description copied from interface:StreamingHttpConnectionFilterFactoryCreate aStreamingHttpConnectionFilterusing the providedFilterableStreamingHttpConnection.- Specified by:
createin interfaceStreamingHttpConnectionFilterFactory- Parameters:
connection-FilterableStreamingHttpConnectionto filter- Returns:
StreamingHttpConnectionFilterusing the providedFilterableStreamingHttpConnection.
-
requiredOffloads
Description copied from interface:HttpExecutionStrategyInfluencerReturn anExecutionStrategythat describes the offloads required by the influencer.The provided default implementation requests offloading of all operations. Implementations that require no offloading should be careful to return
HttpExecutionStrategies.offloadNone()rather thanHttpExecutionStrategies.offloadNever(). Implementations should avoid returningHttpExecutionStrategies.defaultStrategy(), instead returning the strategy they require orHttpExecutionStrategies.offloadAll()if offloading for all paths is required (safe default).- Specified by:
requiredOffloadsin interfaceExecutionStrategyInfluencer<HttpExecutionStrategy>- Specified by:
requiredOffloadsin interfaceHttpExecutionStrategyInfluencer- Returns:
- the
ExecutionStrategyrequired by the influencer.
-