From 497ebb9ccb8bafce487467598ce6df66e34324f8 Mon Sep 17 00:00:00 2001 From: Wolfgang Johannes Kohnen Date: Wed, 6 Apr 2016 21:36:46 +0000 Subject: [PATCH] Handle host names case insensitively. RFC 3986 3.2.2: The host subcomponent is case-insensitive. --- caddy/parse/parsing.go | 4 ++++ caddy/parse/parsing_test.go | 3 +++ server/server.go | 4 ++++ 3 files changed, 11 insertions(+) diff --git a/caddy/parse/parsing.go b/caddy/parse/parsing.go index 26999db5a..3d4a383cd 100644 --- a/caddy/parse/parsing.go +++ b/caddy/parse/parsing.go @@ -104,6 +104,7 @@ func (p *parser) addresses() error { if err != nil { return err } + p.block.Addresses = append(p.block.Addresses, addr) } @@ -329,6 +330,9 @@ func standardAddress(str string) (address, error) { } } + // "The host subcomponent is case-insensitive." (RFC 3986) + host = strings.ToLower(host) + // see if we can set port based off scheme if port == "" { if scheme == "http" { diff --git a/caddy/parse/parsing_test.go b/caddy/parse/parsing_test.go index 493c0fff9..db7fd3e1b 100644 --- a/caddy/parse/parsing_test.go +++ b/caddy/parse/parsing_test.go @@ -13,7 +13,9 @@ func TestStandardAddress(t *testing.T) { shouldErr bool }{ {`localhost`, "", "localhost", "", false}, + {`LOCALHOST`, "", "localhost", "", false}, {`localhost:1234`, "", "localhost", "1234", false}, + {`LOCALHOST:1234`, "", "localhost", "1234", false}, {`localhost:`, "", "localhost", "", false}, {`0.0.0.0`, "", "0.0.0.0", "", false}, {`127.0.0.1:1234`, "", "127.0.0.1", "1234", false}, @@ -35,6 +37,7 @@ func TestStandardAddress(t *testing.T) { {`https://127.0.0.1`, "https", "127.0.0.1", "443", false}, {`http://[::1]`, "http", "::1", "80", false}, {`http://localhost:1234`, "http", "localhost", "1234", false}, + {`http://LOCALHOST:1234`, "http", "localhost", "1234", false}, {`https://127.0.0.1:1234`, "https", "127.0.0.1", "1234", false}, {`http://[::1]:1234`, "http", "::1", "1234", false}, {``, "", "", "", false}, diff --git a/server/server.go b/server/server.go index d09853519..7b9856ef2 100644 --- a/server/server.go +++ b/server/server.go @@ -13,6 +13,7 @@ import ( "net/http" "os" "runtime" + "strings" "sync" "time" ) @@ -301,6 +302,9 @@ func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) { host = r.Host // oh well } + // "The host subcomponent is case-insensitive." (RFC 3986) + host = strings.ToLower(host) + // Try the host as given, or try falling back to 0.0.0.0 (wildcard) if _, ok := s.vhosts[host]; !ok { if _, ok2 := s.vhosts["0.0.0.0"]; ok2 {