All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.core.http.HttpPipelineBuilder Maven / Gradle / Ivy

The newest version!
// 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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy