mirror of https://github.com/databricks/cli.git
68 lines
2.3 KiB
Go
68 lines
2.3 KiB
Go
package phases
|
|
|
|
import (
|
|
"github.com/databricks/cli/bundle"
|
|
"github.com/databricks/cli/bundle/config"
|
|
"github.com/databricks/cli/bundle/config/mutator"
|
|
pythonmutator "github.com/databricks/cli/bundle/config/mutator/python"
|
|
"github.com/databricks/cli/bundle/config/validate"
|
|
"github.com/databricks/cli/bundle/deploy/metadata"
|
|
"github.com/databricks/cli/bundle/deploy/terraform"
|
|
"github.com/databricks/cli/bundle/permissions"
|
|
"github.com/databricks/cli/bundle/python"
|
|
"github.com/databricks/cli/bundle/scripts"
|
|
)
|
|
|
|
// The initialize phase fills in defaults and connects to the workspace.
|
|
// Interpolation of fields referring to the "bundle" and "workspace" keys
|
|
// happens upon completion of this phase.
|
|
func Initialize() bundle.Mutator {
|
|
return newPhase(
|
|
"initialize",
|
|
[]bundle.Mutator{
|
|
validate.AllResourcesHaveValues(),
|
|
mutator.RewriteSyncPaths(),
|
|
mutator.MergeJobClusters(),
|
|
mutator.MergeJobParameters(),
|
|
mutator.MergeJobTasks(),
|
|
mutator.MergePipelineClusters(),
|
|
mutator.InitializeWorkspaceClient(),
|
|
mutator.PopulateCurrentUser(),
|
|
mutator.DefineDefaultWorkspaceRoot(),
|
|
mutator.ExpandWorkspaceRoot(),
|
|
mutator.DefineDefaultWorkspacePaths(),
|
|
mutator.SetVariables(),
|
|
// Intentionally placed before ResolveVariableReferencesInLookup, ResolveResourceReferences,
|
|
// ResolveVariableReferencesInComplexVariables and ResolveVariableReferences.
|
|
// See what is expected in PythonMutatorPhaseInit doc
|
|
pythonmutator.PythonMutator(pythonmutator.PythonMutatorPhaseInit),
|
|
mutator.ResolveVariableReferencesInLookup(),
|
|
mutator.ResolveResourceReferences(),
|
|
mutator.ResolveVariableReferencesInComplexVariables(),
|
|
mutator.ResolveVariableReferences(
|
|
"bundle",
|
|
"workspace",
|
|
"variables",
|
|
),
|
|
mutator.SetRunAs(),
|
|
mutator.OverrideCompute(),
|
|
mutator.ProcessTargetMode(),
|
|
mutator.ApplyPresets(),
|
|
mutator.DefaultQueueing(),
|
|
mutator.ExpandPipelineGlobPaths(),
|
|
|
|
// Configure use of WSFS for reads if the CLI is running on Databricks.
|
|
mutator.ConfigureWSFS(),
|
|
|
|
mutator.TranslatePaths(),
|
|
python.WrapperWarning(),
|
|
permissions.ApplyBundlePermissions(),
|
|
permissions.FilterCurrentUser(),
|
|
metadata.AnnotateJobs(),
|
|
metadata.AnnotatePipelines(),
|
|
terraform.Initialize(),
|
|
scripts.Execute(config.ScriptPostInit),
|
|
},
|
|
)
|
|
}
|