ef36c28eedd9b745f3e89735e2da2e00193fb446
[ric-plt/e2mgr.git] / E2Manager / managers / kubernetes_manager.go
1 //
2 // Copyright 2019 AT&T Intellectual Property
3 // Copyright 2019 Nokia
4 //
5 // Licensed under the Apache License, Version 2.0 (the "License");
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 //      http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17
18 //  This source code is part of the near-RT RIC (RAN Intelligent Controller)
19 //  platform project (RICP).
20
21 package managers
22
23 import (
24         "e2mgr/configuration"
25         "e2mgr/logger"
26         "k8s.io/client-go/kubernetes"
27 )
28
29 type KubernetesManager struct {
30         Logger    *logger.Logger
31         ClientSet kubernetes.Interface
32         Config    *configuration.Configuration
33 }
34
35 func NewKubernetesManager(logger *logger.Logger, config *configuration.Configuration) *KubernetesManager {
36         return &KubernetesManager{
37                 Logger:    logger,
38         //      ClientSet: createClientSet(logger, config),
39                 Config:    config,
40         }
41 }
42
43 /*func (km KubernetesManager) GetAndDeletePod(namespace string, podName string) {
44         km.logger.Infof("#KubernetesManager.GetAndDeletePod - namespace: %s, POD name: %s ", namespace, podName)
45
46         config, err := clientcmd.BuildConfigFromFlags("", "kubeConfigPath")
47         if err != nil {
48                 log.Fatal(err)
49         }
50
51         clientSet, _ := kubernetesManager.NewForConfig(config)
52
53         podInterface := km.GetPodInterface(clientSet.CoreV1(), namespace, podName)
54
55         if podInterface == nil{
56                 return
57         }
58
59         km.DeletePod(podInterface, podName)
60 }*/
61
62 /*func createClientSet(logger *logger.Logger, config *configuration.Configuration) kubernetes.Interface {
63         ////path := os.Getenv("HOME") + "/.kube/config"
64
65         absConfigPath,err := filepath.Abs(config.Kubernetes.ConfigPath)
66         if err != nil {
67                 logger.Errorf("#KubernetesManager.init - error: %s", err)
68                 return nil
69         }
70
71         kubernetesConfig, err := clientcmd.BuildConfigFromFlags("", absConfigPath)
72         if err != nil {
73                 logger.Errorf("#KubernetesManager.init - error: %s", err)
74                 return nil
75         }
76
77         clientSet, err := kubernetes.NewForConfig(kubernetesConfig)
78         if err != nil {
79                 logger.Errorf("#KubernetesManager.init - error: %s", err)
80                 return nil
81         }
82         return clientSet
83 }*/
84
85 /*func (km KubernetesManager) DeletePod(podInterface v1.PodInterface, podName string) {
86         km.logger.Infof("#KubernetesManager.DeletePod - POD name %s ", podName)
87
88         err := podInterface.Delete(podName, &metaV1.DeleteOptions{})
89
90         if err != nil{
91                 km.logger.Warnf("#KubernetesManager.DeletePod - POD %s can't be deleted", podName)
92                 return
93         }
94         km.logger.Infof("#KubernetesManager.DeletePod - POD %s was deleted", podName)
95 }
96 */
97 func (km KubernetesManager) DeletePod(podName string) error {
98 /*      km.Logger.Infof("#KubernetesManager.DeletePod - POD name: %s ", podName)
99
100         if km.ClientSet == nil {
101                 km.Logger.Errorf("#KubernetesManager.DeletePod - no kubernetesManager connection")
102                 return e2managererrors.NewInternalError()
103         }
104
105         if len(podName) == 0 {
106                 km.Logger.Warnf("#KubernetesManager.DeletePod - empty pod name")
107                 return e2managererrors.NewInternalError()
108         }
109
110         err := km.ClientSet.CoreV1().Pods(km.Config.Kubernetes.Namespace).Delete(podName, &metaV1.DeleteOptions{})
111
112         if err != nil {
113                 km.Logger.Errorf("#KubernetesManager.DeletePod - POD %s can't be deleted, error: %s", podName, err)
114                 return err
115         }
116
117         km.Logger.Infof("#KubernetesManager.DeletePod - POD %s was deleted", podName)*/
118         return nil
119 }
120
121 /*func (km KubernetesManager) GetPodInterface(client v1.CoreV1Interface, namespace string, podName string) v1.PodInterface{
122         km.logger.Infof("#KubernetesManager.GetPodInterface - namespace: %s, POD name: %s ", namespace, podName)
123
124
125         podInterface := client.Pods(namespace)
126         pod, err := podInterface.Get(podName, metaV1.GetOptions{})
127
128         if err != nil{
129                 km.logger.Warnf("#KubernetesManager.GetPodInterface - POD name: %s not found", podName)
130                 return nil
131         }
132
133         km.logger.Infof("#KubernetesManager.GetPodInterface - POD status: %s ", pod.Status.String())
134
135         return podInterface
136 }*/