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:
parent
d94e5610d6
commit
0f2deb14d2
2 changed files with 5 additions and 29 deletions
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in a new issue