From 69363bb62e2b9767c527101620010799bd6a3f30 Mon Sep 17 00:00:00 2001 From: Steven Lizano Date: Thu, 11 Apr 2024 08:01:42 -0600 Subject: [PATCH 1/3] [SNOW-1313929] Add https to endpoints without it --- .../UnitTests/SFS3ClientTest.cs | 31 +++++++++++++++++++ .../FileTransfer/StorageClient/SFS3Client.cs | 29 ++++++++--------- 2 files changed, 46 insertions(+), 14 deletions(-) diff --git a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs index 561819623..75f09a555 100644 --- a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs +++ b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs @@ -3,6 +3,7 @@ */ using System; +using Amazon.S3.Encryption; namespace Snowflake.Data.Tests.UnitTests { @@ -219,6 +220,36 @@ public void TestUploadFile(string requestKey, ResultStatus expectedResultStatus) AssertForUploadFileTests(expectedResultStatus); } + [Test] + public void SetCommonClientConfig_AppendHttpsToURL() + { + // Arrange + var amazonS3Client = new AmazonS3Config(); + var endpoint = "endpointWithNoHttps.com"; + var expectedEndpoint = "https://endpointWithNoHttps.com"; + + // ACT + SFS3Client.SetCommonClientConfig(amazonS3Client, string.Empty, endpoint, 1, 0); + + // Assert + Assert.That(amazonS3Client.ServiceURL, Is.EqualTo(expectedEndpoint)); + } + + [Test] + public void SetCommonClientConfig_AppendHttpsToURLWithBrackets() + { + // Arrange + var amazonS3Client = new AmazonS3Config(); + var endpoint = "[endpointWithNoHttps.com]"; + var expectedEndpoint = "https://endpointWithNoHttps.com"; + + // ACT + SFS3Client.SetCommonClientConfig(amazonS3Client, string.Empty, endpoint, 1, 0); + + // Assert + Assert.That(amazonS3Client.ServiceURL, Is.EqualTo(expectedEndpoint)); + } + [Test] [TestCase(MockS3Client.AwsStatusOk, ResultStatus.UPLOADED)] [TestCase(SFS3Client.EXPIRED_TOKEN, ResultStatus.RENEW_TOKEN)] diff --git a/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs b/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs index e68fbbd3e..75bb4190c 100644 --- a/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs +++ b/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs @@ -116,7 +116,7 @@ public SFS3Client( stageInfo.endPoint, maxRetry, parallel); - + // Get the AWS token value and create the S3 client if (stageInfo.stageCredentials.TryGetValue(AWS_TOKEN, out string awsSessionToken)) { @@ -164,7 +164,7 @@ public RemoteLocation ExtractBucketNameAndPath(string stageLocation) { bucketName = stageLocation.Substring(0, stageLocation.IndexOf('/')); - s3path = stageLocation.Substring(stageLocation.IndexOf('/') + 1, + s3path = stageLocation.Substring(stageLocation.IndexOf('/') + 1, stageLocation.Length - stageLocation.IndexOf('/') - 1); if (s3path != null && !s3path.EndsWith("/")) { @@ -287,13 +287,13 @@ private FileHeader HandleFileHeaderResponse(ref SFFileMetadata fileMetadata, Get } /// - /// Set the client configuration common to both client with and without client-side + /// Set the client configuration common to both client with and without client-side /// encryption. /// /// The client config to update. /// The region if any. /// The endpoint if any. - private static void SetCommonClientConfig( + internal static void SetCommonClientConfig( AmazonS3Config clientConfig, string region, string endpoint, @@ -309,23 +309,25 @@ private static void SetCommonClientConfig( } // If a specific endpoint is specified use this - if ((null != endpoint) && (0 != endpoint.Length)) + if (!string.IsNullOrEmpty(endpoint)) { var start = endpoint.IndexOf('['); var end = endpoint.IndexOf(']'); - if(start > -1 && end > -1 && end > start) + if (start > -1 && end > -1 && end > start) { endpoint = endpoint.Substring(start + 1, end - start - 1); - if(!endpoint.Contains("https")) - { - endpoint = "https://" + endpoint; - } } + + if (!endpoint.Contains("https://")) + { + endpoint = "https://" + endpoint; + } + clientConfig.ServiceURL = endpoint; } // The region information used to determine the endpoint for the service. - // RegionEndpoint and ServiceURL are mutually exclusive properties. + // RegionEndpoint and ServiceURL are mutually exclusive properties. // If both stageInfo.endPoint and stageInfo.region have a value, stageInfo.region takes // precedence and ServiceUrl will be reset to null. if ((null != region) && (0 != region.Length)) @@ -337,7 +339,6 @@ private static void SetCommonClientConfig( // Unavailable for .net framework 4.6 //clientConfig.MaxConnectionsPerServer = parallel; clientConfig.MaxErrorRetry = maxRetry; - } /// @@ -410,7 +411,7 @@ private PutObjectRequest GetPutObjectRequest(ref AmazonS3Client client, SFFileMe { PutGetStageInfo stageInfo = fileMetadata.stageInfo; RemoteLocation location = ExtractBucketNameAndPath(stageInfo.location); - + // Create S3 PUT request fileBytesStream.Position = 0; PutObjectRequest putObjectRequest = new PutObjectRequest @@ -585,4 +586,4 @@ private SFFileMetadata HandleDownloadFileErr(Exception ex, SFFileMetadata fileMe return fileMetadata; } } -} \ No newline at end of file +} From 9bb006b2ba4c6437e4a7165b34ba9aed6cdcc5fc Mon Sep 17 00:00:00 2001 From: Steven Lizano Date: Tue, 16 Apr 2024 07:48:25 -0600 Subject: [PATCH 2/3] Change endpoint verification to startWith, change test names --- Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs | 4 ++-- Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs index 75f09a555..5193d9d38 100644 --- a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs +++ b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs @@ -221,7 +221,7 @@ public void TestUploadFile(string requestKey, ResultStatus expectedResultStatus) } [Test] - public void SetCommonClientConfig_AppendHttpsToURL() + public void TestSetCommonClientConfigAppendHttpsToURL() { // Arrange var amazonS3Client = new AmazonS3Config(); @@ -236,7 +236,7 @@ public void SetCommonClientConfig_AppendHttpsToURL() } [Test] - public void SetCommonClientConfig_AppendHttpsToURLWithBrackets() + public void TestSetCommonClientConfigAppendHttpsToURLWithBrackets() { // Arrange var amazonS3Client = new AmazonS3Config(); diff --git a/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs b/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs index 75bb4190c..88b20c1d5 100644 --- a/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs +++ b/Snowflake.Data/Core/FileTransfer/StorageClient/SFS3Client.cs @@ -318,7 +318,7 @@ internal static void SetCommonClientConfig( endpoint = endpoint.Substring(start + 1, end - start - 1); } - if (!endpoint.Contains("https://")) + if (!endpoint.StartsWith("https://", StringComparison.OrdinalIgnoreCase)) { endpoint = "https://" + endpoint; } From e0f2247f1afa30ef7a057255988b19127580604e Mon Sep 17 00:00:00 2001 From: Steven Lizano Date: Wed, 17 Apr 2024 11:37:37 -0600 Subject: [PATCH 3/3] remove SetCommonClientConfig to SFS3ClientTest --- Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs index 5193d9d38..da3baf531 100644 --- a/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs +++ b/Snowflake.Data.Tests/UnitTests/SFS3ClientTest.cs @@ -221,7 +221,7 @@ public void TestUploadFile(string requestKey, ResultStatus expectedResultStatus) } [Test] - public void TestSetCommonClientConfigAppendHttpsToURL() + public void TestAppendHttpsToEndpoint() { // Arrange var amazonS3Client = new AmazonS3Config(); @@ -236,7 +236,7 @@ public void TestSetCommonClientConfigAppendHttpsToURL() } [Test] - public void TestSetCommonClientConfigAppendHttpsToURLWithBrackets() + public void TestAppendHttpsToEndpointWithBrackets() { // Arrange var amazonS3Client = new AmazonS3Config();