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
ConstructorDescriptionTracingHttpRequesterFilter
(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 aStreamingHttpClientFilter
using the providedStreamingHttpClientFilter
.create
(FilterableStreamingHttpConnection connection) Create aStreamingHttpConnectionFilter
using the providedFilterableStreamingHttpConnection
.Return anExecutionStrategy
that describes the offloads required by the influencer.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods 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
-true
to 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
- theFormat
to 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
- theFormat
to use to inject/extract trace info to/fromTextMap
.componentName
- The component name used during building new spans.
-
-
Method Details
-
create
Description copied from interface:StreamingHttpClientFilterFactory
Creates aStreamingHttpClientFilter
using the providedStreamingHttpClientFilter
.- Specified by:
create
in interfaceStreamingHttpClientFilterFactory
- Parameters:
client
-FilterableStreamingHttpClient
to filter- Returns:
StreamingHttpClientFilter
using the providedStreamingHttpClientFilter
.
-
create
Description copied from interface:StreamingHttpConnectionFilterFactory
Create aStreamingHttpConnectionFilter
using the providedFilterableStreamingHttpConnection
.- Specified by:
create
in interfaceStreamingHttpConnectionFilterFactory
- Parameters:
connection
-FilterableStreamingHttpConnection
to filter- Returns:
StreamingHttpConnectionFilter
using the providedFilterableStreamingHttpConnection
.
-
requiredOffloads
Description copied from interface:HttpExecutionStrategyInfluencer
Return anExecutionStrategy
that 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:
requiredOffloads
in interfaceExecutionStrategyInfluencer<HttpExecutionStrategy>
- Specified by:
requiredOffloads
in interfaceHttpExecutionStrategyInfluencer
- Returns:
- the
ExecutionStrategy
required by the influencer.
-