From d84cd40be5c95460eefd8eec782263a0159fe70d Mon Sep 17 00:00:00 2001 From: Robert van Gent Date: Wed, 9 Oct 2024 00:58:30 +0000 Subject: [PATCH] aws: Add support for non-camelcased version of two URL parameters. --- aws/aws.go | 8 ++++---- aws/aws_test.go | 10 ++++++++++ 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/aws/aws.go b/aws/aws.go index 2e4cbafdef..f4a6dce45e 100644 --- a/aws/aws.go +++ b/aws/aws.go @@ -80,8 +80,8 @@ func (co ConfigOverrider) ClientConfig(serviceName string, cfgs ...*aws.Config) // The following query options are supported: // - region: The AWS region for requests; sets aws.Config.Region. // - endpoint: The endpoint URL (hostname only or fully qualified URI); sets aws.Config.Endpoint. -// - disableSSL: A value of "true" disables SSL when sending requests; sets aws.Config.DisableSSL. -// - s3ForcePathStyle: A value of "true" forces the request to use path-style addressing; sets aws.Config.S3ForcePathStyle. +// - disable_ssl (or disableSSL): A value of "true" disables SSL when sending requests; sets aws.Config.DisableSSL. +// - s3_force_path_style (or s3ForcePathStyle): A value of "true" forces the request to use path-style addressing; sets aws.Config.S3ForcePathStyle. // - dualstack: A value of "true" enables dual stack (IPv4 and IPv6) endpoints // - fips: A value of "true" enables the use of FIPS endpoints func ConfigFromURLParams(q url.Values) (*aws.Config, error) { @@ -93,13 +93,13 @@ func ConfigFromURLParams(q url.Values) (*aws.Config, error) { cfg.Region = aws.String(value) case "endpoint": cfg.Endpoint = aws.String(value) - case "disableSSL": + case "disable_ssl", "disableSSL": b, err := strconv.ParseBool(value) if err != nil { return nil, fmt.Errorf("invalid value for query parameter %q: %v", param, err) } cfg.DisableSSL = aws.Bool(b) - case "s3ForcePathStyle": + case "s3_force_path_style", "s3ForcePathStyle": b, err := strconv.ParseBool(value) if err != nil { return nil, fmt.Errorf("invalid value for query parameter %q: %v", param, err) diff --git a/aws/aws_test.go b/aws/aws_test.go index 8ad2984ed4..471580a1d8 100644 --- a/aws/aws_test.go +++ b/aws/aws_test.go @@ -53,6 +53,11 @@ func TestConfigFromURLParams(t *testing.T) { query: url.Values{"endpoint": {"foo"}}, wantCfg: &aws.Config{Endpoint: aws.String("foo")}, }, + { + name: "disable_ssl true", + query: url.Values{"disable_ssl": {"true"}}, + wantCfg: &aws.Config{DisableSSL: aws.Bool(true)}, + }, { name: "DisableSSL true", query: url.Values{"disableSSL": {"true"}}, @@ -68,6 +73,11 @@ func TestConfigFromURLParams(t *testing.T) { query: url.Values{"disableSSL": {"invalid"}}, wantErr: true, }, + { + name: "s3_force_path_style true", + query: url.Values{"s3_force_path_style": {"true"}}, + wantCfg: &aws.Config{S3ForcePathStyle: aws.Bool(true)}, + }, { name: "S3ForcePathStyle true", query: url.Values{"s3ForcePathStyle": {"true"}},