/* * 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; namespace Amazon.Runtime { /// /// The interface for an exception handler. /// public interface IExceptionHandler { /// /// Handles an exception for the given execution context. /// /// The execution context, it contains the /// request and response context. /// The exception to handle. /// /// Returns a boolean value which indicates if the original exception /// should be rethrown. /// This method can also throw a new exception to replace the original exception. /// bool Handle(IExecutionContext executionContext, Exception exception); #if AWS_ASYNC_API /// /// Handles an exception for the given execution context. /// /// The execution context, it contains the /// request and response context. /// The exception to handle. /// /// Returns a boolean value which indicates if the original exception /// should be rethrown. /// This method can also throw a new exception to replace the original exception. /// System.Threading.Tasks.Task HandleAsync(IExecutionContext executionContext, Exception exception); #endif } /// /// The interface for an exception handler with a generic parameter for the exception type. /// /// The exception type. public interface IExceptionHandler : IExceptionHandler where T : Exception { /// /// Handles an exception for the given execution context. /// /// The execution context, it contains the /// request and response context. /// The exception to handle. /// /// Returns a boolean value which indicates if the original exception /// should be rethrown. /// This method can also throw a new exception to replace the original exception. /// bool HandleException(IExecutionContext executionContext, T exception); } }