com.amazonaws.retry.v2.RetryOnExceptionsCondition Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-core Show documentation
Show all versions of aws-java-sdk-core Show documentation
The AWS SDK for Java - Core module holds the classes that are used by the individual service clients to interact with Amazon Web Services. Users need to depend on aws-java-sdk artifact for accessing individual client classes.
/*
* Copyright 2011-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.retry.v2;
import java.util.ArrayList;
import java.util.List;
import static com.amazonaws.util.ValidationUtils.assertNotNull;
/**
* Retry condition implementation that retries if the exception or the cause of the exception matches the classes defined.
*/
public class RetryOnExceptionsCondition implements RetryCondition {
private final List> exceptionsToRetryOn;
/**
* @param exceptionsToRetryOn Exception classes to retry on.
*/
public RetryOnExceptionsCondition(List> exceptionsToRetryOn) {
this.exceptionsToRetryOn = new ArrayList>(
assertNotNull(exceptionsToRetryOn, "exceptionsToRetryOn"));
}
/**
* @param context Context about the state of the last request and information about the number of requests made.
* @return True if the exception class matches one of the whitelisted exceptions or if the cause of the exception matches the
* whitelisted exception.
*/
@Override
public boolean shouldRetry(RetryPolicyContext context) {
if (context.exception() != null) {
for (Class extends Exception> exceptionClass : exceptionsToRetryOn) {
if (exceptionMatches(context, exceptionClass)) {
return true;
}
// Note that we check the wrapped exception too because for things like SocketException or IOException
// we wrap them in an SdkClientException before throwing.
if (wrappedCauseMatches(context, exceptionClass)) {
return true;
}
}
}
return false;
}
/**
* @param context Context containing exception.
* @param exceptionClass Expected exception class.
* @return True if the exception in the context matches the provided class.
*/
private boolean exceptionMatches(RetryPolicyContext context, Class extends Exception> exceptionClass) {
return context.exception().getClass().equals(exceptionClass);
}
/**
* @param context Context containing exception.
* @param exceptionClass Expected exception class.
* @return True if the cause of the exception in the context matches the provided class.
*/
private boolean wrappedCauseMatches(RetryPolicyContext context, Class extends Exception> exceptionClass) {
if (context.exception().getCause() == null) {
return false;
}
return context.exception().getCause().getClass().equals(exceptionClass);
}
}