mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-26 16:22:45 -04:00 
			
		
		
		
	Merge pull request #102 from brk0v/proxy-without
proxy: Add "without" option
This commit is contained in:
		
						commit
						1cb0053720
					
				| @ -42,6 +42,7 @@ type UpstreamHost struct { | ||||
| 	Unhealthy         bool | ||||
| 	ExtraHeaders      http.Header | ||||
| 	CheckDown         UpstreamHostDownFunc | ||||
| 	WithoutPathPrefix string | ||||
| } | ||||
| 
 | ||||
| // Down checks whether the upstream host is down or not. | ||||
| @ -77,7 +78,7 @@ func (p Proxy) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) { | ||||
| 				if baseURL, err := url.Parse(host.Name); err == nil { | ||||
| 					r.Host = baseURL.Host | ||||
| 					if proxy == nil { | ||||
| 						proxy = NewSingleHostReverseProxy(baseURL) | ||||
| 						proxy = NewSingleHostReverseProxy(baseURL, host.WithoutPathPrefix) | ||||
| 					} | ||||
| 				} else if proxy == nil { | ||||
| 					return http.StatusInternalServerError, err | ||||
|  | ||||
| @ -120,7 +120,7 @@ func (u *fakeUpstream) Select() *UpstreamHost { | ||||
| 	uri, _ := url.Parse(u.name) | ||||
| 	return &UpstreamHost{ | ||||
| 		Name:         u.name, | ||||
| 		ReverseProxy: NewSingleHostReverseProxy(uri), | ||||
| 		ReverseProxy: NewSingleHostReverseProxy(uri, ""), | ||||
| 		ExtraHeaders: proxyHeaders, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -62,7 +62,9 @@ func singleJoiningSlash(a, b string) string { | ||||
| // URLs to the scheme, host, and base path provided in target. If the | ||||
| // target's path is "/base" and the incoming request was for "/dir", | ||||
| // the target request will be for /base/dir. | ||||
| func NewSingleHostReverseProxy(target *url.URL) *ReverseProxy { | ||||
| // Without logic: target's path is "/", incoming is "/api/messages", | ||||
| // without is "/api", then the target request will be for /messages. | ||||
| func NewSingleHostReverseProxy(target *url.URL, without string) *ReverseProxy { | ||||
| 	targetQuery := target.RawQuery | ||||
| 	director := func(req *http.Request) { | ||||
| 		req.URL.Scheme = target.Scheme | ||||
| @ -73,6 +75,9 @@ func NewSingleHostReverseProxy(target *url.URL) *ReverseProxy { | ||||
| 		} else { | ||||
| 			req.URL.RawQuery = targetQuery + "&" + req.URL.RawQuery | ||||
| 		} | ||||
| 		if without != "" { | ||||
| 			req.URL.Path = strings.TrimPrefix(req.URL.Path, without) | ||||
| 		} | ||||
| 	} | ||||
| 	return &ReverseProxy{Director: director} | ||||
| } | ||||
|  | ||||
| @ -28,13 +28,13 @@ type staticUpstream struct { | ||||
| 		Path     string | ||||
| 		Interval time.Duration | ||||
| 	} | ||||
| 	WithoutPathPrefix string | ||||
| } | ||||
| 
 | ||||
| // NewStaticUpstreams parses the configuration input and sets up | ||||
| // static upstreams for the proxy middleware. | ||||
| func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { | ||||
| 	var upstreams []Upstream | ||||
| 
 | ||||
| 	for c.Next() { | ||||
| 		upstream := &staticUpstream{ | ||||
| 			from:        "", | ||||
| @ -104,6 +104,11 @@ func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { | ||||
| 			case "websocket": | ||||
| 				proxyHeaders.Add("Connection", "{>Connection}") | ||||
| 				proxyHeaders.Add("Upgrade", "{>Upgrade}") | ||||
| 			case "without": | ||||
| 				if !c.NextArg() { | ||||
| 					return upstreams, c.ArgErr() | ||||
| 				} | ||||
| 				upstream.WithoutPathPrefix = c.Val() | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| @ -131,9 +136,10 @@ func NewStaticUpstreams(c parse.Dispenser) ([]Upstream, error) { | ||||
| 						return false | ||||
| 					} | ||||
| 				}(upstream), | ||||
| 				WithoutPathPrefix: upstream.WithoutPathPrefix, | ||||
| 			} | ||||
| 			if baseURL, err := url.Parse(uh.Name); err == nil { | ||||
| 				uh.ReverseProxy = NewSingleHostReverseProxy(baseURL) | ||||
| 				uh.ReverseProxy = NewSingleHostReverseProxy(baseURL, uh.WithoutPathPrefix) | ||||
| 			} else { | ||||
| 				return upstreams, err | ||||
| 			} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user