From: Damien Neil Date: Fri, 17 Jun 2022 17:09:45 +0000 (-0700) Subject: [release-branch.go1.18] net/http: preserve nil values in Header.Clone X-Git-Tag: go1.18.4~8 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=ebea1e3353fa766025aa5190b9c7cc05cf069187;p=gostls13.git [release-branch.go1.18] net/http: preserve nil values in Header.Clone ReverseProxy makes a distinction between nil and zero-length header values. Avoid losing nil-ness when cloning a request. Thanks to Christian Mehlmauer for discovering this. For #53423 For CVE-2022-32148 Fixes #53621 Change-Id: Ice369cdb4712e2d62e25bb881b080847aa4801f5 Reviewed-on: https://go-review.googlesource.com/c/go/+/412857 Reviewed-by: Ian Lance Taylor Reviewed-by: Brad Fitzpatrick (cherry picked from commit b2cc0fecc2ccd80e6d5d16542cc684f97b3a9c8a) Reviewed-on: https://go-review.googlesource.com/c/go/+/415222 TryBot-Result: Gopher Robot Run-TryBot: Michael Knyszek Reviewed-by: Heschi Kreinick Run-TryBot: Heschi Kreinick Reviewed-by: Michael Knyszek --- diff --git a/src/net/http/header.go b/src/net/http/header.go index 6487e5025d..6437f2d2c0 100644 --- a/src/net/http/header.go +++ b/src/net/http/header.go @@ -103,6 +103,12 @@ func (h Header) Clone() Header { sv := make([]string, nv) // shared backing array for headers' values h2 := make(Header, len(h)) for k, vv := range h { + if vv == nil { + // Preserve nil values. ReverseProxy distinguishes + // between nil and zero-length header values. + h2[k] = nil + continue + } n := copy(sv, vv) h2[k] = sv[:n:n] sv = sv[n:] diff --git a/src/net/http/header_test.go b/src/net/http/header_test.go index 57d16f51a5..0b13d311ac 100644 --- a/src/net/http/header_test.go +++ b/src/net/http/header_test.go @@ -248,6 +248,11 @@ func TestCloneOrMakeHeader(t *testing.T) { in: Header{"foo": {"bar"}}, want: Header{"foo": {"bar"}}, }, + { + name: "nil value", + in: Header{"foo": nil}, + want: Header{"foo": nil}, + }, } for _, tt := range tests {