mirror of
https://github.com/containous/traefik.git
synced 2025-01-11 05:17:52 +03:00
52 lines
1.1 KiB
Go
52 lines
1.1 KiB
Go
package server
|
|
|
|
import (
|
|
"net"
|
|
"net/http"
|
|
"os"
|
|
|
|
"github.com/containous/traefik/whitelist"
|
|
"github.com/vulcand/oxy/forward"
|
|
)
|
|
|
|
// NewHeaderRewriter Create a header rewriter
|
|
func NewHeaderRewriter(trustedIPs []string, insecure bool) (forward.ReqRewriter, error) {
|
|
IPs, err := whitelist.NewIP(trustedIPs, insecure)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
h, err := os.Hostname()
|
|
if err != nil {
|
|
h = "localhost"
|
|
}
|
|
|
|
return &headerRewriter{
|
|
secureRewriter: &forward.HeaderRewriter{TrustForwardHeader: true, Hostname: h},
|
|
insecureRewriter: &forward.HeaderRewriter{TrustForwardHeader: false, Hostname: h},
|
|
ips: IPs,
|
|
insecure: insecure,
|
|
}, nil
|
|
}
|
|
|
|
type headerRewriter struct {
|
|
secureRewriter forward.ReqRewriter
|
|
insecureRewriter forward.ReqRewriter
|
|
insecure bool
|
|
ips *whitelist.IP
|
|
}
|
|
|
|
func (h *headerRewriter) Rewrite(req *http.Request) {
|
|
clientIP, _, err := net.SplitHostPort(req.RemoteAddr)
|
|
if err != nil {
|
|
h.secureRewriter.Rewrite(req)
|
|
}
|
|
|
|
authorized, _, err := h.ips.Contains(clientIP)
|
|
if h.insecure || authorized {
|
|
h.secureRewriter.Rewrite(req)
|
|
} else {
|
|
h.insecureRewriter.Rewrite(req)
|
|
}
|
|
}
|