/* * 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. */ using System; #if AWS_ASYNC_API using System.Threading.Tasks; #endif using Amazon.Runtime; using Amazon.Runtime.Internal; using Amazon.SecurityToken.Model; namespace Amazon.SecurityToken { /// /// An implementation of the that retries certain additional /// STS errors when doing AssumeRoleWithWebIdentity requests. /// public class SecurityTokenServiceRetryPolicy : DefaultRetryPolicy { /// /// Constructor for SecurityTokenServiceRetryPolicy. /// public SecurityTokenServiceRetryPolicy(IClientConfig config) : base(config) { } /// /// Returns true if the request should be retried. /// public override bool RetryForException(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return true; } return base.RetryForException(executionContext, exception); } #if AWS_ASYNC_API /// /// Returns true if the request should be retried. /// public override Task RetryForExceptionAsync(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return Task.FromResult(true); } return base.RetryForExceptionAsync(executionContext, exception); } #endif } /// /// An implementation of the that retries certain additional /// STS errors when doing AssumeRoleWithWebIdentity requests. /// public class SecurityTokenServiceStandardRetryPolicy : StandardRetryPolicy { /// /// Constructor for SecurityTokenServiceStandardRetryPolicy. /// public SecurityTokenServiceStandardRetryPolicy(IClientConfig config) : base(config) { } /// /// Returns true if the request should be retried. /// public override bool RetryForException(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return true; } return base.RetryForException(executionContext, exception); } #if AWS_ASYNC_API /// /// Returns true if the request should be retried. /// public override Task RetryForExceptionAsync(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return Task.FromResult(true); } return base.RetryForExceptionAsync(executionContext, exception); } #endif } /// /// An implementation of the that retries certain additional /// STS errors when doing AssumeRoleWithWebIdentity requests. /// public class SecurityTokenServiceAdaptiveRetryPolicy : AdaptiveRetryPolicy { /// /// Constructor for SecurityTokenServiceAdaptiveRetryPolicy. /// public SecurityTokenServiceAdaptiveRetryPolicy(IClientConfig config) : base(config) { } /// /// Returns true if the request should be retried. /// public override bool RetryForException(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return true; } return base.RetryForException(executionContext, exception); } #if AWS_ASYNC_API /// /// Returns true if the request should be retried. /// public override Task RetryForExceptionAsync(IExecutionContext executionContext, Exception exception) { if (executionContext.RequestContext.OriginalRequest is AssumeRoleWithWebIdentityRequest && (exception is IDPCommunicationErrorException || exception is InvalidIdentityTokenException)) { return Task.FromResult(true); } return base.RetryForExceptionAsync(executionContext, exception); } #endif } }