All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.route53recoverycluster.AWSRoute53RecoveryClusterClient Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Route53 Recovery Cluster module holds the client classes that are used for communicating with Route53 Recovery Cluster Service

There is a newer version: 1.12.772
Show newest version
/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. 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. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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.
 */
package com.amazonaws.services.route53recoverycluster;

import org.w3c.dom.*;

import java.net.*;
import java.util.*;

import javax.annotation.Generated;

import org.apache.commons.logging.*;

import com.amazonaws.*;
import com.amazonaws.annotation.SdkInternalApi;
import com.amazonaws.auth.*;

import com.amazonaws.handlers.*;
import com.amazonaws.http.*;
import com.amazonaws.internal.*;
import com.amazonaws.internal.auth.*;
import com.amazonaws.metrics.*;
import com.amazonaws.regions.*;
import com.amazonaws.transform.*;
import com.amazonaws.util.*;
import com.amazonaws.protocol.json.*;
import com.amazonaws.util.AWSRequestMetrics.Field;
import com.amazonaws.annotation.ThreadSafe;
import com.amazonaws.client.AwsSyncClientParams;
import com.amazonaws.client.builder.AdvancedConfig;

import com.amazonaws.services.route53recoverycluster.AWSRoute53RecoveryClusterClientBuilder;

import com.amazonaws.AmazonServiceException;

import com.amazonaws.services.route53recoverycluster.model.*;

import com.amazonaws.services.route53recoverycluster.model.transform.*;

/**
 * Client for accessing Route53 Recovery Cluster. All service calls made using this client are blocking, and will not
 * return until the service call completes.
 * 

*

* Welcome to the Routing Control (Recovery Cluster) API Reference Guide for Amazon Route 53 Application Recovery * Controller. *

*

* With Route 53 ARC, you can use routing control with extreme reliability to recover applications by rerouting traffic * across Availability Zones or Amazon Web Services Regions. Routing controls are simple on/off switches hosted on a * highly available cluster in Route 53 ARC. A cluster provides a set of five redundant Regional endpoints against which * you can run API calls to get or update the state of routing controls. To implement failover, you set one routing * control to ON and another one to OFF, to reroute traffic from one Availability Zone or Amazon Web Services Region to * another. *

*

* Be aware that you must specify a Regional endpoint for a cluster when you work with API cluster operations to get * or update routing control states in Route 53 ARC. In addition, you must specify the US West (Oregon) Region for * Route 53 ARC API calls. For example, use the parameter --region us-west-2 with AWS CLI commands. For * more information, see * Get and update routing control states using the API in the Amazon Route 53 Application Recovery Controller * Developer Guide. *

*

* This API guide includes information about the API operations for how to get and update routing control states in * Route 53 ARC. To work with routing control in Route 53 ARC, you must first create the required components (clusters, * control panels, and routing controls) using the recovery cluster configuration API. *

*

* For more information about working with routing control in Route 53 ARC, see the following: *

* */ @ThreadSafe @Generated("com.amazonaws:aws-java-sdk-code-generator") public class AWSRoute53RecoveryClusterClient extends AmazonWebServiceClient implements AWSRoute53RecoveryCluster { /** Provider for AWS credentials. */ private final AWSCredentialsProvider awsCredentialsProvider; private static final Log log = LogFactory.getLog(AWSRoute53RecoveryCluster.class); /** Default signing name for the service. */ private static final String DEFAULT_SIGNING_NAME = "route53-recovery-cluster"; /** Client configuration factory providing ClientConfigurations tailored to this client */ protected static final ClientConfigurationFactory configFactory = new ClientConfigurationFactory(); private final AdvancedConfig advancedConfig; private static final com.amazonaws.protocol.json.SdkJsonProtocolFactory protocolFactory = new com.amazonaws.protocol.json.SdkJsonProtocolFactory( new JsonClientMetadata() .withProtocolVersion("1.0") .withSupportsCbor(false) .withSupportsIon(false) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("AccessDeniedException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.AccessDeniedExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("ValidationException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.ValidationExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("ConflictException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.ConflictExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("InternalServerException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.InternalServerExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("ServiceLimitExceededException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.ServiceLimitExceededExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("EndpointTemporarilyUnavailableException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.EndpointTemporarilyUnavailableExceptionUnmarshaller .getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("ThrottlingException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.ThrottlingExceptionUnmarshaller.getInstance())) .addErrorMetadata( new JsonErrorShapeMetadata().withErrorCode("ResourceNotFoundException").withExceptionUnmarshaller( com.amazonaws.services.route53recoverycluster.model.transform.ResourceNotFoundExceptionUnmarshaller.getInstance())) .withBaseServiceExceptionClass(com.amazonaws.services.route53recoverycluster.model.AWSRoute53RecoveryClusterException.class)); public static AWSRoute53RecoveryClusterClientBuilder builder() { return AWSRoute53RecoveryClusterClientBuilder.standard(); } /** * Constructs a new client to invoke service methods on Route53 Recovery Cluster using the specified parameters. * *

* All service calls made using this new client object are blocking, and will not return until the service call * completes. * * @param clientParams * Object providing client parameters. */ AWSRoute53RecoveryClusterClient(AwsSyncClientParams clientParams) { this(clientParams, false); } /** * Constructs a new client to invoke service methods on Route53 Recovery Cluster using the specified parameters. * *

* All service calls made using this new client object are blocking, and will not return until the service call * completes. * * @param clientParams * Object providing client parameters. */ AWSRoute53RecoveryClusterClient(AwsSyncClientParams clientParams, boolean endpointDiscoveryEnabled) { super(clientParams); this.awsCredentialsProvider = clientParams.getCredentialsProvider(); this.advancedConfig = clientParams.getAdvancedConfig(); init(); } private void init() { setServiceNameIntern(DEFAULT_SIGNING_NAME); setEndpointPrefix(ENDPOINT_PREFIX); // calling this.setEndPoint(...) will also modify the signer accordingly setEndpoint("route53-recovery-cluster.us-east-1.amazonaws.com"); HandlerChainFactory chainFactory = new HandlerChainFactory(); requestHandler2s.addAll(chainFactory.newRequestHandlerChain("/com/amazonaws/services/route53recoverycluster/request.handlers")); requestHandler2s.addAll(chainFactory.newRequestHandler2Chain("/com/amazonaws/services/route53recoverycluster/request.handler2s")); requestHandler2s.addAll(chainFactory.getGlobalHandlers()); } /** *

* Get the state for a routing control. A routing control is a simple on/off switch that you can use to route * traffic to cells. When a routing control state is set to ON, traffic flows to a cell. When the state is set to * OFF, traffic does not flow. *

*

* Before you can create a routing control, you must first create a cluster, and then host the control in a control * panel on the cluster. For more information, see Create routing control * structures in the Amazon Route 53 Application Recovery Controller Developer Guide. You access one of the * endpoints for the cluster to get or update the routing control state to redirect traffic for your application. *

*

* You must specify Regional endpoints when you work with API cluster operations to get or update routing control * states in Route 53 ARC. *

*

* To see a code example for getting a routing control state, including accessing Regional cluster endpoints in * sequence, see API * examples in the Amazon Route 53 Application Recovery Controller Developer Guide. *

*

* Learn more about working with routing controls in the following topics in the Amazon Route 53 Application * Recovery Controller Developer Guide: *

* * * @param getRoutingControlStateRequest * @return Result of the GetRoutingControlState operation returned by the service. * @throws AccessDeniedException * You don't have sufficient permissions to perform this action. * @throws InternalServerException * There was an unexpected error during processing of the request. * @throws ResourceNotFoundException * The request references a routing control or control panel that was not found. * @throws ValidationException * There was a validation error on the request. * @throws ThrottlingException * The request was denied because of request throttling. * @throws EndpointTemporarilyUnavailableException * The cluster endpoint isn't available. Try another cluster endpoint. * @sample AWSRoute53RecoveryCluster.GetRoutingControlState * @see AWS API Documentation */ @Override public GetRoutingControlStateResult getRoutingControlState(GetRoutingControlStateRequest request) { request = beforeClientExecution(request); return executeGetRoutingControlState(request); } @SdkInternalApi final GetRoutingControlStateResult executeGetRoutingControlState(GetRoutingControlStateRequest getRoutingControlStateRequest) { ExecutionContext executionContext = createExecutionContext(getRoutingControlStateRequest); AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics(); awsRequestMetrics.startEvent(Field.ClientExecuteTime); Request request = null; Response response = null; try { awsRequestMetrics.startEvent(Field.RequestMarshallTime); try { request = new GetRoutingControlStateRequestProtocolMarshaller(protocolFactory).marshall(super.beforeMarshalling(getRoutingControlStateRequest)); // Binds the request metrics to the current request. request.setAWSRequestMetrics(awsRequestMetrics); request.addHandlerContext(HandlerContextKey.CLIENT_ENDPOINT, endpoint); request.addHandlerContext(HandlerContextKey.ENDPOINT_OVERRIDDEN, isEndpointOverridden()); request.addHandlerContext(HandlerContextKey.SIGNING_REGION, getSigningRegion()); request.addHandlerContext(HandlerContextKey.SERVICE_ID, "Route53 Recovery Cluster"); request.addHandlerContext(HandlerContextKey.OPERATION_NAME, "GetRoutingControlState"); request.addHandlerContext(HandlerContextKey.ADVANCED_CONFIG, advancedConfig); } finally { awsRequestMetrics.endEvent(Field.RequestMarshallTime); } HttpResponseHandler> responseHandler = protocolFactory.createResponseHandler( new JsonOperationMetadata().withPayloadJson(true).withHasStreamingSuccessResponse(false), new GetRoutingControlStateResultJsonUnmarshaller()); response = invoke(request, responseHandler, executionContext); return response.getAwsResponse(); } finally { endClientExecution(awsRequestMetrics, request, response); } } /** *

* List routing control names and Amazon Resource Names (ARNs), as well as the routing control state for each * routing control, along with the control panel name and control panel ARN for the routing controls. If you specify * a control panel ARN, this call lists the routing controls in the control panel. Otherwise, it lists all the * routing controls in the cluster. *

*

* A routing control is a simple on/off switch in Route 53 ARC that you can use to route traffic to cells. When a * routing control state is set to ON, traffic flows to a cell. When the state is set to OFF, traffic does not flow. *

*

* Before you can create a routing control, you must first create a cluster, and then host the control in a control * panel on the cluster. For more information, see Create routing control * structures in the Amazon Route 53 Application Recovery Controller Developer Guide. You access one of the * endpoints for the cluster to get or update the routing control state to redirect traffic for your application. *

*

* You must specify Regional endpoints when you work with API cluster operations to use this API operation to * list routing controls in Route 53 ARC. *

*

* Learn more about working with routing controls in the following topics in the Amazon Route 53 Application * Recovery Controller Developer Guide: *

* * * @param listRoutingControlsRequest * @return Result of the ListRoutingControls operation returned by the service. * @throws AccessDeniedException * You don't have sufficient permissions to perform this action. * @throws InternalServerException * There was an unexpected error during processing of the request. * @throws ResourceNotFoundException * The request references a routing control or control panel that was not found. * @throws ValidationException * There was a validation error on the request. * @throws ThrottlingException * The request was denied because of request throttling. * @throws EndpointTemporarilyUnavailableException * The cluster endpoint isn't available. Try another cluster endpoint. * @sample AWSRoute53RecoveryCluster.ListRoutingControls * @see AWS API Documentation */ @Override public ListRoutingControlsResult listRoutingControls(ListRoutingControlsRequest request) { request = beforeClientExecution(request); return executeListRoutingControls(request); } @SdkInternalApi final ListRoutingControlsResult executeListRoutingControls(ListRoutingControlsRequest listRoutingControlsRequest) { ExecutionContext executionContext = createExecutionContext(listRoutingControlsRequest); AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics(); awsRequestMetrics.startEvent(Field.ClientExecuteTime); Request request = null; Response response = null; try { awsRequestMetrics.startEvent(Field.RequestMarshallTime); try { request = new ListRoutingControlsRequestProtocolMarshaller(protocolFactory).marshall(super.beforeMarshalling(listRoutingControlsRequest)); // Binds the request metrics to the current request. request.setAWSRequestMetrics(awsRequestMetrics); request.addHandlerContext(HandlerContextKey.CLIENT_ENDPOINT, endpoint); request.addHandlerContext(HandlerContextKey.ENDPOINT_OVERRIDDEN, isEndpointOverridden()); request.addHandlerContext(HandlerContextKey.SIGNING_REGION, getSigningRegion()); request.addHandlerContext(HandlerContextKey.SERVICE_ID, "Route53 Recovery Cluster"); request.addHandlerContext(HandlerContextKey.OPERATION_NAME, "ListRoutingControls"); request.addHandlerContext(HandlerContextKey.ADVANCED_CONFIG, advancedConfig); } finally { awsRequestMetrics.endEvent(Field.RequestMarshallTime); } HttpResponseHandler> responseHandler = protocolFactory.createResponseHandler( new JsonOperationMetadata().withPayloadJson(true).withHasStreamingSuccessResponse(false), new ListRoutingControlsResultJsonUnmarshaller()); response = invoke(request, responseHandler, executionContext); return response.getAwsResponse(); } finally { endClientExecution(awsRequestMetrics, request, response); } } /** *

* Set the state of the routing control to reroute traffic. You can set the value to ON or OFF. When the state is * ON, traffic flows to a cell. When the state is OFF, traffic does not flow. *

*

* With Route 53 ARC, you can add safety rules for routing controls, which are safeguards for routing control state * updates that help prevent unexpected outcomes, like fail open traffic routing. However, there are scenarios when * you might want to bypass the routing control safeguards that are enforced with safety rules that you've * configured. For example, you might want to fail over quickly for disaster recovery, and one or more safety rules * might be unexpectedly preventing you from updating a routing control state to reroute traffic. In a "break glass" * scenario like this, you can override one or more safety rules to change a routing control state and fail over * your application. *

*

* The SafetyRulesToOverride property enables you override one or more safety rules and update routing * control states. For more information, see Override * safety rules to reroute traffic in the Amazon Route 53 Application Recovery Controller Developer Guide. *

*

* You must specify Regional endpoints when you work with API cluster operations to get or update routing control * states in Route 53 ARC. *

*

* To see a code example for getting a routing control state, including accessing Regional cluster endpoints in * sequence, see API * examples in the Amazon Route 53 Application Recovery Controller Developer Guide. *

* * * @param updateRoutingControlStateRequest * @return Result of the UpdateRoutingControlState operation returned by the service. * @throws AccessDeniedException * You don't have sufficient permissions to perform this action. * @throws InternalServerException * There was an unexpected error during processing of the request. * @throws ResourceNotFoundException * The request references a routing control or control panel that was not found. * @throws ValidationException * There was a validation error on the request. * @throws ThrottlingException * The request was denied because of request throttling. * @throws EndpointTemporarilyUnavailableException * The cluster endpoint isn't available. Try another cluster endpoint. * @throws ConflictException * There was a conflict with this request. Try again. * @sample AWSRoute53RecoveryCluster.UpdateRoutingControlState * @see AWS API Documentation */ @Override public UpdateRoutingControlStateResult updateRoutingControlState(UpdateRoutingControlStateRequest request) { request = beforeClientExecution(request); return executeUpdateRoutingControlState(request); } @SdkInternalApi final UpdateRoutingControlStateResult executeUpdateRoutingControlState(UpdateRoutingControlStateRequest updateRoutingControlStateRequest) { ExecutionContext executionContext = createExecutionContext(updateRoutingControlStateRequest); AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics(); awsRequestMetrics.startEvent(Field.ClientExecuteTime); Request request = null; Response response = null; try { awsRequestMetrics.startEvent(Field.RequestMarshallTime); try { request = new UpdateRoutingControlStateRequestProtocolMarshaller(protocolFactory).marshall(super .beforeMarshalling(updateRoutingControlStateRequest)); // Binds the request metrics to the current request. request.setAWSRequestMetrics(awsRequestMetrics); request.addHandlerContext(HandlerContextKey.CLIENT_ENDPOINT, endpoint); request.addHandlerContext(HandlerContextKey.ENDPOINT_OVERRIDDEN, isEndpointOverridden()); request.addHandlerContext(HandlerContextKey.SIGNING_REGION, getSigningRegion()); request.addHandlerContext(HandlerContextKey.SERVICE_ID, "Route53 Recovery Cluster"); request.addHandlerContext(HandlerContextKey.OPERATION_NAME, "UpdateRoutingControlState"); request.addHandlerContext(HandlerContextKey.ADVANCED_CONFIG, advancedConfig); } finally { awsRequestMetrics.endEvent(Field.RequestMarshallTime); } HttpResponseHandler> responseHandler = protocolFactory.createResponseHandler( new JsonOperationMetadata().withPayloadJson(true).withHasStreamingSuccessResponse(false), new UpdateRoutingControlStateResultJsonUnmarshaller()); response = invoke(request, responseHandler, executionContext); return response.getAwsResponse(); } finally { endClientExecution(awsRequestMetrics, request, response); } } /** *

* Set multiple routing control states. You can set the value for each state to be ON or OFF. When the state is ON, * traffic flows to a cell. When it's OFF, traffic does not flow. *

*

* With Route 53 ARC, you can add safety rules for routing controls, which are safeguards for routing control state * updates that help prevent unexpected outcomes, like fail open traffic routing. However, there are scenarios when * you might want to bypass the routing control safeguards that are enforced with safety rules that you've * configured. For example, you might want to fail over quickly for disaster recovery, and one or more safety rules * might be unexpectedly preventing you from updating a routing control state to reroute traffic. In a "break glass" * scenario like this, you can override one or more safety rules to change a routing control state and fail over * your application. *

*

* The SafetyRulesToOverride property enables you override one or more safety rules and update routing * control states. For more information, see Override * safety rules to reroute traffic in the Amazon Route 53 Application Recovery Controller Developer Guide. *

*

* You must specify Regional endpoints when you work with API cluster operations to get or update routing control * states in Route 53 ARC. *

*

* To see a code example for getting a routing control state, including accessing Regional cluster endpoints in * sequence, see API * examples in the Amazon Route 53 Application Recovery Controller Developer Guide. *

* * * @param updateRoutingControlStatesRequest * @return Result of the UpdateRoutingControlStates operation returned by the service. * @throws AccessDeniedException * You don't have sufficient permissions to perform this action. * @throws InternalServerException * There was an unexpected error during processing of the request. * @throws ResourceNotFoundException * The request references a routing control or control panel that was not found. * @throws ValidationException * There was a validation error on the request. * @throws ThrottlingException * The request was denied because of request throttling. * @throws EndpointTemporarilyUnavailableException * The cluster endpoint isn't available. Try another cluster endpoint. * @throws ConflictException * There was a conflict with this request. Try again. * @throws ServiceLimitExceededException * The request can't update that many routing control states at the same time. Try again with fewer routing * control states. * @sample AWSRoute53RecoveryCluster.UpdateRoutingControlStates * @see AWS API Documentation */ @Override public UpdateRoutingControlStatesResult updateRoutingControlStates(UpdateRoutingControlStatesRequest request) { request = beforeClientExecution(request); return executeUpdateRoutingControlStates(request); } @SdkInternalApi final UpdateRoutingControlStatesResult executeUpdateRoutingControlStates(UpdateRoutingControlStatesRequest updateRoutingControlStatesRequest) { ExecutionContext executionContext = createExecutionContext(updateRoutingControlStatesRequest); AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics(); awsRequestMetrics.startEvent(Field.ClientExecuteTime); Request request = null; Response response = null; try { awsRequestMetrics.startEvent(Field.RequestMarshallTime); try { request = new UpdateRoutingControlStatesRequestProtocolMarshaller(protocolFactory).marshall(super .beforeMarshalling(updateRoutingControlStatesRequest)); // Binds the request metrics to the current request. request.setAWSRequestMetrics(awsRequestMetrics); request.addHandlerContext(HandlerContextKey.CLIENT_ENDPOINT, endpoint); request.addHandlerContext(HandlerContextKey.ENDPOINT_OVERRIDDEN, isEndpointOverridden()); request.addHandlerContext(HandlerContextKey.SIGNING_REGION, getSigningRegion()); request.addHandlerContext(HandlerContextKey.SERVICE_ID, "Route53 Recovery Cluster"); request.addHandlerContext(HandlerContextKey.OPERATION_NAME, "UpdateRoutingControlStates"); request.addHandlerContext(HandlerContextKey.ADVANCED_CONFIG, advancedConfig); } finally { awsRequestMetrics.endEvent(Field.RequestMarshallTime); } HttpResponseHandler> responseHandler = protocolFactory.createResponseHandler( new JsonOperationMetadata().withPayloadJson(true).withHasStreamingSuccessResponse(false), new UpdateRoutingControlStatesResultJsonUnmarshaller()); response = invoke(request, responseHandler, executionContext); return response.getAwsResponse(); } finally { endClientExecution(awsRequestMetrics, request, response); } } /** * Returns additional metadata for a previously executed successful, request, typically used for debugging issues * where a service isn't acting as expected. This data isn't considered part of the result data returned by an * operation, so it's available through this separate, diagnostic interface. *

* Response metadata is only cached for a limited period of time, so if you need to access this extra diagnostic * information for an executed request, you should use this method to retrieve it as soon as possible after * executing the request. * * @param request * The originally executed request * * @return The response metadata for the specified request, or null if none is available. */ public ResponseMetadata getCachedResponseMetadata(AmazonWebServiceRequest request) { return client.getResponseMetadataForRequest(request); } /** * Normal invoke with authentication. Credentials are required and may be overriden at the request level. **/ private Response invoke(Request request, HttpResponseHandler> responseHandler, ExecutionContext executionContext) { return invoke(request, responseHandler, executionContext, null, null); } /** * Normal invoke with authentication. Credentials are required and may be overriden at the request level. **/ private Response invoke(Request request, HttpResponseHandler> responseHandler, ExecutionContext executionContext, URI cachedEndpoint, URI uriFromEndpointTrait) { executionContext.setCredentialsProvider(CredentialUtils.getCredentialsProvider(request.getOriginalRequest(), awsCredentialsProvider)); return doInvoke(request, responseHandler, executionContext, cachedEndpoint, uriFromEndpointTrait); } /** * Invoke with no authentication. Credentials are not required and any credentials set on the client or request will * be ignored for this operation. **/ private Response anonymousInvoke(Request request, HttpResponseHandler> responseHandler, ExecutionContext executionContext) { return doInvoke(request, responseHandler, executionContext, null, null); } /** * Invoke the request using the http client. Assumes credentials (or lack thereof) have been configured in the * ExecutionContext beforehand. **/ private Response doInvoke(Request request, HttpResponseHandler> responseHandler, ExecutionContext executionContext, URI discoveredEndpoint, URI uriFromEndpointTrait) { if (discoveredEndpoint != null) { request.setEndpoint(discoveredEndpoint); request.getOriginalRequest().getRequestClientOptions().appendUserAgent("endpoint-discovery"); } else if (uriFromEndpointTrait != null) { request.setEndpoint(uriFromEndpointTrait); } else { request.setEndpoint(endpoint); } request.setTimeOffset(timeOffset); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(new JsonErrorResponseMetadata()); return client.execute(request, responseHandler, errorResponseHandler, executionContext); } @com.amazonaws.annotation.SdkInternalApi static com.amazonaws.protocol.json.SdkJsonProtocolFactory getProtocolFactory() { return protocolFactory; } @Override public void shutdown() { super.shutdown(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy