mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-05-17 13:40:22 -04:00
Split cmd package
This commit is contained in:
parent
63898c42bf
commit
de52bf14da
36 changed files with 1875 additions and 2302 deletions
|
@ -9,11 +9,8 @@ import (
|
|||
"github.com/spf13/cobra"
|
||||
"go.uber.org/multierr"
|
||||
|
||||
azure "github.com/edgelesssys/constellation/cli/azure/client"
|
||||
ec2 "github.com/edgelesssys/constellation/cli/ec2/client"
|
||||
"github.com/edgelesssys/constellation/cli/cloud/cloudcmd"
|
||||
"github.com/edgelesssys/constellation/cli/file"
|
||||
gcp "github.com/edgelesssys/constellation/cli/gcp/client"
|
||||
"github.com/edgelesssys/constellation/internal/config"
|
||||
"github.com/edgelesssys/constellation/internal/constants"
|
||||
"github.com/edgelesssys/constellation/internal/state"
|
||||
)
|
||||
|
@ -32,18 +29,12 @@ func newTerminateCmd() *cobra.Command {
|
|||
// runTerminate runs the terminate command.
|
||||
func runTerminate(cmd *cobra.Command, args []string) error {
|
||||
fileHandler := file.NewHandler(afero.NewOsFs())
|
||||
devConfigName, err := cmd.Flags().GetString("dev-config")
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
config, err := config.FromFile(fileHandler, devConfigName)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return terminate(cmd, fileHandler, config)
|
||||
terminator := cloudcmd.NewTerminator()
|
||||
|
||||
return terminate(cmd, terminator, fileHandler)
|
||||
}
|
||||
|
||||
func terminate(cmd *cobra.Command, fileHandler file.Handler, config *config.Config) error {
|
||||
func terminate(cmd *cobra.Command, terminator cloudTerminator, fileHandler file.Handler) error {
|
||||
var stat state.ConstellationState
|
||||
if err := fileHandler.ReadJSON(constants.StateFilename, &stat); err != nil {
|
||||
return err
|
||||
|
@ -51,34 +42,8 @@ func terminate(cmd *cobra.Command, fileHandler file.Handler, config *config.Conf
|
|||
|
||||
cmd.Println("Terminating ...")
|
||||
|
||||
if len(stat.EC2Instances) != 0 || stat.EC2SecurityGroup != "" {
|
||||
ec2client, err := ec2.NewFromDefault(cmd.Context())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if err := terminateEC2(cmd, ec2client, stat); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
// TODO: improve check, also look for other resources that might need to be terminated
|
||||
if len(stat.GCPNodes) != 0 {
|
||||
gcpclient, err := gcp.NewFromDefault(cmd.Context())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if err := terminateGCP(cmd, gcpclient, stat); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
if len(stat.AzureResourceGroup) != 0 {
|
||||
azureclient, err := azure.NewFromDefault(stat.AzureSubscription, stat.AzureTenant)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if err := terminateAzure(cmd, azureclient, stat); err != nil {
|
||||
return err
|
||||
}
|
||||
if err := terminator.Terminate(cmd.Context(), stat); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
cmd.Println("Your Constellation was terminated successfully.")
|
||||
|
@ -98,44 +63,3 @@ func terminate(cmd *cobra.Command, fileHandler file.Handler, config *config.Conf
|
|||
|
||||
return retErr
|
||||
}
|
||||
|
||||
func terminateAzure(cmd *cobra.Command, cl azureclient, stat state.ConstellationState) error {
|
||||
if err := cl.SetState(stat); err != nil {
|
||||
return fmt.Errorf("failed to terminate the Constellation: %w", err)
|
||||
}
|
||||
|
||||
if err := cl.TerminateServicePrincipal(cmd.Context()); err != nil {
|
||||
return err
|
||||
}
|
||||
return cl.TerminateResourceGroup(cmd.Context())
|
||||
}
|
||||
|
||||
func terminateGCP(cmd *cobra.Command, cl gcpclient, stat state.ConstellationState) error {
|
||||
if err := cl.SetState(stat); err != nil {
|
||||
return fmt.Errorf("failed to terminate the Constellation: %w", err)
|
||||
}
|
||||
|
||||
if err := cl.TerminateInstances(cmd.Context()); err != nil {
|
||||
return err
|
||||
}
|
||||
if err := cl.TerminateFirewall(cmd.Context()); err != nil {
|
||||
return err
|
||||
}
|
||||
if err := cl.TerminateVPCs(cmd.Context()); err != nil {
|
||||
return err
|
||||
}
|
||||
return cl.TerminateServiceAccount(cmd.Context())
|
||||
}
|
||||
|
||||
// terminateEC2 and remove the existing Constellation form the state file.
|
||||
func terminateEC2(cmd *cobra.Command, cl ec2client, stat state.ConstellationState) error {
|
||||
if err := cl.SetState(stat); err != nil {
|
||||
return fmt.Errorf("failed to terminate the Constellation: %w", err)
|
||||
}
|
||||
|
||||
if err := cl.TerminateInstances(cmd.Context()); err != nil {
|
||||
return fmt.Errorf("failed to terminate the Constellation: %w", err)
|
||||
}
|
||||
|
||||
return cl.DeleteSecurityGroup(cmd.Context())
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue