fix: better context handling and less unexpected deleting #262
|
@ -15,35 +15,43 @@ import (
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Volumes stores the variable from VolumesFlag
|
|
||||||
var Volumes bool
|
|
||||||
|
|
||||||
// VolumesFlag is used to specify if volumes should be deleted when deleting an app
|
|
||||||
var VolumesFlag = &cli.BoolFlag{
|
|
||||||
Name: "volumes, V",
|
|
||||||
Destination: &Volumes,
|
|
||||||
}
|
|
||||||
|
|
||||||
var appRemoveCommand = cli.Command{
|
var appRemoveCommand = cli.Command{
|
||||||
Name: "remove",
|
Name: "remove",
|
||||||
Aliases: []string{"rm"},
|
Aliases: []string{"rm"},
|
||||||
ArgsUsage: "<domain>",
|
ArgsUsage: "<domain>",
|
||||||
Usage: "Remove an already undeployed app",
|
Usage: "Remove all app data, locally and remotely",
|
||||||
|
Description: `
|
||||||
|
This command removes everything related to an app which is already undeployed.
|
||||||
|
|
||||||
|
By default, it will prompt for confirmation before proceeding. All secrets,
|
||||||
|
volumes and the local app env file will be deleted.
|
||||||
|
|
||||||
|
Only run this command when you are sure you want to completely remove the app
|
||||||
|
and all associated app data. This is a destructive action, Be Careful!
|
||||||
|
|
||||||
|
If you would like to delete specific volumes or secrets, please use removal
|
||||||
|
sub-commands under "app volume" and "app secret" instead.
|
||||||
|
|
||||||
|
Please note, if you delete the local app env file without removing volumes and
|
||||||
|
secrets first, Abra will *not* be able to help you remove them afterwards.
|
||||||
|
|
||||||
|
To delete everything without prompt, use the "--force/-f" or the "--no-input/n"
|
||||||
|
flag.
|
||||||
|
`,
|
||||||
Flags: []cli.Flag{
|
Flags: []cli.Flag{
|
||||||
VolumesFlag,
|
|
||||||
internal.ForceFlag,
|
internal.ForceFlag,
|
||||||
internal.DebugFlag,
|
internal.DebugFlag,
|
||||||
internal.NoInputFlag,
|
internal.NoInputFlag,
|
||||||
},
|
},
|
||||||
Before: internal.SubCommandBefore,
|
BashComplete: autocomplete.AppNameComplete,
|
||||||
|
Before: internal.SubCommandBefore,
|
||||||
Action: func(c *cli.Context) error {
|
Action: func(c *cli.Context) error {
|
||||||
app := internal.ValidateApp(c)
|
app := internal.ValidateApp(c)
|
||||||
|
|
||||||
if !internal.Force && !internal.NoInput {
|
if !internal.Force && !internal.NoInput {
|
||||||
response := false
|
response := false
|
||||||
prompt := &survey.Confirm{
|
msg := "ALERTA ALERTA: this will completely remove %s data and configurations locally and remotely, are you sure?"
|
||||||
Message: fmt.Sprintf("about to remove %s, are you sure?", app.Name),
|
prompt := &survey.Confirm{Message: fmt.Sprintf(msg, app.Name)}
|
||||||
}
|
|
||||||
if err := survey.AskOne(prompt, &response); err != nil {
|
if err := survey.AskOne(prompt, &response); err != nil {
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -84,26 +92,7 @@ var appRemoveCommand = cli.Command{
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(secrets) > 0 {
|
if len(secrets) > 0 {
|
||||||
var secretNamesToRemove []string
|
for _, name := range secretNames {
|
||||||
|
|
||||||
if !internal.Force && !internal.NoInput {
|
|
||||||
secretsPrompt := &survey.MultiSelect{
|
|
||||||
Message: "which secrets do you want to remove?",
|
|
||||||
Help: "'x' indicates selected, enter / return to confirm, ctrl-c to exit, vim mode is enabled",
|
|
||||||
VimMode: true,
|
|
||||||
Options: secretNames,
|
|
||||||
Default: secretNames,
|
|
||||||
}
|
|
||||||
if err := survey.AskOne(secretsPrompt, &secretNamesToRemove); err != nil {
|
|
||||||
logrus.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if internal.Force || internal.NoInput {
|
|
||||||
secretNamesToRemove = secretNames
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, name := range secretNamesToRemove {
|
|
||||||
err := cl.SecretRemove(context.Background(), secrets[name])
|
err := cl.SecretRemove(context.Background(), secrets[name])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
|
@ -131,44 +120,24 @@ var appRemoveCommand = cli.Command{
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(vols) > 0 {
|
if len(vols) > 0 {
|
||||||
if Volumes {
|
var removeVols []string
|
||||||
var removeVols []string
|
for _, vol := range removeVols {
|
||||||
if !internal.Force && !internal.NoInput {
|
err := cl.VolumeRemove(context.Background(), vol, internal.Force) // last argument is for force removing
|
||||||
volumesPrompt := &survey.MultiSelect{
|
if err != nil {
|
||||||
Message: "which volumes do you want to remove?",
|
logrus.Fatal(err)
|
||||||
Help: "'x' indicates selected, enter / return to confirm, ctrl-c to exit, vim mode is enabled",
|
|
||||||
VimMode: true,
|
|
||||||
Options: vols,
|
|
||||||
Default: vols,
|
|
||||||
}
|
|
||||||
if err := survey.AskOne(volumesPrompt, &removeVols); err != nil {
|
|
||||||
logrus.Fatal(err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
logrus.Info(fmt.Sprintf("volume %s removed", vol))
|
||||||
for _, vol := range removeVols {
|
|
||||||
err := cl.VolumeRemove(context.Background(), vol, internal.Force) // last argument is for force removing
|
|
||||||
if err != nil {
|
|
||||||
logrus.Fatal(err)
|
|
||||||
}
|
|
||||||
logrus.Info(fmt.Sprintf("volume %s removed", vol))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
logrus.Info("no volumes were removed")
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if Volumes {
|
logrus.Info("no volumes to remove")
|
||||||
logrus.Info("no volumes to remove")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = os.Remove(app.Path)
|
if err = os.Remove(app.Path); err != nil {
|
||||||
if err != nil {
|
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
logrus.Info(fmt.Sprintf("file: %s removed", app.Path))
|
logrus.Info(fmt.Sprintf("file: %s removed", app.Path))
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
BashComplete: autocomplete.AppNameComplete,
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue