-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkubernetes.go
58 lines (47 loc) · 1.56 KB
/
kubernetes.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*
Package kubernetes is the km k8 package that sets up the configured k8 clientset used to communicate with the apiserver
Use CreateClient to create and verify connectivity.
It's recommended to create a new clientset after a period of inactivity
*/
package kubernetes
import (
"fmt"
"github.com/golang/glog"
cfg "github.com/BitRacer/kube-monkey/config"
"k8s.io/client-go/discovery"
kube "k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
)
// CreateClient creates, verifies and returns an instance of k8 clientset
func CreateClient() (*kube.Clientset, error) {
client, err := NewInClusterClient()
if err != nil {
return nil, fmt.Errorf("Failed to generate NewInClusterClient: %v", err)
}
if VerifyClient(client) {
return client, nil
}
return nil, fmt.Errorf("Unable to verify client connectivity to Kubernetes apiserver")
}
// NewInClusterClient only creates an initialized instance of k8 clientset
func NewInClusterClient() (*kube.Clientset, error) {
config, err := rest.InClusterConfig()
if err != nil {
glog.Errorf("failed to obtain config from InClusterConfig: %v", err)
return nil, err
}
if apiserverHost, override := cfg.ClusterAPIServerHost(); override {
glog.V(5).Infof("API server host overridden to: %s\n", apiserverHost)
config.Host = apiserverHost
}
clientset, err := kube.NewForConfig(config)
if err != nil {
glog.Errorf("failed to create clientset in NewForConfig: %v", err)
return nil, err
}
return clientset, nil
}
func VerifyClient(client discovery.DiscoveryInterface) bool {
_, err := client.ServerVersion()
return err == nil
}