/* * 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 Amazon.Runtime; using Amazon.Runtime.Internal; using Amazon.S3.Util; using System; namespace Amazon.S3.Internal { /// /// Custom pipeline handler to enable sig V4 for Get requests. /// public class AmazonS3KmsHandler : PipelineHandler { /// /// Calls pre invoke logic before calling the next handler /// in the pipeline. /// /// The execution context which contains both the /// requests and response context. public override void InvokeSync(IExecutionContext executionContext) { PreInvoke(executionContext); base.InvokeSync(executionContext); } #if AWS_ASYNC_API /// /// Calls pre invoke logic before calling the next handler /// in the pipeline. /// /// The response type for the current request. /// The execution context, it contains the /// request and response context. /// A task that represents the asynchronous operation. public override System.Threading.Tasks.Task InvokeAsync(IExecutionContext executionContext) { PreInvoke(executionContext); return base.InvokeAsync(executionContext); } #elif AWS_APM_API /// /// Calls pre invoke logic before calling the next handler /// in the pipeline. /// /// The execution context which contains both the /// requests and response context. /// IAsyncResult which represent an async operation. public override IAsyncResult InvokeAsync(IAsyncExecutionContext executionContext) { PreInvoke(ExecutionContext.CreateFromAsyncContext(executionContext)); return base.InvokeAsync(executionContext); } #endif /// /// Custom pipeline handler to enable sig V4 for Get requests. /// /// protected virtual void PreInvoke(IExecutionContext executionContext) { var request = executionContext.RequestContext.Request; EvaluateIfSigV4Required(request); } internal static void EvaluateIfSigV4Required(IRequest request) { // Skip this if the request has already been "upgraded" to SigV4a if (request.SignatureVersion == SignatureVersion.SigV4a) { return; } // Skip this for S3-compatible storage provider endpoints if (request.OriginalRequest is S3.Model.GetObjectRequest && AmazonS3Uri.TryParseAmazonS3Uri(request.Endpoint, out var amazonS3Uri) && amazonS3Uri.Region?.SystemName != RegionEndpoint.USEast1.SystemName) { request.SignatureVersion = SignatureVersion.SigV4; } } } }