mirror of https://github.com/databricks/cli.git
61 lines
1.7 KiB
Go
61 lines
1.7 KiB
Go
package terraform
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"errors"
|
|
"os"
|
|
"path/filepath"
|
|
|
|
"github.com/databricks/cli/bundle"
|
|
tfjson "github.com/hashicorp/terraform-json"
|
|
)
|
|
|
|
// Partial representation of the Terraform state file format.
|
|
// We are only interested global version and serial numbers,
|
|
// plus resource types, names, modes, IDs, and ETags (for dashboards).
|
|
type resourcesState struct {
|
|
Version int `json:"version"`
|
|
Resources []stateResource `json:"resources"`
|
|
}
|
|
|
|
const SupportedStateVersion = 4
|
|
|
|
type stateResource struct {
|
|
Type string `json:"type"`
|
|
Name string `json:"name"`
|
|
Mode tfjson.ResourceMode `json:"mode"`
|
|
Instances []stateResourceInstance `json:"instances"`
|
|
}
|
|
|
|
type stateResourceInstance struct {
|
|
Attributes stateInstanceAttributes `json:"attributes"`
|
|
}
|
|
|
|
type stateInstanceAttributes struct {
|
|
ID string `json:"id"`
|
|
|
|
// Some resources such as Apps do not have an ID, so we use the name instead.
|
|
// We need this for cases when such resource is removed from bundle config but
|
|
// exists in the workspace still so we can correctly display its summary.
|
|
Name string `json:"name,omitempty"`
|
|
ETag string `json:"etag,omitempty"`
|
|
}
|
|
|
|
func ParseResourcesState(ctx context.Context, b *bundle.Bundle) (*resourcesState, error) {
|
|
cacheDir, err := Dir(ctx, b)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
rawState, err := os.ReadFile(filepath.Join(cacheDir, TerraformStateFileName))
|
|
if err != nil {
|
|
if errors.Is(err, os.ErrNotExist) {
|
|
return &resourcesState{Version: SupportedStateVersion}, nil
|
|
}
|
|
return nil, err
|
|
}
|
|
var state resourcesState
|
|
err = json.Unmarshal(rawState, &state)
|
|
return &state, err
|
|
}
|