com.microsoft.azure.management.sql.implementation.SqlServerManager Maven / Gradle / Ivy
/**
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for
* license information.
*/
package com.microsoft.azure.management.sql.implementation;
import com.microsoft.azure.AzureEnvironment;
import com.microsoft.azure.AzureResponseBuilder;
import com.microsoft.azure.credentials.AzureTokenCredentials;
import com.microsoft.azure.management.resources.fluentcore.arm.AzureConfigurable;
import com.microsoft.azure.management.resources.fluentcore.arm.implementation.AzureConfigurableImpl;
import com.microsoft.azure.management.resources.fluentcore.arm.implementation.Manager;
import com.microsoft.azure.management.resources.fluentcore.utils.ProviderRegistrationInterceptor;
import com.microsoft.azure.management.resources.fluentcore.utils.ResourceManagerThrottlingInterceptor;
import com.microsoft.azure.management.sql.SqlServers;
import com.microsoft.azure.serializer.AzureJacksonAdapter;
import com.microsoft.rest.RestClient;
/**
* Entry point to Azure SQLServer resource management.
*/
public class SqlServerManager extends Manager {
private SqlServers sqlServers;
private final String tenantId;
protected SqlServerManager(RestClient restClient, String tenantId, String subscriptionId) {
super(
restClient,
subscriptionId,
new SqlManagementClientImpl(restClient).withSubscriptionId(subscriptionId));
this.tenantId = tenantId;
}
/**
* Get a Configurable instance that can be used to create SqlServer with optional configuration.
*
* @return Configurable
*/
public static Configurable configure() {
return new SqlServerManager.ConfigurableImpl();
}
/**
* Creates an instance of SqlServer that exposes Compute resource management API entry points.
*
* @param credentials the credentials to use
* @param subscriptionId the subscription
* @return the SqlServer
*/
public static SqlServerManager authenticate(AzureTokenCredentials credentials, String subscriptionId) {
return new SqlServerManager(new RestClient.Builder()
.withBaseUrl(credentials.environment(), AzureEnvironment.Endpoint.RESOURCE_MANAGER)
.withCredentials(credentials)
.withSerializerAdapter(new AzureJacksonAdapter())
.withResponseBuilderFactory(new AzureResponseBuilder.Factory())
.withInterceptor(new ProviderRegistrationInterceptor(credentials))
.withInterceptor(new ResourceManagerThrottlingInterceptor())
.build(), credentials.domain(), subscriptionId);
}
/**
* Creates an instance of SqlServer that exposes Compute resource management API entry points.
*
* @param restClient the RestClient to be used for API calls.
* @param tenantId the tenant UUID
* @param subscriptionId the subscription
* @return the SqlServer
*/
public static SqlServerManager authenticate(RestClient restClient, String tenantId, String subscriptionId) {
return new SqlServerManager(restClient, tenantId, subscriptionId);
}
/**
* The interface allowing configurations to be set.
*/
public interface Configurable extends AzureConfigurable {
/**
* Creates an instance of SqlServer that exposes Compute resource management API entry points.
*
* @param credentials the credentials to use
* @param subscriptionId the subscription
* @return the SqlServer
*/
SqlServerManager authenticate(AzureTokenCredentials credentials, String subscriptionId);
}
/**
* The implementation for Configurable interface.
*/
private static final class ConfigurableImpl extends AzureConfigurableImpl implements Configurable {
@Override
public SqlServerManager authenticate(AzureTokenCredentials credentials, String subscriptionId) {
return SqlServerManager.authenticate(buildRestClient(credentials), credentials.domain(), subscriptionId);
}
}
/**
* @return the SQL Server management API entry point
*/
public SqlServers sqlServers() {
if (sqlServers == null) {
sqlServers = new SqlServersImpl(this);
}
return sqlServers;
}
/**
* Get the tenant ID value.
*
* @return the tenant ID value
*/
public String tenantId() {
return this.tenantId;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy