package bundle import ( "fmt" "os" "github.com/databricks/bricks/bundle" "github.com/databricks/bricks/bundle/phases" "github.com/databricks/bricks/cmd/root" "github.com/databricks/bricks/libs/cmdio" "github.com/databricks/bricks/libs/flags" "github.com/spf13/cobra" "golang.org/x/term" ) // TODO: note possibility of aliases var destroyCmd = &cobra.Command{ Use: "destroy", Short: "Destroy deployed bundle resources", PreRunE: root.MustConfigureBundle, RunE: func(cmd *cobra.Command, args []string) error { ctx := cmd.Context() b := bundle.Get(ctx) // If `--force` is specified, force acquisition of the deployment lock. b.Config.Bundle.Lock.Force = force // If `--auto-approve`` is specified, we skip confirmation checks b.AutoApprove = autoApprove // we require auto-approve for non tty terminals since interactive consent // is not possible if !term.IsTerminal(int(os.Stderr.Fd())) && !autoApprove { return fmt.Errorf("please specify --auto-approve to skip interactive confirmation checks for non tty consoles") } // Check auto-approve is selected for json logging logger, ok := cmdio.FromContext(ctx) if !ok { return fmt.Errorf("progress logger not found") } if logger.Mode == flags.ModeJson && !autoApprove { return fmt.Errorf("please specify --auto-approve since selected logging format is json") } return bundle.Apply(ctx, b, []bundle.Mutator{ phases.Initialize(), phases.Build(), phases.Destroy(), }) }, } func init() { AddCommand(destroyCmd) destroyCmd.Flags().BoolVar(&autoApprove, "auto-approve", false, "Skip interactive approvals") destroyCmd.Flags().BoolVar(&force, "force", false, "Force acquisition of deployment lock.") }