Files
PandaX/apps/devops/services/k8s/daemonset/daemonset_detail.go
2022-01-26 14:13:23 +08:00

58 lines
1.8 KiB
Go

package daemonset
import (
"context"
"fmt"
"pandax/base/global"
metaV1 "k8s.io/apimachinery/pkg/apis/meta/v1"
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
k8scommon "pandax/apps/devops/services/k8s/common"
"pandax/apps/devops/services/k8s/service"
)
// DaemonSetDetail represents detailed information about a Daemon Set.
type DaemonSetDetail struct {
// Extends list item structure.
DaemonSet `json:",inline"`
LabelSelector *v1.LabelSelector `json:"labelSelector,omitempty"`
PodList *PodList `json:"podList"`
SvcList *service.ServiceList `json:"svcList"`
}
// GetDaemonSetDetail Returns detailed information about the given daemon set in the given namespace.
func GetDaemonSetDetail(client *kubernetes.Clientset, namespace, name string) (*DaemonSetDetail, error) {
global.Log.Info(fmt.Sprintf("Getting details of %s daemon set in %s namespace", name, namespace))
daemonSet, err := client.AppsV1().DaemonSets(namespace).Get(context.TODO(), name, metaV1.GetOptions{})
if err != nil {
return nil, err
}
channels := &k8scommon.ResourceChannels{
EventList: k8scommon.GetEventListChannel(client, k8scommon.NewSameNamespaceQuery(namespace), 1),
PodList: k8scommon.GetPodListChannel(client, k8scommon.NewSameNamespaceQuery(namespace), 1),
}
eventList := <-channels.EventList.List
if err := <-channels.EventList.Error; err != nil {
return nil, err
}
podList := <-channels.PodList.List
if err := <-channels.PodList.Error; err != nil {
return nil, err
}
serviceList, _ := service.GetToService(client, namespace, name)
return &DaemonSetDetail{
DaemonSet: toDaemonSet(*daemonSet, podList.Items, eventList.Items),
LabelSelector: daemonSet.Spec.Selector,
PodList: getDaemonSetToPod(client, *daemonSet),
SvcList: serviceList,
}, nil
}