Commit ed0c0db6 authored by Matthew Holt's avatar Matthew Holt

If scheme and port defy convention, it is an error

This prevents serving HTTPS over port 80 or HTTP over 443. It's confusing and we don't allow it.
parent 20284905
...@@ -338,7 +338,12 @@ func standardAddress(str string) (address, error) { ...@@ -338,7 +338,12 @@ func standardAddress(str string) (address, error) {
// repeated or conflicting scheme is confusing, so error // repeated or conflicting scheme is confusing, so error
if scheme != "" && (port == "http" || port == "https") { if scheme != "" && (port == "http" || port == "https") {
return address{}, fmt.Errorf("[%s] scheme specified twice in address", str) return address{}, fmt.Errorf("[%s] scheme specified twice in address", input)
}
// error if scheme and port combination violate convention
if (scheme == "http" && port == "443") || (scheme == "https" && port == "80") {
return address{}, fmt.Errorf("[%s] scheme and port violate convention", input)
} }
// standardize http and https ports to their respective port numbers // standardize http and https ports to their respective port numbers
......
...@@ -27,6 +27,8 @@ func TestStandardAddress(t *testing.T) { ...@@ -27,6 +27,8 @@ func TestStandardAddress(t *testing.T) {
{`:https`, "https", "", "443", false}, {`:https`, "https", "", "443", false},
{`http://localhost:https`, "", "", "", true}, // conflict {`http://localhost:https`, "", "", "", true}, // conflict
{`http://localhost:http`, "", "", "", true}, // repeated scheme {`http://localhost:http`, "", "", "", true}, // repeated scheme
{`http://localhost:443`, "", "", "", true}, // not conventional
{`https://localhost:80`, "", "", "", true}, // not conventional
{`http://localhost`, "http", "localhost", "80", false}, {`http://localhost`, "http", "localhost", "80", false},
{`https://localhost`, "https", "localhost", "443", false}, {`https://localhost`, "https", "localhost", "443", false},
{`http://127.0.0.1`, "http", "127.0.0.1", "80", false}, {`http://127.0.0.1`, "http", "127.0.0.1", "80", false},
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment