com.azure.resourcemanager.delegatednetwork.implementation.DncBuilder 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.implementation;
import com.azure.core.annotation.ServiceClientBuilder;
import com.azure.core.http.HttpPipeline;
import com.azure.core.http.HttpPipelineBuilder;
import com.azure.core.http.policy.CookiePolicy;
import com.azure.core.http.policy.RetryPolicy;
import com.azure.core.http.policy.UserAgentPolicy;
import com.azure.core.management.AzureEnvironment;
import com.azure.core.management.serializer.SerializerFactory;
import com.azure.core.util.serializer.SerializerAdapter;
import java.time.Duration;
/** A builder for creating a new instance of the DncImpl type. */
@ServiceClientBuilder(serviceClients = {DncImpl.class})
public final class DncBuilder {
/*
* The ID of the target subscription.
*/
private String subscriptionId;
/**
* Sets The ID of the target subscription.
*
* @param subscriptionId the subscriptionId value.
* @return the DncBuilder.
*/
public DncBuilder subscriptionId(String subscriptionId) {
this.subscriptionId = subscriptionId;
return this;
}
/*
* server parameter
*/
private String endpoint;
/**
* Sets server parameter.
*
* @param endpoint the endpoint value.
* @return the DncBuilder.
*/
public DncBuilder endpoint(String endpoint) {
this.endpoint = endpoint;
return this;
}
/*
* The environment to connect to
*/
private AzureEnvironment environment;
/**
* Sets The environment to connect to.
*
* @param environment the environment value.
* @return the DncBuilder.
*/
public DncBuilder environment(AzureEnvironment environment) {
this.environment = environment;
return this;
}
/*
* The default poll interval for long-running operation
*/
private Duration defaultPollInterval;
/**
* Sets The default poll interval for long-running operation.
*
* @param defaultPollInterval the defaultPollInterval value.
* @return the DncBuilder.
*/
public DncBuilder defaultPollInterval(Duration defaultPollInterval) {
this.defaultPollInterval = defaultPollInterval;
return this;
}
/*
* The HTTP pipeline to send requests through
*/
private HttpPipeline pipeline;
/**
* Sets The HTTP pipeline to send requests through.
*
* @param pipeline the pipeline value.
* @return the DncBuilder.
*/
public DncBuilder pipeline(HttpPipeline pipeline) {
this.pipeline = pipeline;
return this;
}
/*
* The serializer to serialize an object into a string
*/
private SerializerAdapter serializerAdapter;
/**
* Sets The serializer to serialize an object into a string.
*
* @param serializerAdapter the serializerAdapter value.
* @return the DncBuilder.
*/
public DncBuilder serializerAdapter(SerializerAdapter serializerAdapter) {
this.serializerAdapter = serializerAdapter;
return this;
}
/**
* Builds an instance of DncImpl with the provided parameters.
*
* @return an instance of DncImpl.
*/
public DncImpl buildClient() {
if (endpoint == null) {
this.endpoint = "https://management.azure.com";
}
if (environment == null) {
this.environment = AzureEnvironment.AZURE;
}
if (defaultPollInterval == null) {
this.defaultPollInterval = Duration.ofSeconds(30);
}
if (pipeline == null) {
this.pipeline =
new HttpPipelineBuilder()
.policies(new UserAgentPolicy(), new RetryPolicy(), new CookiePolicy())
.build();
}
if (serializerAdapter == null) {
this.serializerAdapter = SerializerFactory.createDefaultManagementSerializerAdapter();
}
DncImpl client =
new DncImpl(pipeline, serializerAdapter, defaultPollInterval, environment, subscriptionId, endpoint);
return client;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy