From 52b2bad186f810d8c80db29ad7031eddb48f6a93 Mon Sep 17 00:00:00 2001 From: Kartik-Garg Date: Thu, 13 Apr 2023 18:48:23 +0530 Subject: [PATCH] CLI now cleans up etcd pvc volume when using k8s or eks distros Now CLI can clean up etcd pvc volumes when using k8s and eks distros as well. Signed-off-by: Kartik-Garg --- cmd/vclusterctl/cmd/delete.go | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/cmd/vclusterctl/cmd/delete.go b/cmd/vclusterctl/cmd/delete.go index f9fd448c1..2f258ef3e 100644 --- a/cmd/vclusterctl/cmd/delete.go +++ b/cmd/vclusterctl/cmd/delete.go @@ -3,9 +3,10 @@ package cmd import ( "context" "fmt" - "github.com/loft-sh/vcluster/pkg/util/translate" "os/exec" + "github.com/loft-sh/vcluster/pkg/util/translate" + "github.com/loft-sh/vcluster/cmd/vclusterctl/cmd/app/localkubernetes" "github.com/loft-sh/vcluster/cmd/vclusterctl/cmd/find" "k8s.io/client-go/rest" @@ -114,6 +115,8 @@ func (cmd *DeleteCmd) Run(cobraCmd *cobra.Command, args []string) error { // try to delete the pvc if !cmd.KeepPVC && !cmd.DeleteNamespace { pvcName := fmt.Sprintf("data-%s-0", args[0]) + pvcNameForK8sAndEks := fmt.Sprintf("data-%s-etcd-0", args[0]) + client, err := kubernetes.NewForConfig(cmd.restConfig) if err != nil { return err @@ -127,6 +130,16 @@ func (cmd *DeleteCmd) Run(cobraCmd *cobra.Command, args []string) error { } else { cmd.log.Donef("Successfully deleted virtual cluster pvc %s in namespace %s", pvcName, cmd.Namespace) } + + // Deleting PVC for K8s and eks distro as well. + err = client.CoreV1().PersistentVolumeClaims(cmd.Namespace).Delete(context.Background(), pvcNameForK8sAndEks, metav1.DeleteOptions{}) + if err != nil { + if !kerrors.IsNotFound(err) { + return errors.Wrap(err, "delete pvc") + } + } else { + cmd.log.Donef("Successfully deleted virtual cluster pvc %s in namespace %s", pvcName, cmd.Namespace) + } } // check if there are any other vclusters in the namespace you are deleting vcluster in.