software.amazon.awssdk.services.elasticache.waiters.DefaultElastiCacheAsyncWaiter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elasticache Show documentation
Show all versions of elasticache Show documentation
The AWS Java SDK for Amazon ElastiCache module holds the client classes that are used for communicating
with Amazon ElastiCache Service
/*
* Copyright 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 software.amazon.awssdk.services.elasticache.waiters;
import java.time.Duration;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.function.Consumer;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.annotations.ThreadSafe;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.awscore.exception.AwsServiceException;
import software.amazon.awssdk.core.ApiName;
import software.amazon.awssdk.core.internal.waiters.WaiterAttribute;
import software.amazon.awssdk.core.retry.backoff.BackoffStrategy;
import software.amazon.awssdk.core.retry.backoff.FixedDelayBackoffStrategy;
import software.amazon.awssdk.core.waiters.AsyncWaiter;
import software.amazon.awssdk.core.waiters.WaiterAcceptor;
import software.amazon.awssdk.core.waiters.WaiterOverrideConfiguration;
import software.amazon.awssdk.core.waiters.WaiterResponse;
import software.amazon.awssdk.services.elasticache.ElastiCacheAsyncClient;
import software.amazon.awssdk.services.elasticache.model.DescribeCacheClustersRequest;
import software.amazon.awssdk.services.elasticache.model.DescribeCacheClustersResponse;
import software.amazon.awssdk.services.elasticache.model.DescribeReplicationGroupsRequest;
import software.amazon.awssdk.services.elasticache.model.DescribeReplicationGroupsResponse;
import software.amazon.awssdk.services.elasticache.model.ElastiCacheRequest;
import software.amazon.awssdk.services.elasticache.waiters.internal.WaitersRuntime;
import software.amazon.awssdk.utils.AttributeMap;
import software.amazon.awssdk.utils.SdkAutoCloseable;
import software.amazon.awssdk.utils.ThreadFactoryBuilder;
@Generated("software.amazon.awssdk:codegen")
@SdkInternalApi
@ThreadSafe
final class DefaultElastiCacheAsyncWaiter implements ElastiCacheAsyncWaiter {
private static final WaiterAttribute CLIENT_ATTRIBUTE = new WaiterAttribute<>(SdkAutoCloseable.class);
private static final WaiterAttribute SCHEDULED_EXECUTOR_SERVICE_ATTRIBUTE = new WaiterAttribute<>(
ScheduledExecutorService.class);
private final ElastiCacheAsyncClient client;
private final AttributeMap managedResources;
private final AsyncWaiter cacheClusterAvailableWaiter;
private final AsyncWaiter cacheClusterDeletedWaiter;
private final AsyncWaiter replicationGroupAvailableWaiter;
private final AsyncWaiter replicationGroupDeletedWaiter;
private final ScheduledExecutorService executorService;
private DefaultElastiCacheAsyncWaiter(DefaultBuilder builder) {
AttributeMap.Builder attributeMapBuilder = AttributeMap.builder();
if (builder.client == null) {
this.client = ElastiCacheAsyncClient.builder().build();
attributeMapBuilder.put(CLIENT_ATTRIBUTE, this.client);
} else {
this.client = builder.client;
}
if (builder.executorService == null) {
this.executorService = Executors.newScheduledThreadPool(1,
new ThreadFactoryBuilder().threadNamePrefix("waiters-ScheduledExecutor").build());
attributeMapBuilder.put(SCHEDULED_EXECUTOR_SERVICE_ATTRIBUTE, this.executorService);
} else {
this.executorService = builder.executorService;
}
managedResources = attributeMapBuilder.build();
this.cacheClusterAvailableWaiter = AsyncWaiter.builder(DescribeCacheClustersResponse.class)
.acceptors(cacheClusterAvailableWaiterAcceptors())
.overrideConfiguration(cacheClusterAvailableWaiterConfig(builder.overrideConfiguration))
.scheduledExecutorService(executorService).build();
this.cacheClusterDeletedWaiter = AsyncWaiter.builder(DescribeCacheClustersResponse.class)
.acceptors(cacheClusterDeletedWaiterAcceptors())
.overrideConfiguration(cacheClusterDeletedWaiterConfig(builder.overrideConfiguration))
.scheduledExecutorService(executorService).build();
this.replicationGroupAvailableWaiter = AsyncWaiter.builder(DescribeReplicationGroupsResponse.class)
.acceptors(replicationGroupAvailableWaiterAcceptors())
.overrideConfiguration(replicationGroupAvailableWaiterConfig(builder.overrideConfiguration))
.scheduledExecutorService(executorService).build();
this.replicationGroupDeletedWaiter = AsyncWaiter.builder(DescribeReplicationGroupsResponse.class)
.acceptors(replicationGroupDeletedWaiterAcceptors())
.overrideConfiguration(replicationGroupDeletedWaiterConfig(builder.overrideConfiguration))
.scheduledExecutorService(executorService).build();
}
private static String errorCode(Throwable error) {
if (error instanceof AwsServiceException) {
return ((AwsServiceException) error).awsErrorDetails().errorCode();
}
return null;
}
@Override
public CompletableFuture> waitUntilCacheClusterAvailable(
DescribeCacheClustersRequest describeCacheClustersRequest) {
return cacheClusterAvailableWaiter.runAsync(() -> client
.describeCacheClusters(applyWaitersUserAgent(describeCacheClustersRequest)));
}
@Override
public CompletableFuture> waitUntilCacheClusterAvailable(
DescribeCacheClustersRequest describeCacheClustersRequest, WaiterOverrideConfiguration overrideConfig) {
return cacheClusterAvailableWaiter.runAsync(
() -> client.describeCacheClusters(applyWaitersUserAgent(describeCacheClustersRequest)),
cacheClusterAvailableWaiterConfig(overrideConfig));
}
@Override
public CompletableFuture> waitUntilCacheClusterDeleted(
DescribeCacheClustersRequest describeCacheClustersRequest) {
return cacheClusterDeletedWaiter.runAsync(() -> client
.describeCacheClusters(applyWaitersUserAgent(describeCacheClustersRequest)));
}
@Override
public CompletableFuture> waitUntilCacheClusterDeleted(
DescribeCacheClustersRequest describeCacheClustersRequest, WaiterOverrideConfiguration overrideConfig) {
return cacheClusterDeletedWaiter.runAsync(
() -> client.describeCacheClusters(applyWaitersUserAgent(describeCacheClustersRequest)),
cacheClusterDeletedWaiterConfig(overrideConfig));
}
@Override
public CompletableFuture> waitUntilReplicationGroupAvailable(
DescribeReplicationGroupsRequest describeReplicationGroupsRequest) {
return replicationGroupAvailableWaiter.runAsync(() -> client
.describeReplicationGroups(applyWaitersUserAgent(describeReplicationGroupsRequest)));
}
@Override
public CompletableFuture> waitUntilReplicationGroupAvailable(
DescribeReplicationGroupsRequest describeReplicationGroupsRequest, WaiterOverrideConfiguration overrideConfig) {
return replicationGroupAvailableWaiter.runAsync(
() -> client.describeReplicationGroups(applyWaitersUserAgent(describeReplicationGroupsRequest)),
replicationGroupAvailableWaiterConfig(overrideConfig));
}
@Override
public CompletableFuture> waitUntilReplicationGroupDeleted(
DescribeReplicationGroupsRequest describeReplicationGroupsRequest) {
return replicationGroupDeletedWaiter.runAsync(() -> client
.describeReplicationGroups(applyWaitersUserAgent(describeReplicationGroupsRequest)));
}
@Override
public CompletableFuture> waitUntilReplicationGroupDeleted(
DescribeReplicationGroupsRequest describeReplicationGroupsRequest, WaiterOverrideConfiguration overrideConfig) {
return replicationGroupDeletedWaiter.runAsync(
() -> client.describeReplicationGroups(applyWaitersUserAgent(describeReplicationGroupsRequest)),
replicationGroupDeletedWaiterConfig(overrideConfig));
}
private static List> cacheClusterAvailableWaiterAcceptors() {
List> result = new ArrayList<>();
result.add(WaiterAcceptor.successOnResponseAcceptor(response -> {
WaitersRuntime.Value input = new WaitersRuntime.Value(response);
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy