com.azure.core.http.HttpPipelineBuilder Maven / Gradle / Ivy
Show all versions of azure-core Show documentation
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.core.http;
import com.azure.core.http.policy.HttpPipelinePolicy;
import com.azure.core.implementation.http.policy.InstrumentationPolicy;
import com.azure.core.implementation.http.UrlSanitizer;
import com.azure.core.util.ClientOptions;
import com.azure.core.util.HttpClientOptions;
import com.azure.core.util.TracingOptions;
import com.azure.core.util.tracing.Tracer;
import com.azure.core.util.tracing.TracerProvider;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Set;
/**
* This class provides a fluent builder API to help aid the configuration and instantiation of the {@link HttpPipeline},
* calling {@link HttpPipelineBuilder#build() build} constructs an instance of the pipeline.
*
*
* A pipeline is configured with a HttpClient that sends the request, if no client is set a default is used.
* A pipeline may be configured with a list of policies that are applied to each request.
*
*
*
* Code Samples
*
*
*
* Create a pipeline without configuration
*
*
*
*
* HttpPipeline pipeline = new HttpPipelineBuilder().build();
*
*
*
*
* Create a pipeline using the default HTTP client and a retry policy
*
*
*
*
* HttpPipeline pipeline = new HttpPipelineBuilder()
* .httpClient(HttpClient.createDefault())
* .policies(new RetryPolicy())
* .build();
*
*
*
* @see HttpPipeline
*/
public class HttpPipelineBuilder {
private HttpClient httpClient;
private List pipelinePolicies;
private ClientOptions clientOptions;
private Tracer tracer;
/**
* Creates a new instance of HttpPipelineBuilder that can configure options for the {@link HttpPipeline} before
* creating an instance of it.
*/
public HttpPipelineBuilder() {
}
/**
* Creates an {@link HttpPipeline} based on options set in the builder. Every time {@code build()} is called, a new
* instance of {@link HttpPipeline} is created.
*
* If HttpClient is not set then a default HttpClient is used.
*
* @return A HttpPipeline with the options set from the builder.
*/
public HttpPipeline build() {
List policies = (pipelinePolicies == null) ? new ArrayList<>() : pipelinePolicies;
HttpClient client;
if (httpClient != null) {
client = httpClient;
} else if (clientOptions instanceof HttpClientOptions) {
client = HttpClient.createDefault((HttpClientOptions) clientOptions);
} else {
client = HttpClient.createDefault();
}
configureTracing(policies, clientOptions);
return new HttpPipeline(client, policies, tracer);
}
private void configureTracing(List policies, ClientOptions clientOptions) {
if (tracer == null) {
TracingOptions tracingOptions = clientOptions == null ? null : clientOptions.getTracingOptions();
tracer = TracerProvider.getDefaultProvider().createTracer("azure-core", null, null, tracingOptions);
}
for (HttpPipelinePolicy policy : policies) {
if (policy instanceof InstrumentationPolicy) {
UrlSanitizer sanitizer = new UrlSanitizer(getAllowedQueryParams(clientOptions));
((InstrumentationPolicy) policy).initialize(tracer, sanitizer);
}
}
}
private static Set getAllowedQueryParams(ClientOptions options) {
if (options == null || options.getTracingOptions() == null) {
return null;
}
return options.getTracingOptions().getAllowedTracingQueryParamNames();
}
/**
* Sets the HttpClient that the pipeline will use to send requests.
*
* @param httpClient The HttpClient the pipeline will use when sending requests.
* @return The updated HttpPipelineBuilder object.
*/
public HttpPipelineBuilder httpClient(HttpClient httpClient) {
this.httpClient = httpClient;
return this;
}
/**
* Adds {@link HttpPipelinePolicy policies} to the set of policies that the pipeline will use when sending
* requests.
*
* @param policies Policies to add to the policy set.
* @return The updated HttpPipelineBuilder object.
*/
public HttpPipelineBuilder policies(HttpPipelinePolicy... policies) {
if (pipelinePolicies == null) {
pipelinePolicies = new ArrayList<>();
}
this.pipelinePolicies.addAll(Arrays.asList(policies));
return this;
}
/**
* Sets the ClientOptions that will configure the pipeline.
*
* @param clientOptions The ClientOptions that will configure the pipeline.
* @return The updated HttpPipelineBuilder object.
*/
public HttpPipelineBuilder clientOptions(ClientOptions clientOptions) {
this.clientOptions = clientOptions;
return this;
}
/**
* Sets the Tracer to trace logical and HTTP calls.
*
* @param tracer The Tracer instance.
* @return The updated HttpPipelineBuilder object.
*/
public HttpPipelineBuilder tracer(Tracer tracer) {
this.tracer = tracer;
return this;
}
}