databricks-cli/bundle/deploy/terraform/write.go

48 lines
871 B
Go
Raw Normal View History

package terraform
import (
"context"
"encoding/json"
"os"
"path/filepath"
"github.com/databricks/cli/bundle"
)
type write struct{}
func (w *write) Name() string {
return "terraform.Write"
}
func (w *write) Apply(ctx context.Context, b *bundle.Bundle) error {
dir, err := Dir(b)
if err != nil {
return err
}
root, noResources := BundleToTerraform(&b.Config)
b.TerraformHasNoResources = noResources
f, err := os.Create(filepath.Join(dir, "bundle.tf.json"))
if err != nil {
return err
}
defer f.Close()
enc := json.NewEncoder(f)
enc.SetIndent("", " ")
err = enc.Encode(root)
if err != nil {
return err
}
return nil
}
// Write returns a [bundle.Mutator] that converts resources in a bundle configuration
// to the equivalent Terraform JSON representation and writes the result to a file.
func Write() bundle.Mutator {
return &write{}
}