Skip to content

Commit

Permalink
add list of CRs that are installed on cluster
Browse files Browse the repository at this point in the history
add roles, rolebindings, replicasets
  • Loading branch information
lynnemorrison committed Dec 23, 2024
1 parent f240ddc commit 51c9771
Showing 1 changed file with 72 additions and 12 deletions.
84 changes: 72 additions & 12 deletions internal/cmd/skupper/debug/kube/debug.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,16 @@ import (
"path/filepath"
"time"

"sigs.k8s.io/yaml"

"github.com/skupperproject/skupper/internal/cmd/skupper/common"
"github.com/skupperproject/skupper/internal/kube/client"
skupperv2alpha1 "github.com/skupperproject/skupper/pkg/generated/client/clientset/versioned/typed/skupper/v2alpha1"
kube "github.com/skupperproject/skupper/pkg/kube"
"github.com/skupperproject/skupper/pkg/utils/validator"
"github.com/spf13/cobra"
v1 "k8s.io/api/core/v1"
crdClient "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
Expand All @@ -37,6 +40,7 @@ type CmdDebug struct {
Namespace string
fileName string
Rest *restclient.Config
crdClient *crdClient.Clientset
}

func NewCmdDebug() *CmdDebug {
Expand Down Expand Up @@ -72,6 +76,11 @@ func (cmd *CmdDebug) NewClient(cobraCommand *cobra.Command, args []string) {
restconfig.APIPath = "/api"
restconfig.NegotiatedSerializer = serializer.WithoutConversionCodecFactory{CodecFactory: scheme.Codecs}
cmd.Rest = restconfig

cmd.crdClient, err = crdClient.NewForConfig(cmd.Rest)
if err != nil {
return
}
}
}

Expand Down Expand Up @@ -146,12 +155,36 @@ func (cmd *CmdDebug) Run() error {
if site != nil && err == nil {
path := "/site-namespace/"

events, err := runCommand("kubectl", "events")
if err == nil {
writeTar(path+"events.txt", events, time.Now(), tw)
}

endpoints, err := runCommand("kubectl", "get", "endpoints", "-o", "yaml")
if err == nil {
writeTar(path+"endpoints.yaml", endpoints, time.Now(), tw)
}

path = path + "resources/"
err = getDeployments(cmd, path, "skupper-router", tw)
if err != nil {
return err
}

path = path + "resources/"
// List all the existing installed CRs in the cluster
crdList, err := cmd.crdClient.ApiextensionsV1().CustomResourceDefinitions().List(context.TODO(), metav1.ListOptions{})
if err == nil {
var encodedOutput []byte
var crds []string
for _, crd := range crdList.Items {
crds = append(crds, crd.Name)
}
encodedOutput, err = yaml.Marshal(crds)
if err == nil {
writeTar(path+"crds.yaml", encodedOutput, time.Now(), tw)
}
}

for i := range configMaps {
cm, err := cmd.KubeClient.CoreV1().ConfigMaps(cmd.Namespace).Get(context.TODO(), configMaps[i], metav1.GetOptions{})
if err == nil {
Expand Down Expand Up @@ -299,12 +332,22 @@ func (cmd *CmdDebug) Run() error {
if controller != nil && err == nil {
path := "/controller-namespace/"

events, err := runCommand("kubectl", "events")
if err == nil {
writeTar(path+"events.txt", events, time.Now(), tw)
}

endpoints, err := runCommand("kubectl", "get", "endpoints", "-o", "yaml")
if err == nil {
writeTar(path+"endpoints.yaml", endpoints, time.Now(), tw)
}

path = path + "resources/"
err = getDeployments(cmd, path, "skupper-controller", tw)
if err != nil {
return err
}

path = path + "resources/"
for i := range controllerServices {
service, err := cmd.KubeClient.CoreV1().Services(cmd.Namespace).Get(context.TODO(), controllerServices[i], metav1.GetOptions{})
if err == nil {
Expand Down Expand Up @@ -380,17 +423,7 @@ func getDeployments(cmd *CmdDebug, path string, deploymentType string, tw *tar.W
deployments = controllerDeployments
labelSelector = "application="
}
events, err := runCommand("kubectl", "events")
if err == nil {
writeTar(path+"events.txt", events, time.Now(), tw)
}

endpoints, err := runCommand("kubectl", "get", "endpoints", "-o", "yaml")
if err == nil {
writeTar(path+"endpoints.yaml", endpoints, time.Now(), tw)
}

path = path + "resources/"
for i := range deployments {
deployment, err := cmd.KubeClient.AppsV1().Deployments(cmd.Namespace).Get(context.TODO(), deployments[i], metav1.GetOptions{})
if err != nil {
Expand Down Expand Up @@ -448,6 +481,33 @@ func getDeployments(cmd *CmdDebug, path string, deploymentType string, tw *tar.W
}
}
}

role, err := cmd.KubeClient.RbacV1().Roles(cmd.Namespace).Get(context.TODO(), deployments[i], metav1.GetOptions{})
if err == nil && role != nil {
err = writeObject(role, path+"Role-"+deployment.Name, ".yaml", tw)
if err != nil {
return err
}
}

roleBinding, err := cmd.KubeClient.RbacV1().RoleBindings(cmd.Namespace).Get(context.TODO(), deployments[i], metav1.GetOptions{})
if err == nil && roleBinding != nil {
err = writeObject(roleBinding, path+"RoleBinding-"+deployment.Name, ".yaml", tw)
if err != nil {
return err
}
}

replicaSetList, err := cmd.KubeClient.AppsV1().ReplicaSets(cmd.Namespace).List(context.TODO(), metav1.ListOptions{LabelSelector: labelSelector + deployments[i]})
if err == nil && replicaSetList != nil {
for _, replicaSet := range replicaSetList.Items {
r := replicaSet.DeepCopy()
err = writeObject(r, path+"ReplicaSet-"+replicaSet.Name, ".yaml", tw)
if err != nil {
return err
}
}
}
}
return nil
}
Expand Down

0 comments on commit 51c9771

Please sign in to comment.