caddyhttp: Fix header matcher when using nil

Uncovered in #3807
This commit is contained in:
Matthew Holt 2020-11-17 11:29:43 -07:00
parent 99b8f44486
commit 4fc570711e
No known key found for this signature in database
GPG key ID: 2A349DD577D586A5
2 changed files with 14 additions and 0 deletions

View file

@ -445,6 +445,10 @@ func matchHeaders(input, against http.Header, host string) bool {
// match if the header field exists at all // match if the header field exists at all
continue continue
} }
if allowedFieldVals == nil && actualFieldVals == nil {
// a nil list means match if the header does not exist at all
continue
}
var match bool var match bool
fieldVals: fieldVals:
for _, actualFieldVal := range actualFieldVals { for _, actualFieldVal := range actualFieldVals {

View file

@ -480,6 +480,16 @@ func TestHeaderMatcher(t *testing.T) {
host: "caddyserver.com", host: "caddyserver.com",
expect: false, expect: false,
}, },
{
match: MatchHeader{"Must-Not-Exist": nil},
input: http.Header{},
expect: true,
},
{
match: MatchHeader{"Must-Not-Exist": nil},
input: http.Header{"Must-Not-Exist": []string{"do not match"}},
expect: false,
},
} { } {
req := &http.Request{Header: tc.input, Host: tc.host} req := &http.Request{Header: tc.input, Host: tc.host}
actual := tc.match.Match(req) actual := tc.match.Match(req)