fix: custom Host header.

This commit is contained in:
Ludovic Fernandez 2020-03-18 00:54:04 +01:00 committed by GitHub
parent 668e6fd610
commit 09224e4b04
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 51 additions and 2 deletions

View file

@ -165,9 +165,14 @@ func (s *Header) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
func (s *Header) modifyCustomRequestHeaders(req *http.Request) { func (s *Header) modifyCustomRequestHeaders(req *http.Request) {
// Loop through Custom request headers // Loop through Custom request headers
for header, value := range s.headers.CustomRequestHeaders { for header, value := range s.headers.CustomRequestHeaders {
if value == "" { switch {
case value == "":
req.Header.Del(header) req.Header.Del(header)
} else {
case strings.EqualFold(header, "Host"):
req.Host = value
default:
req.Header.Set(header, value) req.Header.Set(header, value)
} }
} }

View file

@ -33,6 +33,50 @@ func TestCustomRequestHeader(t *testing.T) {
assert.Equal(t, "test_request", req.Header.Get("X-Custom-Request-Header")) assert.Equal(t, "test_request", req.Header.Get("X-Custom-Request-Header"))
} }
func TestCustomRequestHeader_Host(t *testing.T) {
emptyHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {})
testCases := []struct {
desc string
customHeaders map[string]string
expectedHost string
expectedURLHost string
}{
{
desc: "standard Host header",
customHeaders: map[string]string{},
expectedHost: "example.org",
expectedURLHost: "example.org",
},
{
desc: "custom Host header",
customHeaders: map[string]string{
"Host": "example.com",
},
expectedHost: "example.com",
expectedURLHost: "example.org",
},
}
for _, test := range testCases {
t.Run(test.desc, func(t *testing.T) {
header := NewHeader(emptyHandler, dynamic.Headers{
CustomRequestHeaders: test.customHeaders,
})
res := httptest.NewRecorder()
req, err := http.NewRequest(http.MethodGet, "http://example.org/foo", nil)
require.NoError(t, err)
header.ServeHTTP(res, req)
assert.Equal(t, http.StatusOK, res.Code)
assert.Equal(t, test.expectedHost, req.Host)
assert.Equal(t, test.expectedURLHost, req.URL.Host)
})
}
}
func TestCustomRequestHeaderEmptyValue(t *testing.T) { func TestCustomRequestHeaderEmptyValue(t *testing.T) {
emptyHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {}) emptyHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {})