com.microsoft.azure.management.sql.ServerUpgradeOperationsImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-mgmt-sql Show documentation
Show all versions of azure-mgmt-sql Show documentation
This package contains Microsoft Azure SDK for SQL Management module.
/**
*
* Copyright (c) Microsoft and contributors. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
// Warning: This code was generated by a tool.
//
// Changes to this file may cause incorrect behavior and will be lost if the
// code is regenerated.
package com.microsoft.azure.management.sql;
import com.microsoft.azure.management.sql.models.RecommendedDatabaseProperties;
import com.microsoft.azure.management.sql.models.ServerUpgradeGetResponse;
import com.microsoft.azure.management.sql.models.ServerUpgradeStartParameters;
import com.microsoft.azure.management.sql.models.UpgradeRecommendedElasticPoolProperties;
import com.microsoft.windowsazure.core.LazyCollection;
import com.microsoft.windowsazure.core.OperationResponse;
import com.microsoft.windowsazure.core.ServiceOperations;
import com.microsoft.windowsazure.core.pipeline.apache.CustomHttpDelete;
import com.microsoft.windowsazure.core.utils.CollectionStringBuilder;
import com.microsoft.windowsazure.exception.ServiceException;
import com.microsoft.windowsazure.tracing.CloudTracing;
import org.apache.commons.io.IOUtils;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.node.ArrayNode;
import org.codehaus.jackson.node.NullNode;
import org.codehaus.jackson.node.ObjectNode;
import javax.xml.bind.DatatypeConverter;
import java.io.IOException;
import java.io.InputStream;
import java.io.StringWriter;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.HashMap;
import java.util.TimeZone;
import java.util.concurrent.Callable;
import java.util.concurrent.Future;
/**
* Represents all the operations for Azure SQL Database Server Upgrade
*/
public class ServerUpgradeOperationsImpl implements ServiceOperations, ServerUpgradeOperations {
/**
* Initializes a new instance of the ServerUpgradeOperationsImpl class.
*
* @param client Reference to the service client.
*/
ServerUpgradeOperationsImpl(SqlManagementClientImpl client) {
this.client = client;
}
private SqlManagementClientImpl client;
/**
* Gets a reference to the
* microsoft.azure.management.sql.SqlManagementClientImpl.
* @return The Client value.
*/
public SqlManagementClientImpl getClient() {
return this.client;
}
/**
* Cancel a pending upgrade for the Azure SQL Database server.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* cancel upgrade.
* @return A standard service response including an HTTP status code and
* request ID.
*/
@Override
public Future cancelAsync(final String resourceGroupName, final String serverName) {
return this.getClient().getExecutorService().submit(new Callable() {
@Override
public OperationResponse call() throws Exception {
return cancel(resourceGroupName, serverName);
}
});
}
/**
* Cancel a pending upgrade for the Azure SQL Database server.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* cancel upgrade.
* @throws IOException Signals that an I/O exception of some sort has
* occurred. This class is the general class of exceptions produced by
* failed or interrupted I/O operations.
* @throws ServiceException Thrown if an unexpected response is found.
* @return A standard service response including an HTTP status code and
* request ID.
*/
@Override
public OperationResponse cancel(String resourceGroupName, String serverName) throws IOException, ServiceException {
// Validate
if (resourceGroupName == null) {
throw new NullPointerException("resourceGroupName");
}
if (serverName == null) {
throw new NullPointerException("serverName");
}
// Tracing
boolean shouldTrace = CloudTracing.getIsEnabled();
String invocationId = null;
if (shouldTrace) {
invocationId = Long.toString(CloudTracing.getNextInvocationId());
HashMap tracingParameters = new HashMap();
tracingParameters.put("resourceGroupName", resourceGroupName);
tracingParameters.put("serverName", serverName);
CloudTracing.enter(invocationId, this, "cancelAsync", tracingParameters);
}
// Construct URL
String url = "";
url = url + "/subscriptions/";
if (this.getClient().getCredentials().getSubscriptionId() != null) {
url = url + URLEncoder.encode(this.getClient().getCredentials().getSubscriptionId(), "UTF-8");
}
url = url + "/resourceGroups/";
url = url + URLEncoder.encode(resourceGroupName, "UTF-8");
url = url + "/providers/";
url = url + "Microsoft.Sql";
url = url + "/servers/";
url = url + URLEncoder.encode(serverName, "UTF-8");
url = url + "/operationResults/versionUpgrade";
ArrayList queryParameters = new ArrayList();
queryParameters.add("api-version=" + "2014-04-01");
if (queryParameters.size() > 0) {
url = url + "?" + CollectionStringBuilder.join(queryParameters, "&");
}
String baseUrl = this.getClient().getBaseUri().toString();
// Trim '/' character from the end of baseUrl and beginning of url.
if (baseUrl.charAt(baseUrl.length() - 1) == '/') {
baseUrl = baseUrl.substring(0, (baseUrl.length() - 1) + 0);
}
if (url.charAt(0) == '/') {
url = url.substring(1);
}
url = baseUrl + "/" + url;
url = url.replace(" ", "%20");
// Create HTTP transport objects
CustomHttpDelete httpRequest = new CustomHttpDelete(url);
// Set Headers
httpRequest.setHeader("Content-Type", "application/json; charset=utf-8");
// Send Request
HttpResponse httpResponse = null;
try {
if (shouldTrace) {
CloudTracing.sendRequest(invocationId, httpRequest);
}
httpResponse = this.getClient().getHttpClient().execute(httpRequest);
if (shouldTrace) {
CloudTracing.receiveResponse(invocationId, httpResponse);
}
int statusCode = httpResponse.getStatusLine().getStatusCode();
if (statusCode != HttpStatus.SC_ACCEPTED) {
ServiceException ex = ServiceException.createFromXml(httpRequest, null, httpResponse, httpResponse.getEntity());
if (shouldTrace) {
CloudTracing.error(invocationId, ex);
}
throw ex;
}
// Create Result
OperationResponse result = null;
// Deserialize Response
result = new OperationResponse();
result.setStatusCode(statusCode);
if (httpResponse.getHeaders("x-ms-request-id").length > 0) {
result.setRequestId(httpResponse.getFirstHeader("x-ms-request-id").getValue());
}
if (shouldTrace) {
CloudTracing.exit(invocationId, result);
}
return result;
} finally {
if (httpResponse != null && httpResponse.getEntity() != null) {
httpResponse.getEntity().getContent().close();
}
}
}
/**
* Returns information about Upgrade status of an Azure SQL Database Server.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* upgrade.
* @return Represents the response to a Get request for Upgrade status of an
* Azure SQL Database Server.
*/
@Override
public Future getAsync(final String resourceGroupName, final String serverName) {
return this.getClient().getExecutorService().submit(new Callable() {
@Override
public ServerUpgradeGetResponse call() throws Exception {
return get(resourceGroupName, serverName);
}
});
}
/**
* Returns information about Upgrade status of an Azure SQL Database Server.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* upgrade.
* @throws IOException Signals that an I/O exception of some sort has
* occurred. This class is the general class of exceptions produced by
* failed or interrupted I/O operations.
* @throws ServiceException Thrown if an unexpected response is found.
* @return Represents the response to a Get request for Upgrade status of an
* Azure SQL Database Server.
*/
@Override
public ServerUpgradeGetResponse get(String resourceGroupName, String serverName) throws IOException, ServiceException {
// Validate
if (resourceGroupName == null) {
throw new NullPointerException("resourceGroupName");
}
if (serverName == null) {
throw new NullPointerException("serverName");
}
// Tracing
boolean shouldTrace = CloudTracing.getIsEnabled();
String invocationId = null;
if (shouldTrace) {
invocationId = Long.toString(CloudTracing.getNextInvocationId());
HashMap tracingParameters = new HashMap();
tracingParameters.put("resourceGroupName", resourceGroupName);
tracingParameters.put("serverName", serverName);
CloudTracing.enter(invocationId, this, "getAsync", tracingParameters);
}
// Construct URL
String url = "";
url = url + "/subscriptions/";
if (this.getClient().getCredentials().getSubscriptionId() != null) {
url = url + URLEncoder.encode(this.getClient().getCredentials().getSubscriptionId(), "UTF-8");
}
url = url + "/resourceGroups/";
url = url + URLEncoder.encode(resourceGroupName, "UTF-8");
url = url + "/providers/";
url = url + "Microsoft.Sql";
url = url + "/servers/";
url = url + URLEncoder.encode(serverName, "UTF-8");
url = url + "/operationResults/versionUpgrade";
ArrayList queryParameters = new ArrayList();
queryParameters.add("api-version=" + "2014-04-01");
if (queryParameters.size() > 0) {
url = url + "?" + CollectionStringBuilder.join(queryParameters, "&");
}
String baseUrl = this.getClient().getBaseUri().toString();
// Trim '/' character from the end of baseUrl and beginning of url.
if (baseUrl.charAt(baseUrl.length() - 1) == '/') {
baseUrl = baseUrl.substring(0, (baseUrl.length() - 1) + 0);
}
if (url.charAt(0) == '/') {
url = url.substring(1);
}
url = baseUrl + "/" + url;
url = url.replace(" ", "%20");
// Create HTTP transport objects
HttpGet httpRequest = new HttpGet(url);
// Set Headers
// Send Request
HttpResponse httpResponse = null;
try {
if (shouldTrace) {
CloudTracing.sendRequest(invocationId, httpRequest);
}
httpResponse = this.getClient().getHttpClient().execute(httpRequest);
if (shouldTrace) {
CloudTracing.receiveResponse(invocationId, httpResponse);
}
int statusCode = httpResponse.getStatusLine().getStatusCode();
if (statusCode != HttpStatus.SC_OK && statusCode != HttpStatus.SC_ACCEPTED) {
ServiceException ex = ServiceException.createFromJson(httpRequest, null, httpResponse, httpResponse.getEntity());
if (shouldTrace) {
CloudTracing.error(invocationId, ex);
}
throw ex;
}
// Create Result
ServerUpgradeGetResponse result = null;
// Deserialize Response
if (statusCode == HttpStatus.SC_OK || statusCode == HttpStatus.SC_ACCEPTED) {
InputStream responseContent = httpResponse.getEntity().getContent();
result = new ServerUpgradeGetResponse();
ObjectMapper objectMapper = new ObjectMapper();
JsonNode responseDoc = null;
String responseDocContent = IOUtils.toString(responseContent);
if (responseDocContent == null == false && responseDocContent.length() > 0) {
responseDoc = objectMapper.readTree(responseDocContent);
}
if (responseDoc != null && responseDoc instanceof NullNode == false) {
JsonNode statusValue = responseDoc.get("status");
if (statusValue != null && statusValue instanceof NullNode == false) {
String statusInstance;
statusInstance = statusValue.getTextValue();
result.setStatus(statusInstance);
}
JsonNode scheduleUpgradeAfterTimeValue = responseDoc.get("scheduleUpgradeAfterTime");
if (scheduleUpgradeAfterTimeValue != null && scheduleUpgradeAfterTimeValue instanceof NullNode == false) {
Calendar scheduleUpgradeAfterTimeInstance;
scheduleUpgradeAfterTimeInstance = DatatypeConverter.parseDateTime(scheduleUpgradeAfterTimeValue.getTextValue());
result.setScheduleUpgradeAfterTime(scheduleUpgradeAfterTimeInstance);
}
}
}
result.setStatusCode(statusCode);
if (httpResponse.getHeaders("x-ms-request-id").length > 0) {
result.setRequestId(httpResponse.getFirstHeader("x-ms-request-id").getValue());
}
if (shouldTrace) {
CloudTracing.exit(invocationId, result);
}
return result;
} finally {
if (httpResponse != null && httpResponse.getEntity() != null) {
httpResponse.getEntity().getContent().close();
}
}
}
/**
* Start an Azure SQL Database Server Upgrade.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* upgrade.
* @param parameters Required. The required parameters for the Azure SQL
* Database Server Upgrade.
* @return A standard service response including an HTTP status code and
* request ID.
*/
@Override
public Future startAsync(final String resourceGroupName, final String serverName, final ServerUpgradeStartParameters parameters) {
return this.getClient().getExecutorService().submit(new Callable() {
@Override
public OperationResponse call() throws Exception {
return start(resourceGroupName, serverName, parameters);
}
});
}
/**
* Start an Azure SQL Database Server Upgrade.
*
* @param resourceGroupName Required. The name of the Resource Group to
* which the server belongs.
* @param serverName Required. The name of the Azure SQL Database Server to
* upgrade.
* @param parameters Required. The required parameters for the Azure SQL
* Database Server Upgrade.
* @throws IOException Signals that an I/O exception of some sort has
* occurred. This class is the general class of exceptions produced by
* failed or interrupted I/O operations.
* @throws ServiceException Thrown if an unexpected response is found.
* @return A standard service response including an HTTP status code and
* request ID.
*/
@Override
public OperationResponse start(String resourceGroupName, String serverName, ServerUpgradeStartParameters parameters) throws IOException, ServiceException {
// Validate
if (resourceGroupName == null) {
throw new NullPointerException("resourceGroupName");
}
if (serverName == null) {
throw new NullPointerException("serverName");
}
if (parameters == null) {
throw new NullPointerException("parameters");
}
if (parameters.getProperties() == null) {
throw new NullPointerException("parameters.Properties");
}
if (parameters.getProperties().getVersion() == null) {
throw new NullPointerException("parameters.Properties.Version");
}
// Tracing
boolean shouldTrace = CloudTracing.getIsEnabled();
String invocationId = null;
if (shouldTrace) {
invocationId = Long.toString(CloudTracing.getNextInvocationId());
HashMap tracingParameters = new HashMap();
tracingParameters.put("resourceGroupName", resourceGroupName);
tracingParameters.put("serverName", serverName);
tracingParameters.put("parameters", parameters);
CloudTracing.enter(invocationId, this, "startAsync", tracingParameters);
}
// Construct URL
String url = "";
url = url + "/subscriptions/";
if (this.getClient().getCredentials().getSubscriptionId() != null) {
url = url + URLEncoder.encode(this.getClient().getCredentials().getSubscriptionId(), "UTF-8");
}
url = url + "/resourceGroups/";
url = url + URLEncoder.encode(resourceGroupName, "UTF-8");
url = url + "/providers/";
url = url + "Microsoft.Sql";
url = url + "/servers/";
url = url + URLEncoder.encode(serverName, "UTF-8");
url = url + "/upgrade";
ArrayList queryParameters = new ArrayList();
queryParameters.add("api-version=" + "2014-04-01");
if (queryParameters.size() > 0) {
url = url + "?" + CollectionStringBuilder.join(queryParameters, "&");
}
String baseUrl = this.getClient().getBaseUri().toString();
// Trim '/' character from the end of baseUrl and beginning of url.
if (baseUrl.charAt(baseUrl.length() - 1) == '/') {
baseUrl = baseUrl.substring(0, (baseUrl.length() - 1) + 0);
}
if (url.charAt(0) == '/') {
url = url.substring(1);
}
url = baseUrl + "/" + url;
url = url.replace(" ", "%20");
// Create HTTP transport objects
HttpPost httpRequest = new HttpPost(url);
// Set Headers
httpRequest.setHeader("Content-Type", "application/json; charset=utf-8");
// Serialize Request
String requestContent = null;
JsonNode requestDoc = null;
ObjectMapper objectMapper = new ObjectMapper();
ObjectNode serverUpgradeStartParametersValue = objectMapper.createObjectNode();
requestDoc = serverUpgradeStartParametersValue;
ObjectNode serverUpgradePropertiesValue = objectMapper.createObjectNode();
((ObjectNode) serverUpgradeStartParametersValue).put("serverUpgradeProperties", serverUpgradePropertiesValue);
((ObjectNode) serverUpgradePropertiesValue).put("Version", parameters.getProperties().getVersion());
if (parameters.getProperties().getScheduleUpgradeAfterUtcDateTime() != null) {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSSSSS'Z'");
simpleDateFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
((ObjectNode) serverUpgradePropertiesValue).put("ScheduleUpgradeAfterUtcDateTime", simpleDateFormat.format(parameters.getProperties().getScheduleUpgradeAfterUtcDateTime().getTime()));
}
if (parameters.getProperties().getDatabaseCollection() != null) {
if (parameters.getProperties().getDatabaseCollection() instanceof LazyCollection == false || ((LazyCollection) parameters.getProperties().getDatabaseCollection()).isInitialized()) {
ArrayNode databaseCollectionArray = objectMapper.createArrayNode();
for (RecommendedDatabaseProperties databaseCollectionItem : parameters.getProperties().getDatabaseCollection()) {
ObjectNode recommendedDatabasePropertiesValue = objectMapper.createObjectNode();
databaseCollectionArray.add(recommendedDatabasePropertiesValue);
if (databaseCollectionItem.getName() != null) {
((ObjectNode) recommendedDatabasePropertiesValue).put("Name", databaseCollectionItem.getName());
}
if (databaseCollectionItem.getTargetEdition() != null) {
((ObjectNode) recommendedDatabasePropertiesValue).put("TargetEdition", databaseCollectionItem.getTargetEdition());
}
if (databaseCollectionItem.getTargetServiceLevelObjective() != null) {
((ObjectNode) recommendedDatabasePropertiesValue).put("TargetServiceLevelObjective", databaseCollectionItem.getTargetServiceLevelObjective());
}
}
((ObjectNode) serverUpgradePropertiesValue).put("DatabaseCollection", databaseCollectionArray);
}
}
if (parameters.getProperties().getElasticPoolCollection() != null) {
if (parameters.getProperties().getElasticPoolCollection() instanceof LazyCollection == false || ((LazyCollection) parameters.getProperties().getElasticPoolCollection()).isInitialized()) {
ArrayNode elasticPoolCollectionArray = objectMapper.createArrayNode();
for (UpgradeRecommendedElasticPoolProperties elasticPoolCollectionItem : parameters.getProperties().getElasticPoolCollection()) {
ObjectNode upgradeRecommendedElasticPoolPropertiesValue = objectMapper.createObjectNode();
elasticPoolCollectionArray.add(upgradeRecommendedElasticPoolPropertiesValue);
if (elasticPoolCollectionItem.getName() != null) {
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("Name", elasticPoolCollectionItem.getName());
}
if (elasticPoolCollectionItem.getEdition() != null) {
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("Edition", elasticPoolCollectionItem.getEdition());
}
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("Dtu", elasticPoolCollectionItem.getDtu());
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("StorageMb", elasticPoolCollectionItem.getStorageMb());
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("DatabaseDtuMin", elasticPoolCollectionItem.getDatabaseDtuMin());
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("DatabaseDtuMax", elasticPoolCollectionItem.getDatabaseDtuMax());
if (elasticPoolCollectionItem.getDatabaseCollection() != null) {
if (elasticPoolCollectionItem.getDatabaseCollection() instanceof LazyCollection == false || ((LazyCollection) elasticPoolCollectionItem.getDatabaseCollection()).isInitialized()) {
ArrayNode databaseCollectionArray2 = objectMapper.createArrayNode();
for (String databaseCollectionItem2 : elasticPoolCollectionItem.getDatabaseCollection()) {
databaseCollectionArray2.add(databaseCollectionItem2);
}
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("DatabaseCollection", databaseCollectionArray2);
}
}
if (elasticPoolCollectionItem.isIncludeAllDatabases() != null) {
((ObjectNode) upgradeRecommendedElasticPoolPropertiesValue).put("IncludeAllDatabases", elasticPoolCollectionItem.isIncludeAllDatabases());
}
}
((ObjectNode) serverUpgradePropertiesValue).put("ElasticPoolCollection", elasticPoolCollectionArray);
}
}
StringWriter stringWriter = new StringWriter();
objectMapper.writeValue(stringWriter, requestDoc);
requestContent = stringWriter.toString();
StringEntity entity = new StringEntity(requestContent);
httpRequest.setEntity(entity);
httpRequest.setHeader("Content-Type", "application/json; charset=utf-8");
// Send Request
HttpResponse httpResponse = null;
try {
if (shouldTrace) {
CloudTracing.sendRequest(invocationId, httpRequest);
}
httpResponse = this.getClient().getHttpClient().execute(httpRequest);
if (shouldTrace) {
CloudTracing.receiveResponse(invocationId, httpResponse);
}
int statusCode = httpResponse.getStatusLine().getStatusCode();
if (statusCode != HttpStatus.SC_ACCEPTED) {
ServiceException ex = ServiceException.createFromXml(httpRequest, requestContent, httpResponse, httpResponse.getEntity());
if (shouldTrace) {
CloudTracing.error(invocationId, ex);
}
throw ex;
}
// Create Result
OperationResponse result = null;
// Deserialize Response
result = new OperationResponse();
result.setStatusCode(statusCode);
if (httpResponse.getHeaders("x-ms-request-id").length > 0) {
result.setRequestId(httpResponse.getFirstHeader("x-ms-request-id").getValue());
}
if (shouldTrace) {
CloudTracing.exit(invocationId, result);
}
return result;
} finally {
if (httpResponse != null && httpResponse.getEntity() != null) {
httpResponse.getEntity().getContent().close();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy