0
Fork 0
mirror of https://github.com/willnorris/imageproxy.git synced 2025-01-06 22:40:34 -05:00

customize copy of ReverseProxy

- allow Director func to return an error
- convert ErrorLog to an interface
- remove unused NewSingleHostReverseProxy func
This commit is contained in:
Will Norris 2017-06-15 00:58:23 -04:00
parent 7a890f5966
commit 457e1fbe35

View file

@ -12,7 +12,6 @@ import (
"log" "log"
"net" "net"
"net/http" "net/http"
"net/url"
"strings" "strings"
"sync" "sync"
"time" "time"
@ -32,7 +31,7 @@ type ReverseProxy struct {
// back to the original client unmodified. // back to the original client unmodified.
// Director must not access the provided Request // Director must not access the provided Request
// after returning. // after returning.
Director func(*http.Request) Director func(*http.Request) error
// The transport used to perform proxy requests. // The transport used to perform proxy requests.
// If nil, http.DefaultTransport is used. // If nil, http.DefaultTransport is used.
@ -48,7 +47,9 @@ type ReverseProxy struct {
// that occur when attempting to proxy the request. // that occur when attempting to proxy the request.
// If nil, logging goes to os.Stderr via the log package's // If nil, logging goes to os.Stderr via the log package's
// standard logger. // standard logger.
ErrorLog *log.Logger ErrorLog interface {
Printf(format string, v ...interface{})
}
// BufferPool optionally specifies a buffer pool to // BufferPool optionally specifies a buffer pool to
// get byte slices for use by io.CopyBuffer when // get byte slices for use by io.CopyBuffer when
@ -80,32 +81,6 @@ func singleJoiningSlash(a, b string) string {
return a + b return a + b
} }
// NewSingleHostReverseProxy returns a new ReverseProxy that routes
// 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.
// NewSingleHostReverseProxy does not rewrite the Host header.
// To rewrite Host headers, use ReverseProxy directly with a custom
// Director policy.
func NewSingleHostReverseProxy(target *url.URL) *ReverseProxy {
targetQuery := target.RawQuery
director := func(req *http.Request) {
req.URL.Scheme = target.Scheme
req.URL.Host = target.Host
req.URL.Path = singleJoiningSlash(target.Path, req.URL.Path)
if targetQuery == "" || req.URL.RawQuery == "" {
req.URL.RawQuery = targetQuery + req.URL.RawQuery
} else {
req.URL.RawQuery = targetQuery + "&" + req.URL.RawQuery
}
if _, ok := req.Header["User-Agent"]; !ok {
// explicitly disable User-Agent so it's not set to default value
req.Header.Set("User-Agent", "")
}
}
return &ReverseProxy{Director: director}
}
func copyHeader(dst, src http.Header) { func copyHeader(dst, src http.Header) {
for k, vv := range src { for k, vv := range src {
for _, v := range vv { for _, v := range vv {
@ -154,7 +129,12 @@ func (p *ReverseProxy) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
outreq.Body = nil // Issue 16036: nil Body for http.Transport retries outreq.Body = nil // Issue 16036: nil Body for http.Transport retries
} }
p.Director(outreq) if err := p.Director(outreq); err != nil {
p.logf("http: proxy error: %v", err)
rw.WriteHeader(http.StatusBadGateway)
return
}
outreq.Close = false outreq.Close = false
// We are modifying the same underlying map from req (shallow // We are modifying the same underlying map from req (shallow