From 5787c1e83f1ae75d20ac9579ddedefb1aeccb6ef Mon Sep 17 00:00:00 2001 From: Stephen Heywood Date: Fri, 20 Aug 2021 08:57:19 +1200 Subject: [PATCH] Redirect proxy requests for only GET & HEAD methods --- staging/src/k8s.io/apimachinery/pkg/util/proxy/upgradeaware.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/staging/src/k8s.io/apimachinery/pkg/util/proxy/upgradeaware.go b/staging/src/k8s.io/apimachinery/pkg/util/proxy/upgradeaware.go index 8ef16eeb63fcb..53e9bbae4420f 100644 --- a/staging/src/k8s.io/apimachinery/pkg/util/proxy/upgradeaware.go +++ b/staging/src/k8s.io/apimachinery/pkg/util/proxy/upgradeaware.go @@ -202,6 +202,7 @@ func (h *UpgradeAwareHandler) ServeHTTP(w http.ResponseWriter, req *http.Request loc := *h.Location loc.RawQuery = req.URL.RawQuery + method := req.Method // If original request URL ended in '/', append a '/' at the end of the // of the proxy URL @@ -213,7 +214,7 @@ func (h *UpgradeAwareHandler) ServeHTTP(w http.ResponseWriter, req *http.Request // Redirect requests with an empty path to a location that ends with a '/' // This is essentially a hack for http://issue.k8s.io/4958. // Note: Keep this code after tryUpgrade to not break that flow. - if len(loc.Path) == 0 { + if len(loc.Path) == 0 && (method == http.MethodGet || method == http.MethodHead) { var queryPart string if len(req.URL.RawQuery) > 0 { queryPart = "?" + req.URL.RawQuery