From a13458fad500ac33fbd2610ea74bc55c911039ba Mon Sep 17 00:00:00 2001 From: LiHui Date: Tue, 24 May 2022 21:59:34 +0800 Subject: [PATCH] Fix: painc when kubeconfig set filed insecure-skip-tls-verify --- pkg/controller/util/cluster_util.go | 41 ++++++++++++++++------------- 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/pkg/controller/util/cluster_util.go b/pkg/controller/util/cluster_util.go index 4bf79ae857..cf42bba6f4 100644 --- a/pkg/controller/util/cluster_util.go +++ b/pkg/controller/util/cluster_util.go @@ -124,26 +124,31 @@ func CustomizeTLSTransport(fedCluster *fedv1b1.KubeFedCluster, clientConfig *res return errors.Errorf("Cluster %s transport error: %s", fedCluster.Name, err) } - err = CustomizeCertificateValidation(fedCluster, transportConfig) - if err != nil { - return errors.Errorf("Cluster %s custom certificate validation error: %s", fedCluster.Name, err) - } + if transportConfig != nil { + err = CustomizeCertificateValidation(fedCluster, transportConfig) + if err != nil { + return errors.Errorf("Cluster %s custom certificate validation error: %s", fedCluster.Name, err) + } - // using the same defaults as http.DefaultTransport - clientConfig.Transport = &http.Transport{ - Proxy: http.ProxyFromEnvironment, - DialContext: (&net.Dialer{ - Timeout: 30 * time.Second, - KeepAlive: 30 * time.Second, - DualStack: true, - }).DialContext, - MaxIdleConns: 100, - IdleConnTimeout: 90 * time.Second, - TLSHandshakeTimeout: 10 * time.Second, - ExpectContinueTimeout: 1 * time.Second, - TLSClientConfig: transportConfig, + // using the same defaults as http.DefaultTransport + clientConfig.Transport = &http.Transport{ + Proxy: http.ProxyFromEnvironment, + DialContext: (&net.Dialer{ + Timeout: 30 * time.Second, + KeepAlive: 30 * time.Second, + DualStack: true, + }).DialContext, + MaxIdleConns: 100, + IdleConnTimeout: 90 * time.Second, + TLSHandshakeTimeout: 10 * time.Second, + ExpectContinueTimeout: 1 * time.Second, + TLSClientConfig: transportConfig, + } + clientConfig.TLSClientConfig = restclient.TLSClientConfig{} + } else { + clientConfig.Insecure = true } - clientConfig.TLSClientConfig = restclient.TLSClientConfig{} + return nil }