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

com.amazonaws.services.sagemakeredgemanager.AmazonSagemakerEdgeManagerAsyncClient Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon Sagemaker Edge Manager module holds the client classes that are used for communicating with Amazon Sagemaker Edge Manager Service

There is a newer version: 1.12.780
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.sagemakeredgemanager;

import javax.annotation.Generated;

import com.amazonaws.services.sagemakeredgemanager.model.*;
import com.amazonaws.client.AwsAsyncClientParams;
import com.amazonaws.annotation.ThreadSafe;

import java.util.concurrent.ExecutorService;

/**
 * Client for accessing Amazon Sagemaker Edge Manager asynchronously. Each asynchronous method will return a Java Future
 * object representing the asynchronous operation; overloads which accept an {@code AsyncHandler} can be used to receive
 * notification when an asynchronous operation completes.
 * 

*

* SageMaker Edge Manager dataplane service for communicating with active agents. *

*/ @ThreadSafe @Generated("com.amazonaws:aws-java-sdk-code-generator") public class AmazonSagemakerEdgeManagerAsyncClient extends AmazonSagemakerEdgeManagerClient implements AmazonSagemakerEdgeManagerAsync { private static final int DEFAULT_THREAD_POOL_SIZE = 50; private final java.util.concurrent.ExecutorService executorService; public static AmazonSagemakerEdgeManagerAsyncClientBuilder asyncBuilder() { return AmazonSagemakerEdgeManagerAsyncClientBuilder.standard(); } /** * Constructs a new asynchronous client to invoke service methods on Amazon Sagemaker Edge Manager using the * specified parameters. * * @param asyncClientParams * Object providing client parameters. */ AmazonSagemakerEdgeManagerAsyncClient(AwsAsyncClientParams asyncClientParams) { this(asyncClientParams, false); } /** * Constructs a new asynchronous client to invoke service methods on Amazon Sagemaker Edge Manager using the * specified parameters. * * @param asyncClientParams * Object providing client parameters. * @param endpointDiscoveryEnabled * true will enable endpoint discovery if the service supports it. */ AmazonSagemakerEdgeManagerAsyncClient(AwsAsyncClientParams asyncClientParams, boolean endpointDiscoveryEnabled) { super(asyncClientParams, endpointDiscoveryEnabled); this.executorService = asyncClientParams.getExecutor(); } /** * Returns the executor service used by this client to execute async requests. * * @return The executor service used by this client to execute async requests. */ public ExecutorService getExecutorService() { return executorService; } @Override public java.util.concurrent.Future getDeploymentsAsync(GetDeploymentsRequest request) { return getDeploymentsAsync(request, null); } @Override public java.util.concurrent.Future getDeploymentsAsync(final GetDeploymentsRequest request, final com.amazonaws.handlers.AsyncHandler asyncHandler) { final GetDeploymentsRequest finalRequest = beforeClientExecution(request); return executorService.submit(new java.util.concurrent.Callable() { @Override public GetDeploymentsResult call() throws Exception { GetDeploymentsResult result = null; try { result = executeGetDeployments(finalRequest); } catch (Exception ex) { if (asyncHandler != null) { asyncHandler.onError(ex); } throw ex; } if (asyncHandler != null) { asyncHandler.onSuccess(finalRequest, result); } return result; } }); } @Override public java.util.concurrent.Future getDeviceRegistrationAsync(GetDeviceRegistrationRequest request) { return getDeviceRegistrationAsync(request, null); } @Override public java.util.concurrent.Future getDeviceRegistrationAsync(final GetDeviceRegistrationRequest request, final com.amazonaws.handlers.AsyncHandler asyncHandler) { final GetDeviceRegistrationRequest finalRequest = beforeClientExecution(request); return executorService.submit(new java.util.concurrent.Callable() { @Override public GetDeviceRegistrationResult call() throws Exception { GetDeviceRegistrationResult result = null; try { result = executeGetDeviceRegistration(finalRequest); } catch (Exception ex) { if (asyncHandler != null) { asyncHandler.onError(ex); } throw ex; } if (asyncHandler != null) { asyncHandler.onSuccess(finalRequest, result); } return result; } }); } @Override public java.util.concurrent.Future sendHeartbeatAsync(SendHeartbeatRequest request) { return sendHeartbeatAsync(request, null); } @Override public java.util.concurrent.Future sendHeartbeatAsync(final SendHeartbeatRequest request, final com.amazonaws.handlers.AsyncHandler asyncHandler) { final SendHeartbeatRequest finalRequest = beforeClientExecution(request); return executorService.submit(new java.util.concurrent.Callable() { @Override public SendHeartbeatResult call() throws Exception { SendHeartbeatResult result = null; try { result = executeSendHeartbeat(finalRequest); } catch (Exception ex) { if (asyncHandler != null) { asyncHandler.onError(ex); } throw ex; } if (asyncHandler != null) { asyncHandler.onSuccess(finalRequest, result); } return result; } }); } /** * Shuts down the client, releasing all managed resources. This includes forcibly terminating all pending * asynchronous service calls. Clients who wish to give pending asynchronous service calls time to complete should * call {@code getExecutorService().shutdown()} followed by {@code getExecutorService().awaitTermination()} prior to * calling this method. */ @Override public void shutdown() { super.shutdown(); executorService.shutdownNow(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy