0
Fork 0
mirror of https://github.com/willnorris/imageproxy.git synced 2024-12-30 22:34:18 -05:00

remove behavior of copyHeaders to copy all headers

Previously, when no keys were specified, copyHeaders would copy all
headers from src to dst.  I believe this is a remnant of some old code,
as we don't actually ever use that behavior today.

I'm removing this as it seems too likely to accidentally pass along
headers that shouldn't be.  Instead, let's always be explicit about
which headers to copy (which is what we currently do anyway).
This commit is contained in:
Will Norris 2021-11-05 08:27:05 -07:00
parent d94e5610d6
commit 0f2deb14d2
2 changed files with 5 additions and 29 deletions

View file

@ -273,17 +273,11 @@ func peekContentType(p *bufio.Reader) string {
return http.DetectContentType(byt) return http.DetectContentType(byt)
} }
// copyHeader copies header values from src to dst, adding to any existing // copyHeader copies values for specified headers from src to dst, adding to
// values with the same header name. If keys is not empty, only those header // any existing values with the same header name.
// keys will be copied. func copyHeader(dst, src http.Header, headerNames ...string) {
func copyHeader(dst, src http.Header, keys ...string) { for _, name := range headerNames {
if len(keys) == 0 { k := http.CanonicalHeaderKey(name)
for k := range src {
keys = append(keys, k)
}
}
for _, key := range keys {
k := http.CanonicalHeaderKey(key)
for _, v := range src[k] { for _, v := range src[k] {
dst.Add(k, v) dst.Add(k, v)
} }

View file

@ -62,30 +62,12 @@ func TestCopyHeader(t *testing.T) {
}, },
// copy headers // copy headers
{
dst: http.Header{},
src: http.Header{"A": []string{"a"}},
keys: nil,
want: http.Header{"A": []string{"a"}},
},
{
dst: http.Header{"A": []string{"a"}},
src: http.Header{"B": []string{"b"}},
keys: nil,
want: http.Header{"A": []string{"a"}, "B": []string{"b"}},
},
{ {
dst: http.Header{"A": []string{"a"}}, dst: http.Header{"A": []string{"a"}},
src: http.Header{"B": []string{"b"}, "C": []string{"c"}}, src: http.Header{"B": []string{"b"}, "C": []string{"c"}},
keys: []string{"B"}, keys: []string{"B"},
want: http.Header{"A": []string{"a"}, "B": []string{"b"}}, want: http.Header{"A": []string{"a"}, "B": []string{"b"}},
}, },
{
dst: http.Header{"A": []string{"a1"}},
src: http.Header{"A": []string{"a2"}},
keys: nil,
want: http.Header{"A": []string{"a1", "a2"}},
},
} }
for _, tt := range tests { for _, tt := range tests {