diff options
author | Ritu Sood <ritu.sood@intel.com> | 2018-11-10 09:56:52 -0800 |
---|---|---|
committer | Victor Morales <victor.morales@intel.com> | 2018-11-20 01:50:58 -0800 |
commit | 5026d1d89b05eac5e004279b742df6745a73d93a (patch) | |
tree | 8f9aed1e476706e008b746debda6d616bd0ac7a5 /internal/pkg/kube | |
parent | 9506ae48eb545d502cc3685a99862740d28e7afb (diff) |
Seed code for the Plugin
The code includes ovn4nfvk8s Plugin & CNI. It implements multiple OVN
interfaces for Pods and assumes Multus (or similar CNI) calls its CNI
not as first CNI.
Change-Id: I524c1d18752eb6dbc8d34addd3b60d5bbaa06ff4
Signed-off-by: Ritu Sood <ritu.sood@intel.com>
Signed-off-by: Victor Morales <victor.morales@intel.com>
Diffstat (limited to 'internal/pkg/kube')
-rw-r--r-- | internal/pkg/kube/.gitkeep | 0 | ||||
-rw-r--r-- | internal/pkg/kube/kube.go | 141 |
2 files changed, 141 insertions, 0 deletions
diff --git a/internal/pkg/kube/.gitkeep b/internal/pkg/kube/.gitkeep deleted file mode 100644 index e69de29..0000000 --- a/internal/pkg/kube/.gitkeep +++ /dev/null diff --git a/internal/pkg/kube/kube.go b/internal/pkg/kube/kube.go new file mode 100644 index 0000000..cc7c29b --- /dev/null +++ b/internal/pkg/kube/kube.go @@ -0,0 +1,141 @@ +package kube + +import ( + "fmt" + + "github.com/sirupsen/logrus" + + kapi "k8s.io/api/core/v1" + kapisnetworking "k8s.io/api/networking/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/labels" + "k8s.io/apimachinery/pkg/types" + "k8s.io/client-go/kubernetes" +) + +// Interface represents the exported methods for dealing with getting/setting +// kubernetes resources +type Interface interface { + SetAnnotationOnPod(pod *kapi.Pod, key, value string) error + SetAnnotationOnNode(node *kapi.Node, key, value string) error + SetAnnotationOnNamespace(ns *kapi.Namespace, key, value string) error + GetAnnotationsOnPod(namespace, name string) (map[string]string, error) + GetPod(namespace, name string) (*kapi.Pod, error) + GetPods(namespace string) (*kapi.PodList, error) + GetPodsByLabels(namespace string, selector labels.Selector) (*kapi.PodList, error) + GetNodes() (*kapi.NodeList, error) + GetNode(name string) (*kapi.Node, error) + GetService(namespace, name string) (*kapi.Service, error) + GetEndpoints(namespace string) (*kapi.EndpointsList, error) + GetNamespace(name string) (*kapi.Namespace, error) + GetNamespaces() (*kapi.NamespaceList, error) + GetNetworkPolicies(namespace string) (*kapisnetworking.NetworkPolicyList, error) +} + +// Kube is the structure object upon which the Interface is implemented +type Kube struct { + KClient kubernetes.Interface +} + +// SetAnnotationOnPod takes the pod object and key/value string pair to set it as an annotation +func (k *Kube) SetAnnotationOnPod(pod *kapi.Pod, key, value string) error { + logrus.Infof("Setting annotations %s=%s on pod %s", key, value, pod.Name) + patchData := fmt.Sprintf(`{"metadata":{"annotations":{"%s":"%s"}}}`, key, value) + _, err := k.KClient.Core().Pods(pod.Namespace).Patch(pod.Name, types.MergePatchType, []byte(patchData)) + if err != nil { + logrus.Errorf("Error in setting annotation on pod %s/%s: %v", pod.Name, pod.Namespace, err) + } + return err +} + +// SetAnnotationOnNode takes the node object and key/value string pair to set it as an annotation +func (k *Kube) SetAnnotationOnNode(node *kapi.Node, key, value string) error { + logrus.Infof("Setting annotations %s=%s on node %s", key, value, node.Name) + patchData := fmt.Sprintf(`{"metadata":{"annotations":{"%s":"%s"}}}`, key, value) + _, err := k.KClient.Core().Nodes().Patch(node.Name, types.MergePatchType, []byte(patchData)) + if err != nil { + logrus.Errorf("Error in setting annotation on node %s: %v", node.Name, err) + } + return err +} + +// SetAnnotationOnNamespace takes the Namespace object and key/value pair +// to set it as an annotation +func (k *Kube) SetAnnotationOnNamespace(ns *kapi.Namespace, key, + value string) error { + logrus.Infof("Setting annotations %s=%s on namespace %s", key, value, + ns.Name) + patchData := fmt.Sprintf(`{"metadata":{"annotations":{"%s":"%s"}}}`, key, + value) + _, err := k.KClient.Core().Namespaces().Patch(ns.Name, + types.MergePatchType, []byte(patchData)) + if err != nil { + logrus.Errorf("Error in setting annotation on namespace %s: %v", + ns.Name, err) + } + return err +} + +// GetAnnotationsOnPod obtains the pod annotations from kubernetes apiserver, given the name and namespace +func (k *Kube) GetAnnotationsOnPod(namespace, name string) (map[string]string, error) { + pod, err := k.KClient.Core().Pods(namespace).Get(name, metav1.GetOptions{}) + if err != nil { + return nil, err + } + return pod.ObjectMeta.Annotations, nil +} + +// GetPod obtains the Pod resource from kubernetes apiserver, given the name and namespace +func (k *Kube) GetPod(namespace, name string) (*kapi.Pod, error) { + return k.KClient.Core().Pods(namespace).Get(name, metav1.GetOptions{}) +} + +// GetPods obtains the Pod resource from kubernetes apiserver, given the name and namespace +func (k *Kube) GetPods(namespace string) (*kapi.PodList, error) { + return k.KClient.Core().Pods(namespace).List(metav1.ListOptions{}) +} + +// GetPodsByLabels obtains the Pod resources from kubernetes apiserver, +// given the namespace and label +func (k *Kube) GetPodsByLabels(namespace string, selector labels.Selector) (*kapi.PodList, error) { + options := metav1.ListOptions{} + options.LabelSelector = selector.String() + return k.KClient.Core().Pods(namespace).List(options) +} + +// GetNodes returns the list of all Node objects from kubernetes +func (k *Kube) GetNodes() (*kapi.NodeList, error) { + return k.KClient.Core().Nodes().List(metav1.ListOptions{}) +} + +// GetNode returns the Node resource from kubernetes apiserver, given its name +func (k *Kube) GetNode(name string) (*kapi.Node, error) { + return k.KClient.Core().Nodes().Get(name, metav1.GetOptions{}) +} + +// GetService returns the Service resource from kubernetes apiserver, given its name and namespace +func (k *Kube) GetService(namespace, name string) (*kapi.Service, error) { + return k.KClient.Core().Services(namespace).Get(name, metav1.GetOptions{}) +} + +// GetEndpoints returns all the Endpoint resources from kubernetes +// apiserver, given namespace +func (k *Kube) GetEndpoints(namespace string) (*kapi.EndpointsList, error) { + return k.KClient.Core().Endpoints(namespace).List(metav1.ListOptions{}) +} + +// GetNamespace returns the Namespace resource from kubernetes apiserver, +// given its name +func (k *Kube) GetNamespace(name string) (*kapi.Namespace, error) { + return k.KClient.Core().Namespaces().Get(name, metav1.GetOptions{}) +} + +// GetNamespaces returns all Namespace resource from kubernetes apiserver +func (k *Kube) GetNamespaces() (*kapi.NamespaceList, error) { + return k.KClient.Core().Namespaces().List(metav1.ListOptions{}) +} + +// GetNetworkPolicies returns all network policy objects from kubernetes +func (k *Kube) GetNetworkPolicies(namespace string) (*kapisnetworking.NetworkPolicyList, error) { + return k.KClient.Networking().NetworkPolicies(namespace).List(metav1.ListOptions{}) +} |