com.azure.resourcemanager.delegatednetwork.DelegatedNetworkManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-resourcemanager-delegatednetwork Show documentation
Show all versions of azure-resourcemanager-delegatednetwork Show documentation
This package contains Microsoft Azure SDK for DelegatedNetwork Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt. DNC web api provides way to create, get and delete dnc controller. Package tag package-2021-03-15.
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.
package com.azure.resourcemanager.delegatednetwork;
import com.azure.core.credential.TokenCredential;
import com.azure.core.http.HttpClient;
import com.azure.core.http.HttpPipeline;
import com.azure.core.http.HttpPipelineBuilder;
import com.azure.core.http.policy.AddDatePolicy;
import com.azure.core.http.policy.BearerTokenAuthenticationPolicy;
import com.azure.core.http.policy.HttpLogOptions;
import com.azure.core.http.policy.HttpLoggingPolicy;
import com.azure.core.http.policy.HttpPipelinePolicy;
import com.azure.core.http.policy.HttpPolicyProviders;
import com.azure.core.http.policy.RequestIdPolicy;
import com.azure.core.http.policy.RetryPolicy;
import com.azure.core.http.policy.UserAgentPolicy;
import com.azure.core.management.profile.AzureProfile;
import com.azure.core.util.Configuration;
import com.azure.core.util.logging.ClientLogger;
import com.azure.resourcemanager.delegatednetwork.fluent.Dnc;
import com.azure.resourcemanager.delegatednetwork.implementation.ControllersImpl;
import com.azure.resourcemanager.delegatednetwork.implementation.DelegatedNetworksImpl;
import com.azure.resourcemanager.delegatednetwork.implementation.DelegatedSubnetServicesImpl;
import com.azure.resourcemanager.delegatednetwork.implementation.DncBuilder;
import com.azure.resourcemanager.delegatednetwork.implementation.OperationsImpl;
import com.azure.resourcemanager.delegatednetwork.implementation.OrchestratorInstanceServicesImpl;
import com.azure.resourcemanager.delegatednetwork.models.Controllers;
import com.azure.resourcemanager.delegatednetwork.models.DelegatedNetworks;
import com.azure.resourcemanager.delegatednetwork.models.DelegatedSubnetServices;
import com.azure.resourcemanager.delegatednetwork.models.Operations;
import com.azure.resourcemanager.delegatednetwork.models.OrchestratorInstanceServices;
import java.time.Duration;
import java.time.temporal.ChronoUnit;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
/** Entry point to DelegatedNetworkManager. DNC web api provides way to create, get and delete dnc controller. */
public final class DelegatedNetworkManager {
private Controllers controllers;
private DelegatedNetworks delegatedNetworks;
private OrchestratorInstanceServices orchestratorInstanceServices;
private DelegatedSubnetServices delegatedSubnetServices;
private Operations operations;
private final Dnc clientObject;
private DelegatedNetworkManager(HttpPipeline httpPipeline, AzureProfile profile, Duration defaultPollInterval) {
Objects.requireNonNull(httpPipeline, "'httpPipeline' cannot be null.");
Objects.requireNonNull(profile, "'profile' cannot be null.");
this.clientObject =
new DncBuilder()
.pipeline(httpPipeline)
.endpoint(profile.getEnvironment().getResourceManagerEndpoint())
.subscriptionId(profile.getSubscriptionId())
.defaultPollInterval(defaultPollInterval)
.buildClient();
}
/**
* Creates an instance of DelegatedNetwork service API entry point.
*
* @param credential the credential to use.
* @param profile the Azure profile for client.
* @return the DelegatedNetwork service API instance.
*/
public static DelegatedNetworkManager authenticate(TokenCredential credential, AzureProfile profile) {
Objects.requireNonNull(credential, "'credential' cannot be null.");
Objects.requireNonNull(profile, "'profile' cannot be null.");
return configure().authenticate(credential, profile);
}
/**
* Gets a Configurable instance that can be used to create DelegatedNetworkManager with optional configuration.
*
* @return the Configurable instance allowing configurations.
*/
public static Configurable configure() {
return new DelegatedNetworkManager.Configurable();
}
/** The Configurable allowing configurations to be set. */
public static final class Configurable {
private final ClientLogger logger = new ClientLogger(Configurable.class);
private HttpClient httpClient;
private HttpLogOptions httpLogOptions;
private final List policies = new ArrayList<>();
private RetryPolicy retryPolicy;
private Duration defaultPollInterval;
private Configurable() {
}
/**
* Sets the http client.
*
* @param httpClient the HTTP client.
* @return the configurable object itself.
*/
public Configurable withHttpClient(HttpClient httpClient) {
this.httpClient = Objects.requireNonNull(httpClient, "'httpClient' cannot be null.");
return this;
}
/**
* Sets the logging options to the HTTP pipeline.
*
* @param httpLogOptions the HTTP log options.
* @return the configurable object itself.
*/
public Configurable withLogOptions(HttpLogOptions httpLogOptions) {
this.httpLogOptions = Objects.requireNonNull(httpLogOptions, "'httpLogOptions' cannot be null.");
return this;
}
/**
* Adds the pipeline policy to the HTTP pipeline.
*
* @param policy the HTTP pipeline policy.
* @return the configurable object itself.
*/
public Configurable withPolicy(HttpPipelinePolicy policy) {
this.policies.add(Objects.requireNonNull(policy, "'policy' cannot be null."));
return this;
}
/**
* Sets the retry policy to the HTTP pipeline.
*
* @param retryPolicy the HTTP pipeline retry policy.
* @return the configurable object itself.
*/
public Configurable withRetryPolicy(RetryPolicy retryPolicy) {
this.retryPolicy = Objects.requireNonNull(retryPolicy, "'retryPolicy' cannot be null.");
return this;
}
/**
* Sets the default poll interval, used when service does not provide "Retry-After" header.
*
* @param defaultPollInterval the default poll interval.
* @return the configurable object itself.
*/
public Configurable withDefaultPollInterval(Duration defaultPollInterval) {
this.defaultPollInterval = Objects.requireNonNull(defaultPollInterval, "'retryPolicy' cannot be null.");
if (this.defaultPollInterval.isNegative()) {
throw logger.logExceptionAsError(new IllegalArgumentException("'httpPipeline' cannot be negative"));
}
return this;
}
/**
* Creates an instance of DelegatedNetwork service API entry point.
*
* @param credential the credential to use.
* @param profile the Azure profile for client.
* @return the DelegatedNetwork service API instance.
*/
public DelegatedNetworkManager authenticate(TokenCredential credential, AzureProfile profile) {
Objects.requireNonNull(credential, "'credential' cannot be null.");
Objects.requireNonNull(profile, "'profile' cannot be null.");
StringBuilder userAgentBuilder = new StringBuilder();
userAgentBuilder
.append("azsdk-java")
.append("-")
.append("com.azure.resourcemanager.delegatednetwork")
.append("/")
.append("1.0.0-beta.1");
if (!Configuration.getGlobalConfiguration().get("AZURE_TELEMETRY_DISABLED", false)) {
userAgentBuilder
.append(" (")
.append(Configuration.getGlobalConfiguration().get("java.version"))
.append("; ")
.append(Configuration.getGlobalConfiguration().get("os.name"))
.append("; ")
.append(Configuration.getGlobalConfiguration().get("os.version"))
.append("; auto-generated)");
} else {
userAgentBuilder.append(" (auto-generated)");
}
if (retryPolicy == null) {
retryPolicy = new RetryPolicy("Retry-After", ChronoUnit.SECONDS);
}
List policies = new ArrayList<>();
policies.add(new UserAgentPolicy(userAgentBuilder.toString()));
policies.add(new RequestIdPolicy());
HttpPolicyProviders.addBeforeRetryPolicies(policies);
policies.add(retryPolicy);
policies.add(new AddDatePolicy());
policies
.add(
new BearerTokenAuthenticationPolicy(
credential, profile.getEnvironment().getManagementEndpoint() + "/.default"));
HttpPolicyProviders.addAfterRetryPolicies(policies);
policies.add(new HttpLoggingPolicy(httpLogOptions));
HttpPipeline httpPipeline =
new HttpPipelineBuilder()
.httpClient(httpClient)
.policies(policies.toArray(new HttpPipelinePolicy[0]))
.build();
return new DelegatedNetworkManager(httpPipeline, profile, defaultPollInterval);
}
}
/** @return Resource collection API of Controllers. */
public Controllers controllers() {
if (this.controllers == null) {
this.controllers = new ControllersImpl(clientObject.getControllers(), this);
}
return controllers;
}
/** @return Resource collection API of DelegatedNetworks. */
public DelegatedNetworks delegatedNetworks() {
if (this.delegatedNetworks == null) {
this.delegatedNetworks = new DelegatedNetworksImpl(clientObject.getDelegatedNetworks(), this);
}
return delegatedNetworks;
}
/** @return Resource collection API of OrchestratorInstanceServices. */
public OrchestratorInstanceServices orchestratorInstanceServices() {
if (this.orchestratorInstanceServices == null) {
this.orchestratorInstanceServices =
new OrchestratorInstanceServicesImpl(clientObject.getOrchestratorInstanceServices(), this);
}
return orchestratorInstanceServices;
}
/** @return Resource collection API of DelegatedSubnetServices. */
public DelegatedSubnetServices delegatedSubnetServices() {
if (this.delegatedSubnetServices == null) {
this.delegatedSubnetServices =
new DelegatedSubnetServicesImpl(clientObject.getDelegatedSubnetServices(), this);
}
return delegatedSubnetServices;
}
/** @return Resource collection API of Operations. */
public Operations operations() {
if (this.operations == null) {
this.operations = new OperationsImpl(clientObject.getOperations(), this);
}
return operations;
}
/**
* @return Wrapped service client Dnc providing direct access to the underlying auto-generated API implementation,
* based on Azure REST API.
*/
public Dnc serviceClient() {
return this.clientObject;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy