mirror of
https://github.com/yunionio/cloudpods.git
synced 2026-05-22 12:32:36 +08:00
./goimports -w -local yunion.io/x/onecloud/ -corp yunion.io/x/ $GOPATH/src/yunion.io/x/onecloud/{cmd,pkg}
61 lines
1.4 KiB
Go
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)
|
|
}
|