Files
cloudpods/pkg/proxy/http.go
Yousong Zhou 8fe4f2ec98 treewide: group imports with goimports
./goimports -w -local yunion.io/x/onecloud/ -corp yunion.io/x/ $GOPATH/src/yunion.io/x/onecloud/{cmd,pkg}
2019-03-13 10:46:12 +00:00

61 lines
1.4 KiB
Go

package proxy
import (
"context"
"crypto/tls"
"net/http"
"net/http/httputil"
"net/url"
"yunion.io/x/log"
"yunion.io/x/onecloud/pkg/httperrors"
)
type EndpointGenerator func(context.Context, http.ResponseWriter, *http.Request) (string, error)
type SEndpointFactory struct {
generator EndpointGenerator
serviceName string
}
func NewEndpointFactory(f EndpointGenerator, serviceName string) *SEndpointFactory {
return &SEndpointFactory{
generator: f,
serviceName: serviceName,
}
}
type SReverseProxy struct {
*SEndpointFactory
}
func NewHTTPReverseProxy(ef *SEndpointFactory) *SReverseProxy {
return &SReverseProxy{
SEndpointFactory: ef,
}
}
func (p *SReverseProxy) ServeHTTP(ctx context.Context, w http.ResponseWriter, r *http.Request) {
endpoint, err := p.generator(ctx, w, r)
if err != nil {
httperrors.InternalServerError(w, err.Error())
return
}
remoteUrl, err := url.Parse(endpoint)
if err != nil {
httperrors.InternalServerError(w, "failed parsing url %q: %v", endpoint, err)
return
}
log.Debugf("Forwarding to servie: %q, url: %q", p.serviceName, remoteUrl.String())
proxy := httputil.NewSingleHostReverseProxy(remoteUrl)
proxy.Transport = &http.Transport{
Proxy: http.ProxyFromEnvironment,
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
DisableKeepAlives: true,
}
r.Header.Del("Cookie")
r.Header.Del("X-Auth-Token")
proxy.ServeHTTP(w, r)
}