From f56d2090b61dcb9ba127f751a506c95b81617663 Mon Sep 17 00:00:00 2001 From: Tw Date: Tue, 17 Nov 2015 14:07:32 +0800 Subject: [PATCH] proxy: make http header block scoped Each proxy block should could specify its own http header instead of sharing a global one. Fix issue #341 Signed-off-by: Tw --- middleware/proxy/proxy_test.go | 9 +++------ middleware/proxy/upstream.go | 22 ++++++++++++++-------- 2 files changed, 17 insertions(+), 14 deletions(-) diff --git a/middleware/proxy/proxy_test.go b/middleware/proxy/proxy_test.go index aab836bcc..55abe2dc2 100644 --- a/middleware/proxy/proxy_test.go +++ b/middleware/proxy/proxy_test.go @@ -98,11 +98,6 @@ func TestWebSocketReverseProxyFromWSClient(t *testing.T) { // also sets up the rules/environment for testing WebSocket // proxy. func newWebSocketTestProxy(backendAddr string) *Proxy { - proxyHeaders = http.Header{ - "Connection": {"{>Connection}"}, - "Upgrade": {"{>Upgrade}"}, - } - return &Proxy{ Upstreams: []Upstream{&fakeUpstream{name: backendAddr}}, } @@ -121,7 +116,9 @@ func (u *fakeUpstream) Select() *UpstreamHost { return &UpstreamHost{ Name: u.name, ReverseProxy: NewSingleHostReverseProxy(uri, ""), - ExtraHeaders: proxyHeaders, + ExtraHeaders: http.Header{ + "Connection": {"{>Connection}"}, + "Upgrade": {"{>Upgrade}"}}, } } diff --git a/middleware/proxy/upstream.go b/middleware/proxy/upstream.go index 7916b3b6c..5e9152e46 100644 --- a/middleware/proxy/upstream.go +++ b/middleware/proxy/upstream.go @@ -16,13 +16,13 @@ import ( var ( supportedPolicies = make(map[string]func() Policy) - proxyHeaders = make(http.Header) ) type staticUpstream struct { - from string - Hosts HostPool - Policy Policy + from string + proxyHeaders http.Header + Hosts HostPool + Policy Policy FailTimeout time.Duration MaxFails int32 @@ -72,7 +72,7 @@ func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { Fails: 0, FailTimeout: upstream.FailTimeout, Unhealthy: false, - ExtraHeaders: proxyHeaders, + ExtraHeaders: upstream.proxyHeaders, CheckDown: func(upstream *staticUpstream) UpstreamHostDownFunc { return func(uh *UpstreamHost) bool { if uh.Unhealthy { @@ -159,10 +159,16 @@ func parseBlock(c *parse.Dispenser, u *staticUpstream) error { if !c.Args(&header, &value) { return c.ArgErr() } - proxyHeaders.Add(header, value) + if u.proxyHeaders == nil { + u.proxyHeaders = make(http.Header) + } + u.proxyHeaders.Add(header, value) case "websocket": - proxyHeaders.Add("Connection", "{>Connection}") - proxyHeaders.Add("Upgrade", "{>Upgrade}") + if u.proxyHeaders == nil { + u.proxyHeaders = make(http.Header) + } + u.proxyHeaders.Add("Connection", "{>Connection}") + u.proxyHeaders.Add("Upgrade", "{>Upgrade}") case "without": if !c.NextArg() { return c.ArgErr()