mirror of
https://github.com/opentofu/opentofu.git
synced 2024-12-24 08:00:17 -06:00
e9fe0f1118
Signed-off-by: Ronny Orot <ronny.orot@gmail.com>
79 lines
2.6 KiB
Go
79 lines
2.6 KiB
Go
// Copyright (c) The OpenTofu Authors
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
// Copyright (c) 2023 HashiCorp, Inc.
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
package addrs
|
|
|
|
import (
|
|
"github.com/hashicorp/hcl/v2"
|
|
"github.com/opentofu/opentofu/internal/tfdiags"
|
|
)
|
|
|
|
// RemoveEndpoint is to ConfigRemovable what Target is to Targetable:
|
|
// a wrapping struct that captures the result of decoding an HCL
|
|
// traversal representing a relative path from the current module to
|
|
// a removable object. It is very similar to MoveEndpoint.
|
|
//
|
|
// Its purpose is to represent the "from" address in a "removed" block
|
|
// in the configuration.
|
|
//
|
|
// To obtain a full address from a RemoveEndpoint we need to combine it
|
|
// with any ancestor modules in the configuration
|
|
type RemoveEndpoint struct {
|
|
// SourceRange is the location of the physical endpoint address
|
|
// in configuration, if this RemoveEndpoint was decoded from a
|
|
// configuration expression.
|
|
SourceRange tfdiags.SourceRange
|
|
|
|
// the representation of our relative address as a ConfigRemovable
|
|
RelSubject ConfigRemovable
|
|
}
|
|
|
|
// ParseRemoveEndpoint attempts to interpret the given traversal as a
|
|
// "remove endpoint" address, which is a relative path from the module containing
|
|
// the traversal to a removable object in either the same module or in some
|
|
// child module.
|
|
//
|
|
// This deals only with the syntactic element of a remove endpoint expression
|
|
// in configuration. Before the result will be useful you'll need to combine
|
|
// it with the address of the module where it was declared in order to get
|
|
// an absolute address relative to the root module.
|
|
func ParseRemoveEndpoint(traversal hcl.Traversal) (*RemoveEndpoint, tfdiags.Diagnostics) {
|
|
path, remain, diags := parseModulePrefix(traversal)
|
|
if diags.HasErrors() {
|
|
return nil, diags
|
|
}
|
|
|
|
rng := tfdiags.SourceRangeFromHCL(traversal.SourceRange())
|
|
|
|
if len(remain) == 0 {
|
|
return &RemoveEndpoint{
|
|
RelSubject: path,
|
|
SourceRange: rng,
|
|
}, diags
|
|
}
|
|
|
|
riAddr, moreDiags := parseResourceUnderModule(path, remain)
|
|
diags = diags.Append(moreDiags)
|
|
if diags.HasErrors() {
|
|
return nil, diags
|
|
}
|
|
|
|
if riAddr.Resource.Mode == DataResourceMode {
|
|
diags = diags.Append(&hcl.Diagnostic{
|
|
Severity: hcl.DiagError,
|
|
Summary: "Data source address is not allowed",
|
|
Detail: "Data sources cannot be destroyed, and therefore, 'removed' blocks are not allowed to target them. To remove data sources from the state, you should remove the data source block from the configuration.",
|
|
Subject: traversal.SourceRange().Ptr(),
|
|
})
|
|
|
|
return nil, diags
|
|
}
|
|
|
|
return &RemoveEndpoint{
|
|
RelSubject: riAddr,
|
|
SourceRange: rng,
|
|
}, diags
|
|
}
|