databricks-cli/bundle/phases/destroy.go

60 lines
1.4 KiB
Go
Raw Normal View History

package phases
import (
"context"
"errors"
"net/http"
"github.com/databricks/cli/bundle"
"github.com/databricks/cli/bundle/deploy/files"
"github.com/databricks/cli/bundle/deploy/lock"
"github.com/databricks/cli/bundle/deploy/terraform"
"github.com/databricks/cli/libs/log"
"github.com/databricks/databricks-sdk-go/apierr"
)
func assertRootPathExists(ctx context.Context, b *bundle.Bundle) (bool, error) {
w := b.WorkspaceClient()
_, err := w.Workspace.GetStatusByPath(ctx, b.Config.Workspace.RootPath)
var aerr *apierr.APIError
if errors.As(err, &aerr) && aerr.StatusCode == http.StatusNotFound {
log.Infof(ctx, "Root path does not exist: %s", b.Config.Workspace.RootPath)
return false, nil
}
return true, err
}
// The destroy phase deletes artifacts and resources.
func Destroy() bundle.Mutator {
destroyMutator := bundle.Seq(
2023-05-16 16:01:50 +00:00
lock.Acquire(),
bundle.Defer(
bundle.Seq(
terraform.StatePull(),
terraform.Interpolate(),
terraform.Write(),
terraform.Plan(terraform.PlanGoal("destroy")),
terraform.Destroy(),
terraform.StatePush(),
files.Delete(),
),
lock.Release(lock.GoalDestroy),
),
bundle.LogString("Destroy complete!"),
)
2023-05-16 16:01:50 +00:00
return newPhase(
"destroy",
[]bundle.Mutator{
// Only run deploy mutator if root path exists.
bundle.If(
assertRootPathExists,
destroyMutator,
bundle.LogString("No active deployment found to destroy!"),
),
},
)
}