com.azure.core.util.ClientOptions Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.core.util;
import com.azure.core.annotation.Fluent;
import com.azure.core.http.policy.UserAgentPolicy;
import com.azure.core.util.logging.ClientLogger;
import java.util.Collections;
/**
* General configuration options for clients.
*/
@Fluent
public class ClientOptions {
private static final int MAX_APPLICATION_ID_LENGTH = 24;
private static final String INVALID_APPLICATION_ID_LENGTH = "'applicationId' length cannot be greater than "
+ MAX_APPLICATION_ID_LENGTH;
private static final String INVALID_APPLICATION_ID_SPACE = "'applicationId' cannot contain spaces.";
// ClientOptions is a commonly used class, use a static logger.
private static final ClientLogger LOGGER = new ClientLogger(ClientOptions.class);
private Iterable headers;
private String applicationId;
private MetricsOptions metricsOptions;
/**
* Creates a new instance of {@link ClientOptions}.
*/
public ClientOptions() {
}
/**
* Gets the application ID.
*
* @return The application ID.
*/
public String getApplicationId() {
return applicationId;
}
/**
* Sets the application ID.
*
* The {@code applicationId} is used to configure {@link UserAgentPolicy} for telemetry/monitoring purposes.
*
* See Azure Core: Telemetry
* policy for additional information.
*
*
Code Samples
*
* Create ClientOptions with application ID 'myApplicationId'
*
*
*
* ClientOptions clientOptions = new ClientOptions()
* .setApplicationId("myApplicationId");
*
*
*
* @param applicationId The application ID.
*
* @return The updated ClientOptions object.
*
* @throws IllegalArgumentException If {@code applicationId} contains spaces or is larger than 24 characters in
* length.
*/
public ClientOptions setApplicationId(String applicationId) {
if (!CoreUtils.isNullOrEmpty(applicationId)) {
if (applicationId.length() > MAX_APPLICATION_ID_LENGTH) {
throw LOGGER.logExceptionAsError(new IllegalArgumentException(INVALID_APPLICATION_ID_LENGTH));
} else if (applicationId.contains(" ")) {
throw LOGGER.logExceptionAsError(new IllegalArgumentException(INVALID_APPLICATION_ID_SPACE));
}
}
this.applicationId = applicationId;
return this;
}
/**
* Sets the {@link Header Headers}.
*
* The passed headers are applied to each request sent with the client.
*
* This overwrites all previously set headers.
*
*
Code Samples
*
* Create ClientOptions with Header 'myCustomHeader':'myStaticValue'
*
*
*
* ClientOptions clientOptions = new ClientOptions()
* .setHeaders(Collections.singletonList(new Header("myCustomHeader", "myStaticValue")));
*
*
*
* @param headers The headers.
* @return The updated {@link ClientOptions} object.
*/
public ClientOptions setHeaders(Iterable headers) {
this.headers = headers;
return this;
}
/**
* Gets the {@link Header Headers}.
*
* @return The {@link Header Headers}, if headers weren't set previously an empty list is returned.
*/
public Iterable getHeaders() {
if (headers == null) {
return Collections.emptyList();
}
return headers;
}
/**
* Sets {@link MetricsOptions} that are applied to each metric reported by the client.
* Use metrics options to enable and disable metrics or pass implementation-specific configuration.
*
* @param metricsOptions instance of {@link MetricsOptions} to set.
* @return The updated {@link ClientOptions} object.
*/
public ClientOptions setMetricsOptions(MetricsOptions metricsOptions) {
this.metricsOptions = metricsOptions;
return this;
}
/**
* Gets {@link MetricsOptions}
* @return The {@link MetricsOptions} instance, if metric options weren't set previously, {@code null} is returned.
*/
public MetricsOptions getMetricsOptions() {
return metricsOptions;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy