Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright 2010-2015 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.workspaces;
 
 import java.net.*;
 import java.util.*;
 
 
 
Client for accessing AmazonWorkspaces. All service calls made using this client are blocking, and will not return until the service call completes.

Amazon WorkSpaces Service

This is the Amazon WorkSpaces API Reference . This guide provides detailed information about Amazon WorkSpaces operations, data types, parameters, and errors.

 
 public class AmazonWorkspacesClient extends AmazonWebServiceClient implements AmazonWorkspaces {

    
Provider for AWS credentials.
 
 
     private static final Log log = LogFactory.getLog(AmazonWorkspaces.class);

    
List of exception unmarshallers for all AmazonWorkspaces exceptions.
 
     protected List<JsonErrorUnmarshallerjsonErrorUnmarshallers;

    
Constructs a new client to invoke service methods on AmazonWorkspaces. A credentials provider chain will be used that searches for credentials in this order:
  • Environment Variables - AWS_ACCESS_KEY_ID and AWS_SECRET_KEY
  • Java System Properties - aws.accessKeyId and aws.secretKey
  • Instance profile credentials delivered through the Amazon EC2 metadata service

All service calls made using this new client object are blocking, and will not return until the service call completes.

 
     public AmazonWorkspacesClient() {
         this(new DefaultAWSCredentialsProviderChain(), new ClientConfiguration());
     }

    
Constructs a new client to invoke service methods on AmazonWorkspaces. A credentials provider chain will be used that searches for credentials in this order:
  • Environment Variables - AWS_ACCESS_KEY_ID and AWS_SECRET_KEY
  • Java System Properties - aws.accessKeyId and aws.secretKey
  • Instance profile credentials delivered through the Amazon EC2 metadata service

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
clientConfiguration The client configuration options controlling how this client connects to AmazonWorkspaces (ex: proxy settings, retry counts, etc.).
See also:
com.amazonaws.auth.DefaultAWSCredentialsProviderChain
    public AmazonWorkspacesClient(ClientConfiguration clientConfiguration) {
        this(new DefaultAWSCredentialsProviderChain(), clientConfiguration);
    }

    
Constructs a new client to invoke service methods on AmazonWorkspaces using the specified AWS account credentials.

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
awsCredentials The AWS credentials (access key ID and secret key) to use when authenticating with AWS services.
    public AmazonWorkspacesClient(AWSCredentials awsCredentials) {
        this(awsCredentialsnew ClientConfiguration());
    }

    
Constructs a new client to invoke service methods on AmazonWorkspaces using the specified AWS account credentials and client configuration options.

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
awsCredentials The AWS credentials (access key ID and secret key) to use when authenticating with AWS services.
clientConfiguration The client configuration options controlling how this client connects to AmazonWorkspaces (ex: proxy settings, retry counts, etc.).
    public AmazonWorkspacesClient(AWSCredentials awsCredentialsClientConfiguration clientConfiguration) {
        super(adjustClientConfiguration(clientConfiguration));
        
        this. = new StaticCredentialsProvider(awsCredentials);
        
        init();
    }

    
Constructs a new client to invoke service methods on AmazonWorkspaces using the specified AWS account credentials provider.

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
awsCredentialsProvider The AWS credentials provider which will provide credentials to authenticate requests with AWS services.
    public AmazonWorkspacesClient(AWSCredentialsProvider awsCredentialsProvider) {
        this(awsCredentialsProvidernew ClientConfiguration());
    }

    
Constructs a new client to invoke service methods on AmazonWorkspaces using the specified AWS account credentials provider and client configuration options.

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
awsCredentialsProvider The AWS credentials provider which will provide credentials to authenticate requests with AWS services.
clientConfiguration The client configuration options controlling how this client connects to AmazonWorkspaces (ex: proxy settings, retry counts, etc.).
    public AmazonWorkspacesClient(AWSCredentialsProvider awsCredentialsProviderClientConfiguration clientConfiguration) {
        this(awsCredentialsProviderclientConfigurationnull);
    }

    
Constructs a new client to invoke service methods on AmazonWorkspaces using the specified AWS account credentials provider, client configuration options and request metric collector.

All service calls made using this new client object are blocking, and will not return until the service call completes.

Parameters:
awsCredentialsProvider The AWS credentials provider which will provide credentials to authenticate requests with AWS services.
clientConfiguration The client configuration options controlling how this client connects to AmazonWorkspaces (ex: proxy settings, retry counts, etc.).
requestMetricCollector optional request metric collector
    public AmazonWorkspacesClient(AWSCredentialsProvider awsCredentialsProvider,
            ClientConfiguration clientConfiguration,
            RequestMetricCollector requestMetricCollector) {
        super(adjustClientConfiguration(clientConfiguration), requestMetricCollector);
        
        this. = awsCredentialsProvider;
        
        init();
    }
    private void init() {
        
        
        // calling this.setEndPoint(...) will also modify the signer accordingly
        this.setEndpoint("workspaces.us-east-1.amazonaws.com/");
        
        HandlerChainFactory chainFactory = new HandlerChainFactory();
        .addAll(chainFactory.newRequestHandlerChain(
                "/com/amazonaws/services/workspaces/request.handlers"));
        .addAll(chainFactory.newRequestHandler2Chain(
                "/com/amazonaws/services/workspaces/request.handler2s"));
    }
        ClientConfiguration config = orig;
        
        return config;
    }

    

Creates one or more WorkSpaces.

NOTE: This operation is asynchronous and returns before the WorkSpaces are created.

Parameters:
createWorkspacesRequest Container for the necessary parameters to execute the CreateWorkspaces service method on AmazonWorkspaces.
Returns:
The response from the CreateWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.ResourceLimitExceededException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    public CreateWorkspacesResult createWorkspaces(CreateWorkspacesRequest createWorkspacesRequest) {
        ExecutionContext executionContext = createExecutionContext(createWorkspacesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<CreateWorkspacesRequestrequest = null;
        Response<CreateWorkspacesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new CreateWorkspacesRequestMarshaller().marshall(super.beforeMarshalling(createWorkspacesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<CreateWorkspacesResultJsonUnmarshallerContextunmarshaller =
                new CreateWorkspacesResultJsonUnmarshaller();
            JsonResponseHandler<CreateWorkspacesResultresponseHandler =
                new JsonResponseHandler<CreateWorkspacesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Obtains information about the WorkSpace bundles that are available to your account in the specified region.

You can filter the results with either the BundleIds parameter, or the Owner parameter, but not both.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Parameters:
describeWorkspaceBundlesRequest Container for the necessary parameters to execute the DescribeWorkspaceBundles service method on AmazonWorkspaces.
Returns:
The response from the DescribeWorkspaceBundles service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
        ExecutionContext executionContext = createExecutionContext(describeWorkspaceBundlesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<DescribeWorkspaceBundlesRequestrequest = null;
        Response<DescribeWorkspaceBundlesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new DescribeWorkspaceBundlesRequestMarshaller().marshall(super.beforeMarshalling(describeWorkspaceBundlesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<DescribeWorkspaceBundlesResultJsonUnmarshallerContextunmarshaller =
                new DescribeWorkspaceBundlesResultJsonUnmarshaller();
            JsonResponseHandler<DescribeWorkspaceBundlesResultresponseHandler =
                new JsonResponseHandler<DescribeWorkspaceBundlesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Reboots the specified WorkSpaces.

To be able to reboot a WorkSpace, the WorkSpace must have a State of AVAILABLE , IMPAIRED , or INOPERABLE .

NOTE: This operation is asynchronous and will return before the WorkSpaces have rebooted.

Parameters:
rebootWorkspacesRequest Container for the necessary parameters to execute the RebootWorkspaces service method on AmazonWorkspaces.
Returns:
The response from the RebootWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    public RebootWorkspacesResult rebootWorkspaces(RebootWorkspacesRequest rebootWorkspacesRequest) {
        ExecutionContext executionContext = createExecutionContext(rebootWorkspacesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<RebootWorkspacesRequestrequest = null;
        Response<RebootWorkspacesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new RebootWorkspacesRequestMarshaller().marshall(super.beforeMarshalling(rebootWorkspacesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<RebootWorkspacesResultJsonUnmarshallerContextunmarshaller =
                new RebootWorkspacesResultJsonUnmarshaller();
            JsonResponseHandler<RebootWorkspacesResultresponseHandler =
                new JsonResponseHandler<RebootWorkspacesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Obtains information about the specified WorkSpaces.

Only one of the filter parameters, such as BundleId , DirectoryId , or WorkspaceIds , can be specified at a time.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Parameters:
describeWorkspacesRequest Container for the necessary parameters to execute the DescribeWorkspaces service method on AmazonWorkspaces.
Returns:
The response from the DescribeWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.ResourceUnavailableException
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    public DescribeWorkspacesResult describeWorkspaces(DescribeWorkspacesRequest describeWorkspacesRequest) {
        ExecutionContext executionContext = createExecutionContext(describeWorkspacesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<DescribeWorkspacesRequestrequest = null;
        Response<DescribeWorkspacesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new DescribeWorkspacesRequestMarshaller().marshall(super.beforeMarshalling(describeWorkspacesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<DescribeWorkspacesResultJsonUnmarshallerContextunmarshaller =
                new DescribeWorkspacesResultJsonUnmarshaller();
            JsonResponseHandler<DescribeWorkspacesResultresponseHandler =
                new JsonResponseHandler<DescribeWorkspacesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Retrieves information about the AWS Directory Service directories in the region that are registered with Amazon WorkSpaces and are available to your account.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Parameters:
describeWorkspaceDirectoriesRequest Container for the necessary parameters to execute the DescribeWorkspaceDirectories service method on AmazonWorkspaces.
Returns:
The response from the DescribeWorkspaceDirectories service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
        ExecutionContext executionContext = createExecutionContext(describeWorkspaceDirectoriesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<DescribeWorkspaceDirectoriesRequestrequest = null;
        Response<DescribeWorkspaceDirectoriesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new DescribeWorkspaceDirectoriesRequestMarshaller().marshall(super.beforeMarshalling(describeWorkspaceDirectoriesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
                new DescribeWorkspaceDirectoriesResultJsonUnmarshaller();
            JsonResponseHandler<DescribeWorkspaceDirectoriesResultresponseHandler =
                new JsonResponseHandler<DescribeWorkspaceDirectoriesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Rebuilds the specified WorkSpaces.

Rebuilding a WorkSpace is a potentially destructive action that can result in the loss of data. Rebuilding a WorkSpace causes the following to occur:

  • The system is restored to the image of the bundle that the WorkSpace is created from. Any applications that have been installed, or system settings that have been made since the WorkSpace was created will be lost.
  • The data drive (D drive) is re-created from the last automatic snapshot taken of the data drive. The current contents of the data drive are overwritten. Automatic snapshots of the data drive are taken every 12 hours, so the snapshot can be as much as 12 hours old.

To be able to rebuild a WorkSpace, the WorkSpace must have a State of AVAILABLE or ERROR .

NOTE: This operation is asynchronous and will return before the WorkSpaces have been completely rebuilt.

Parameters:
rebuildWorkspacesRequest Container for the necessary parameters to execute the RebuildWorkspaces service method on AmazonWorkspaces.
Returns:
The response from the RebuildWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    public RebuildWorkspacesResult rebuildWorkspaces(RebuildWorkspacesRequest rebuildWorkspacesRequest) {
        ExecutionContext executionContext = createExecutionContext(rebuildWorkspacesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<RebuildWorkspacesRequestrequest = null;
        Response<RebuildWorkspacesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new RebuildWorkspacesRequestMarshaller().marshall(super.beforeMarshalling(rebuildWorkspacesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<RebuildWorkspacesResultJsonUnmarshallerContextunmarshaller =
                new RebuildWorkspacesResultJsonUnmarshaller();
            JsonResponseHandler<RebuildWorkspacesResultresponseHandler =
                new JsonResponseHandler<RebuildWorkspacesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Terminates the specified WorkSpaces.

Terminating a WorkSpace is a permanent action and cannot be undone. The user's data is not maintained and will be destroyed. If you need to archive any user data, contact Amazon Web Services before terminating the WorkSpace.

You can terminate a WorkSpace that is in any state except SUSPENDED .

NOTE: This operation is asynchronous and will return before the WorkSpaces have been completely terminated.

Parameters:
terminateWorkspacesRequest Container for the necessary parameters to execute the TerminateWorkspaces service method on AmazonWorkspaces.
Returns:
The response from the TerminateWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    public TerminateWorkspacesResult terminateWorkspaces(TerminateWorkspacesRequest terminateWorkspacesRequest) {
        ExecutionContext executionContext = createExecutionContext(terminateWorkspacesRequest);
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        awsRequestMetrics.startEvent(.);
        Request<TerminateWorkspacesRequestrequest = null;
        Response<TerminateWorkspacesResultresponse = null;
        
        try {
            awsRequestMetrics.startEvent(.);
            try {
                request = new TerminateWorkspacesRequestMarshaller().marshall(super.beforeMarshalling(terminateWorkspacesRequest));
                // Binds the request metrics to the current request.
                request.setAWSRequestMetrics(awsRequestMetrics);
            } finally {
                awsRequestMetrics.endEvent(.);
            }
            Unmarshaller<TerminateWorkspacesResultJsonUnmarshallerContextunmarshaller =
                new TerminateWorkspacesResultJsonUnmarshaller();
            JsonResponseHandler<TerminateWorkspacesResultresponseHandler =
                new JsonResponseHandler<TerminateWorkspacesResult>(unmarshaller);
            response = invoke(requestresponseHandlerexecutionContext);
            return response.getAwsResponse();
        } finally {
            
            endClientExecution(awsRequestMetricsrequestresponse);
        }
    }

    

Obtains information about the WorkSpace bundles that are available to your account in the specified region.

You can filter the results with either the BundleIds parameter, or the Owner parameter, but not both.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Returns:
The response from the DescribeWorkspaceBundles service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    }
    
    

Obtains information about the specified WorkSpaces.

Only one of the filter parameters, such as BundleId , DirectoryId , or WorkspaceIds , can be specified at a time.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Returns:
The response from the DescribeWorkspaces service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.ResourceUnavailableException
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
        return describeWorkspaces(new DescribeWorkspacesRequest());
    }
    
    

Retrieves information about the AWS Directory Service directories in the region that are registered with Amazon WorkSpaces and are available to your account.

This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the NextToken response member contains a token that you pass in the next call to this operation to retrieve the next set of items.

Returns:
The response from the DescribeWorkspaceDirectories service method, as returned by AmazonWorkspaces.
Throws:
com.amazonaws.services.workspaces.model.InvalidParameterValuesException
com.amazonaws.AmazonClientException If any internal errors are encountered inside the client while attempting to make the request or handle the response. For example if a network connection is not available.
com.amazonaws.AmazonServiceException If an error response is returned by AmazonWorkspaces indicating either a problem with the data in the request, or a server side issue.
    }
    @Override
    public void setEndpoint(String endpoint) {
        super.setEndpoint(endpoint);
    }
    @Override
    public void setEndpoint(String endpointString serviceNameString regionIdthrows IllegalArgumentException {
        super.setEndpoint(endpointserviceNameregionId);
    }

    
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.

Parameters:
request The originally executed request
Returns:
The response metadata for the specified request, or null if none is available.
        return .getResponseMetadataForRequest(request);
    }
    private <X, Y extends AmazonWebServiceRequestResponse<X> invoke(Request<Y> request,
            HttpResponseHandler<AmazonWebServiceResponse<X>> responseHandler,
            ExecutionContext executionContext) {
        request.setEndpoint();
        request.setTimeOffset();
        AWSRequestMetrics awsRequestMetrics = executionContext.getAwsRequestMetrics();
        AWSCredentials credentials;
        awsRequestMetrics.startEvent(.);
        try {
            credentials = .getCredentials();
        } finally {
            awsRequestMetrics.endEvent(.);
        }
        AmazonWebServiceRequest originalRequest = request.getOriginalRequest();
        if (originalRequest != null && originalRequest.getRequestCredentials() != null) {
            credentials = originalRequest.getRequestCredentials();
        }
        executionContext.setCredentials(credentials);
        JsonErrorResponseHandler errorResponseHandler = new JsonErrorResponseHandler();
        Response<X> result = .execute(requestresponseHandler,
                errorResponseHandlerexecutionContext);
        return result;
    }
}
        
New to GrepCode? Check out our FAQ X