1
0
mirror of https://github.com/rancher/rke.git synced 2025-04-27 11:21:08 +00:00
rke/k8s/k8s.go
2020-10-20 14:36:09 +01:00

76 lines
1.9 KiB
Go

package k8s
import (
"bytes"
"time"
"k8s.io/client-go/transport"
yamlutil "k8s.io/apimachinery/pkg/util/yaml"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/clientcmd"
)
const (
DefaultRetries = 5
DefaultSleepSeconds = 5
DefaultTimeout = 45
K8sWrapTransportTimeout = 30
)
type k8sCall func(*kubernetes.Clientset, interface{}) error
func NewClient(kubeConfigPath string, k8sWrapTransport transport.WrapperFunc) (*kubernetes.Clientset, error) {
// use the current admin kubeconfig
config, err := clientcmd.BuildConfigFromFlags("", kubeConfigPath)
if err != nil {
return nil, err
}
if k8sWrapTransport != nil {
config.WrapTransport = k8sWrapTransport
}
config.Timeout = time.Second * time.Duration(K8sWrapTransportTimeout)
K8sClientSet, err := kubernetes.NewForConfig(config)
if err != nil {
return nil, err
}
return K8sClientSet, nil
}
func DecodeYamlResource(resource interface{}, yamlManifest string) error {
decoder := yamlutil.NewYAMLToJSONDecoder(bytes.NewReader([]byte(yamlManifest)))
return decoder.Decode(&resource)
}
func retryToWithTimeout(runFunc k8sCall, k8sClient *kubernetes.Clientset, resource interface{}, timeout int) error {
var err error
timePassed := 0
for timePassed < timeout {
if err = runFunc(k8sClient, resource); err != nil {
time.Sleep(time.Second * time.Duration(DefaultSleepSeconds))
timePassed += DefaultSleepSeconds
continue
}
return nil
}
return err
}
func retryTo(runFunc k8sCall, k8sClient *kubernetes.Clientset, resource interface{}, retries, sleepSeconds int) error {
var err error
if retries == 0 {
retries = DefaultRetries
}
if sleepSeconds == 0 {
sleepSeconds = DefaultSleepSeconds
}
for i := 0; i < retries; i++ {
if err = runFunc(k8sClient, resource); err != nil {
time.Sleep(time.Second * time.Duration(sleepSeconds))
continue
}
return nil
}
return err
}