mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-22 08:33:01 +08:00
Revert "Merge pull request #931 from pedronasser/master"
This reverts commit9ea0591951
, reversing changes made to2125ae5f99
.
This commit is contained in:
parent
4678471fe0
commit
57710e8b0d
|
@ -30,8 +30,6 @@ type Upstream interface {
|
||||||
Select() *UpstreamHost
|
Select() *UpstreamHost
|
||||||
// Checks if subpath is not an ignored path
|
// Checks if subpath is not an ignored path
|
||||||
AllowedPath(string) bool
|
AllowedPath(string) bool
|
||||||
// Is Upstream in transparent mode?
|
|
||||||
Transparent() bool
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpstreamHostDownFunc can be used to customize how Down behaves.
|
// UpstreamHostDownFunc can be used to customize how Down behaves.
|
||||||
|
@ -96,7 +94,6 @@ func (p Proxy) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
for time.Now().Sub(start) < tryDuration {
|
for time.Now().Sub(start) < tryDuration {
|
||||||
host := upstream.Select()
|
host := upstream.Select()
|
||||||
|
|
||||||
if host == nil {
|
if host == nil {
|
||||||
return http.StatusBadGateway, errUnreachable
|
return http.StatusBadGateway, errUnreachable
|
||||||
}
|
}
|
||||||
|
@ -128,9 +125,6 @@ func (p Proxy) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
if v, ok := host.UpstreamHeaders["Host"]; ok {
|
if v, ok := host.UpstreamHeaders["Host"]; ok {
|
||||||
outreq.Host = replacer.Replace(v[len(v)-1])
|
outreq.Host = replacer.Replace(v[len(v)-1])
|
||||||
}
|
}
|
||||||
if upstream.Transparent() {
|
|
||||||
host.UpstreamHeaders.Set("Host", host.Name)
|
|
||||||
}
|
|
||||||
// modify headers for request that will be sent to the upstream host
|
// modify headers for request that will be sent to the upstream host
|
||||||
upHeaders := createHeadersByRules(host.UpstreamHeaders, r.Header, replacer)
|
upHeaders := createHeadersByRules(host.UpstreamHeaders, r.Header, replacer)
|
||||||
for k, v := range upHeaders {
|
for k, v := range upHeaders {
|
||||||
|
|
|
@ -687,10 +687,6 @@ func (u *fakeUpstream) AllowedPath(requestPath string) bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *fakeUpstream) Transparent() bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// newWebSocketTestProxy returns a test proxy that will
|
// newWebSocketTestProxy returns a test proxy that will
|
||||||
// redirect to the specified backendAddr. The function
|
// redirect to the specified backendAddr. The function
|
||||||
// also sets up the rules/environment for testing WebSocket
|
// also sets up the rules/environment for testing WebSocket
|
||||||
|
@ -733,10 +729,6 @@ func (u *fakeWsUpstream) AllowedPath(requestPath string) bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *fakeWsUpstream) Transparent() bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
// recorderHijacker is a ResponseRecorder that can
|
// recorderHijacker is a ResponseRecorder that can
|
||||||
// be hijacked.
|
// be hijacked.
|
||||||
type recorderHijacker struct {
|
type recorderHijacker struct {
|
||||||
|
|
|
@ -26,7 +26,6 @@ type staticUpstream struct {
|
||||||
Hosts HostPool
|
Hosts HostPool
|
||||||
Policy Policy
|
Policy Policy
|
||||||
insecureSkipVerify bool
|
insecureSkipVerify bool
|
||||||
transparent bool
|
|
||||||
|
|
||||||
FailTimeout time.Duration
|
FailTimeout time.Duration
|
||||||
MaxFails int32
|
MaxFails int32
|
||||||
|
@ -55,7 +54,6 @@ func NewStaticUpstreams(c caddyfile.Dispenser) ([]Upstream, error) {
|
||||||
FailTimeout: 10 * time.Second,
|
FailTimeout: 10 * time.Second,
|
||||||
MaxFails: 1,
|
MaxFails: 1,
|
||||||
MaxConns: 0,
|
MaxConns: 0,
|
||||||
transparent: false,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if !c.Args(&upstream.from) {
|
if !c.Args(&upstream.from) {
|
||||||
|
@ -294,7 +292,7 @@ func parseBlock(c *caddyfile.Dispenser, u *staticUpstream) error {
|
||||||
}
|
}
|
||||||
u.downstreamHeaders.Add(header, value)
|
u.downstreamHeaders.Add(header, value)
|
||||||
case "transparent":
|
case "transparent":
|
||||||
u.transparent = true
|
u.upstreamHeaders.Add("Host", "{host}")
|
||||||
u.upstreamHeaders.Add("X-Real-IP", "{remote}")
|
u.upstreamHeaders.Add("X-Real-IP", "{remote}")
|
||||||
u.upstreamHeaders.Add("X-Forwarded-For", "{remote}")
|
u.upstreamHeaders.Add("X-Forwarded-For", "{remote}")
|
||||||
u.upstreamHeaders.Add("X-Forwarded-Proto", "{scheme}")
|
u.upstreamHeaders.Add("X-Forwarded-Proto", "{scheme}")
|
||||||
|
@ -373,11 +371,6 @@ func (u *staticUpstream) Select() *UpstreamHost {
|
||||||
return u.Policy.Select(pool)
|
return u.Policy.Select(pool)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Transparent returns true if upstream in transparent mode
|
|
||||||
func (u *staticUpstream) Transparent() bool {
|
|
||||||
return u.transparent
|
|
||||||
}
|
|
||||||
|
|
||||||
func (u *staticUpstream) AllowedPath(requestPath string) bool {
|
func (u *staticUpstream) AllowedPath(requestPath string) bool {
|
||||||
for _, ignoredSubPath := range u.IgnoredSubPaths {
|
for _, ignoredSubPath := range u.IgnoredSubPaths {
|
||||||
if httpserver.Path(path.Clean(requestPath)).Matches(path.Join(u.From(), ignoredSubPath)) {
|
if httpserver.Path(path.Clean(requestPath)).Matches(path.Join(u.From(), ignoredSubPath)) {
|
||||||
|
|
|
@ -209,8 +209,8 @@ func TestParseBlock(t *testing.T) {
|
||||||
for _, upstream := range upstreams {
|
for _, upstream := range upstreams {
|
||||||
headers := upstream.Select().UpstreamHeaders
|
headers := upstream.Select().UpstreamHeaders
|
||||||
|
|
||||||
if !upstream.Transparent() {
|
if _, ok := headers["Host"]; !ok {
|
||||||
t.Errorf("Test %d: Upstream should be in transparent mode", i+1)
|
t.Errorf("Test %d: Could not find the Host header", i+1)
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, ok := headers["X-Real-Ip"]; !ok {
|
if _, ok := headers["X-Real-Ip"]; !ok {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user