From e99ce30f5035e3a91f336ab233acae53067826c1 Mon Sep 17 00:00:00 2001 From: Harshavardhana Date: Tue, 22 Feb 2022 18:38:55 -0800 Subject: [PATCH] fix: ipv6 support without 'port' add missing brackets (#1624) --- api.go | 4 ++++ api_unit_test.go | 2 ++ 2 files changed, 6 insertions(+) diff --git a/api.go b/api.go index a8318e0ee..6b874e5c9 100644 --- a/api.go +++ b/api.go @@ -875,10 +875,14 @@ func (c *Client) makeTargetURL(bucketName, objectName, bucketLocation string, is if h, p, err := net.SplitHostPort(host); err == nil { if scheme == "http" && p == "80" || scheme == "https" && p == "443" { host = h + if ip := net.ParseIP(h); ip != nil && ip.To16() != nil { + host = "[" + h + "]" + } } } urlStr := scheme + "://" + host + "/" + // Make URL only if bucketName is available, otherwise use the // endpoint URL. if bucketName != "" { diff --git a/api_unit_test.go b/api_unit_test.go index dadfeeb85..3defca202 100644 --- a/api_unit_test.go +++ b/api_unit_test.go @@ -196,6 +196,8 @@ func TestMakeTargetURL(t *testing.T) { {"localhost:80", false, "mybucket", "myobject", "", nil, url.URL{Host: "localhost", Scheme: "http", Path: "/mybucket/myobject"}, nil}, // Test 9, testing with port 443 {"localhost:443", true, "mybucket", "myobject", "", nil, url.URL{Host: "localhost", Scheme: "https", Path: "/mybucket/myobject"}, nil}, + {"[240b:c0e0:102:54C0:1c05:c2c1:19:5001]:443", true, "mybucket", "myobject", "", nil, url.URL{Host: "[240b:c0e0:102:54C0:1c05:c2c1:19:5001]", Scheme: "https", Path: "/mybucket/myobject"}, nil}, + {"[240b:c0e0:102:54C0:1c05:c2c1:19:5001]:9000", true, "mybucket", "myobject", "", nil, url.URL{Host: "[240b:c0e0:102:54C0:1c05:c2c1:19:5001]:9000", Scheme: "https", Path: "/mybucket/myobject"}, nil}, } for i, testCase := range testCases {