generated from hashicorp/terraform-provider-scaffolding
-
Notifications
You must be signed in to change notification settings - Fork 50
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HCPE-830 - Add TGW attachment resource #58
Merged
Merged
Changes from all commits
Commits
Show all changes
17 commits
Select commit
Hold shift + click to select a range
13101d8
Add TGW resource
roaks3 a1a5a58
Add TGW timeouts
roaks3 f701034
Change tgw to transit_gateway for resource names and fields
roaks3 b29dd52
Update error messages to use Transit gateway instead of TGW
roaks3 1f4c9ad
Rename resources from hcp_transit_gateway_attachment to hcp_aws_trans…
roaks3 1150867
Add field descriptions and validations
roaks3 ade5703
Add basic examples and regenerate docs
roaks3 c1d4273
Remove importing
roaks3 b4cb33e
Update TGW resource to properly handle failures that occur during create
roaks3 abe6259
Update some field descriptions to be more clear
roaks3 f0b1981
Update data source to use wait_for_active_state flag instead of optio…
roaks3 3d57ffc
Update format of states in documentation
roaks3 88894b8
Update resource name used in error message
roaks3 6f12d74
Change capitalization of Transit to transit for TGW descriptions and …
roaks3 c6fc80d
Update some descriptions and messages for clarity
roaks3 dd79282
go mod tidy
roaks3 8d86ede
Add back state as a computed value
roaks3 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
--- | ||
page_title: "hcp_aws_transit_gateway_attachment Data Source - terraform-provider-hcp" | ||
subcategory: "" | ||
description: |- | ||
The AWS Transit Gateway Attachment data source provides information about an existing transit gateway attachment. | ||
--- | ||
|
||
# Data Source `hcp_aws_transit_gateway_attachment` | ||
|
||
The AWS Transit Gateway Attachment data source provides information about an existing transit gateway attachment. | ||
|
||
## Example Usage | ||
|
||
```terraform | ||
data "hcp_aws_transit_gateway_attachment" "test" { | ||
hvn_id = var.hvn_id | ||
transit_gateway_attachment_id = var.transit_gateway_attachment_id | ||
} | ||
``` | ||
|
||
## Schema | ||
|
||
### Required | ||
|
||
- **hvn_id** (String) The ID of the HashiCorp Virtual Network (HVN). | ||
- **transit_gateway_attachment_id** (String) The user-settable name of the transit gateway attachment in HCP. | ||
|
||
### Optional | ||
|
||
- **id** (String) The ID of this resource. | ||
roaks3 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
- **timeouts** (Block, Optional) (see [below for nested schema](#nestedblock--timeouts)) | ||
- **wait_for_active_state** (Boolean) If `true`, Terraform will wait for the transit gateway attachment to reach an `ACTIVE` state before continuing. Default `false`. | ||
|
||
### Read-only | ||
|
||
- **created_at** (String) The time that the transit gateway attachment was created. | ||
- **destination_cidrs** (List of String) The list of associated CIDR ranges. Traffic from these CIDRs will be allowed for all resources in the HVN. Traffic to these CIDRs will be routed into this transit gateway attachment. | ||
- **expires_at** (String) The time after which the transit gateway attachment will be considered expired if it hasn't transitioned into `ACCEPTED` or `ACTIVE` state. | ||
- **organization_id** (String) The ID of the HCP organization where the transit gateway attachment is located. Always matches the HVN's organization. | ||
- **project_id** (String) The ID of the HCP project where the transit gateway attachment is located. Always matches the HVN's project. | ||
- **provider_transit_gateway_attachment_id** (String) The transit gateway attachment ID used by AWS. | ||
- **state** (String) The state of the transit gateway attachment. | ||
- **transit_gateway_id** (String) The ID of the user-owned transit gateway in AWS. | ||
|
||
roaks3 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<a id="nestedblock--timeouts"></a> | ||
### Nested Schema for `timeouts` | ||
|
||
Optional: | ||
|
||
- **default** (String) | ||
roaks3 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
--- | ||
page_title: "hcp_aws_transit_gateway_attachment Resource - terraform-provider-hcp" | ||
subcategory: "" | ||
description: |- | ||
The AWS Transit Gateway Attachment resource allows you to manage a transit gateway attachment. The transit gateway attachment attaches an HVN to a user-owned transit gateway in AWS. Note that the HVN and transit gateway must be located in the same AWS region. | ||
--- | ||
|
||
# Resource `hcp_aws_transit_gateway_attachment` | ||
|
||
The AWS Transit Gateway Attachment resource allows you to manage a transit gateway attachment. The transit gateway attachment attaches an HVN to a user-owned transit gateway in AWS. Note that the HVN and transit gateway must be located in the same AWS region. | ||
|
||
## Example Usage | ||
|
||
```terraform | ||
provider "aws" { | ||
region = "us-west-2" | ||
} | ||
|
||
resource "hcp_hvn" "main" { | ||
hvn_id = "main-hvn" | ||
cloud_provider = "aws" | ||
region = "us-west-2" | ||
cidr_block = "172.25.16.0/20" | ||
} | ||
|
||
resource "aws_vpc" "example" { | ||
cidr_block = "172.31.0.0/16" | ||
} | ||
|
||
resource "aws_ec2_transit_gateway" "example" { | ||
tags = { | ||
Name = "example-tgw" | ||
} | ||
} | ||
|
||
resource "aws_ram_resource_share" "example" { | ||
name = "example-resource-share" | ||
allow_external_principals = true | ||
} | ||
|
||
resource "aws_ram_principal_association" "example" { | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
principal = hcp_hvn.main.provider_account_id | ||
} | ||
|
||
resource "aws_ram_resource_association" "example" { | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
resource_arn = aws_ec2_transit_gateway.example.arn | ||
} | ||
|
||
resource "hcp_aws_transit_gateway_attachment" "example" { | ||
depends_on = [ | ||
aws_ram_principal_association.example, | ||
aws_ram_resource_association.example, | ||
] | ||
|
||
hvn_id = hcp_hvn.main.hvn_id | ||
transit_gateway_attachment_id = "example-tgw-attachment" | ||
transit_gateway_id = aws_ec2_transit_gateway.example.id | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
destination_cidrs = [aws_vpc.example.cidr_block] | ||
} | ||
|
||
resource "aws_ec2_transit_gateway_vpc_attachment_accepter" "example" { | ||
transit_gateway_attachment_id = hcp_aws_transit_gateway_attachment.example.provider_transit_gateway_attachment_id | ||
} | ||
``` | ||
|
||
## Schema | ||
|
||
### Required | ||
|
||
- **destination_cidrs** (List of String) The list of associated CIDR ranges. Traffic from these CIDRs will be allowed for all resources in the HVN. Traffic to these CIDRs will be routed into this transit gateway attachment. | ||
- **hvn_id** (String) The ID of the HashiCorp Virtual Network (HVN). | ||
- **resource_share_arn** (String, Sensitive) The Amazon Resource Name (ARN) of the Resource Share that is needed to grant HCP access to the transit gateway in AWS. The Resource Share should be associated with the HCP AWS account principal (see [aws_ram_principal_association](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/ram_principal_association)) and the transit gateway resource (see [aws_ram_resource_association](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/ram_resource_association)) | ||
- **transit_gateway_attachment_id** (String) The user-settable name of the transit gateway attachment in HCP. | ||
- **transit_gateway_id** (String) The ID of the user-owned transit gateway in AWS. The AWS region of the transit gateway must match the HVN. | ||
|
||
### Optional | ||
|
||
- **id** (String) The ID of this resource. | ||
- **timeouts** (Block, Optional) (see [below for nested schema](#nestedblock--timeouts)) | ||
roaks3 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
### Read-only | ||
|
||
- **created_at** (String) The time that the transit gateway attachment was created. | ||
- **expires_at** (String) The time after which the transit gateway attachment will be considered expired if it hasn't transitioned into `ACCEPTED` or `ACTIVE` state. | ||
- **organization_id** (String) The ID of the HCP organization where the transit gateway attachment is located. Always matches the HVN's organization. | ||
- **project_id** (String) The ID of the HCP project where the transit gateway attachment is located. Always matches the HVN's project. | ||
- **provider_transit_gateway_attachment_id** (String) The transit gateway attachment ID used by AWS. | ||
- **state** (String) The state of the transit gateway attachment. | ||
|
||
<a id="nestedblock--timeouts"></a> | ||
### Nested Schema for `timeouts` | ||
|
||
Optional: | ||
|
||
- **create** (String) | ||
smaant marked this conversation as resolved.
Show resolved
Hide resolved
|
||
- **default** (String) | ||
- **delete** (String) | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
4 changes: 4 additions & 0 deletions
4
examples/data-sources/hcp_aws_transit_gateway_attachment/data-source.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
data "hcp_aws_transit_gateway_attachment" "test" { | ||
hvn_id = var.hvn_id | ||
transit_gateway_attachment_id = var.transit_gateway_attachment_id | ||
} |
9 changes: 9 additions & 0 deletions
9
examples/data-sources/hcp_aws_transit_gateway_attachment/variables.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
variable "hvn_id" { | ||
description = "The ID of the HashiCorp Virtual Network (HVN)." | ||
type = string | ||
} | ||
|
||
variable "transit_gateway_attachment_id" { | ||
description = "The user-settable name of the transit gateway attachment in HCP." | ||
type = string | ||
} |
52 changes: 52 additions & 0 deletions
52
examples/resources/hcp_aws_transit_gateway_attachment/resource.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
provider "aws" { | ||
region = "us-west-2" | ||
} | ||
|
||
resource "hcp_hvn" "main" { | ||
hvn_id = "main-hvn" | ||
cloud_provider = "aws" | ||
region = "us-west-2" | ||
cidr_block = "172.25.16.0/20" | ||
} | ||
|
||
resource "aws_vpc" "example" { | ||
cidr_block = "172.31.0.0/16" | ||
} | ||
|
||
resource "aws_ec2_transit_gateway" "example" { | ||
tags = { | ||
Name = "example-tgw" | ||
} | ||
} | ||
|
||
resource "aws_ram_resource_share" "example" { | ||
name = "example-resource-share" | ||
allow_external_principals = true | ||
} | ||
|
||
resource "aws_ram_principal_association" "example" { | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
principal = hcp_hvn.main.provider_account_id | ||
} | ||
|
||
resource "aws_ram_resource_association" "example" { | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
resource_arn = aws_ec2_transit_gateway.example.arn | ||
} | ||
|
||
resource "hcp_aws_transit_gateway_attachment" "example" { | ||
depends_on = [ | ||
aws_ram_principal_association.example, | ||
aws_ram_resource_association.example, | ||
] | ||
|
||
hvn_id = hcp_hvn.main.hvn_id | ||
transit_gateway_attachment_id = "example-tgw-attachment" | ||
transit_gateway_id = aws_ec2_transit_gateway.example.id | ||
resource_share_arn = aws_ram_resource_share.example.arn | ||
destination_cidrs = [aws_vpc.example.cidr_block] | ||
} | ||
|
||
resource "aws_ec2_transit_gateway_vpc_attachment_accepter" "example" { | ||
transit_gateway_attachment_id = hcp_aws_transit_gateway_attachment.example.provider_transit_gateway_attachment_id | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,103 @@ | ||
package clients | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"time" | ||
|
||
"github.com/hashicorp/hcp-sdk-go/clients/cloud-network/preview/2020-09-07/client/network_service" | ||
networkmodels "github.com/hashicorp/hcp-sdk-go/clients/cloud-network/preview/2020-09-07/models" | ||
sharedmodels "github.com/hashicorp/hcp-sdk-go/clients/cloud-shared/v1/models" | ||
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" | ||
) | ||
|
||
// GetTGWAttachmentByID gets a TGW attachment by its ID, hvnID, and location | ||
func GetTGWAttachmentByID(ctx context.Context, client *Client, tgwAttachmentID string, hvnID string, loc *sharedmodels.HashicorpCloudLocationLocation) (*networkmodels.HashicorpCloudNetwork20200907TGWAttachment, error) { | ||
getTGWAttachmentParams := network_service.NewGetTGWAttachmentParams() | ||
getTGWAttachmentParams.ID = tgwAttachmentID | ||
getTGWAttachmentParams.HvnID = hvnID | ||
getTGWAttachmentParams.HvnLocationOrganizationID = loc.OrganizationID | ||
getTGWAttachmentParams.HvnLocationProjectID = loc.ProjectID | ||
getTGWAttachmentResponse, err := client.Network.GetTGWAttachment(getTGWAttachmentParams, nil) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
return getTGWAttachmentResponse.Payload.TgwAttachment, nil | ||
} | ||
|
||
const ( | ||
// TgwAttachmentStateCreating is the CREATING state of a TGW attachment | ||
TgwAttachmentStateCreating = string(networkmodels.HashicorpCloudNetwork20200907TGWAttachmentStateCREATING) | ||
|
||
// TgwAttachmentStatePendingAcceptance is the PENDING_ACCEPTANCE state of a TGW attachment | ||
TgwAttachmentStatePendingAcceptance = string(networkmodels.HashicorpCloudNetwork20200907TGWAttachmentStatePENDINGACCEPTANCE) | ||
|
||
// TgwAttachmentStateAccepted is the ACCEPTED state of a TGW attachment | ||
TgwAttachmentStateAccepted = string(networkmodels.HashicorpCloudNetwork20200907TGWAttachmentStateACCEPTED) | ||
|
||
// TgwAttachmentStateActive is the ACTIVE state of a TGW attachment | ||
TgwAttachmentStateActive = string(networkmodels.HashicorpCloudNetwork20200907TGWAttachmentStateACTIVE) | ||
) | ||
|
||
// tgwAttachmentRefreshState refreshes the state of the TGW attachment by | ||
// calling the GET endpoint | ||
func tgwAttachmentRefreshState(ctx context.Context, client *Client, tgwAttachmentID string, hvnID string, loc *sharedmodels.HashicorpCloudLocationLocation) resource.StateRefreshFunc { | ||
return func() (interface{}, string, error) { | ||
tgwAtt, err := GetTGWAttachmentByID(ctx, client, tgwAttachmentID, hvnID, loc) | ||
if err != nil { | ||
return nil, "", err | ||
} | ||
|
||
return tgwAtt, string(tgwAtt.State), nil | ||
} | ||
} | ||
|
||
// WaitForTGWAttachmentToBeActive will poll the GET TGW attachment endpoint | ||
// until the state is ACTIVE, ctx is canceled, or an error occurs. | ||
func WaitForTGWAttachmentToBeActive(ctx context.Context, client *Client, tgwAttachmentID string, hvnID string, loc *sharedmodels.HashicorpCloudLocationLocation, timeout time.Duration) (*networkmodels.HashicorpCloudNetwork20200907TGWAttachment, error) { | ||
stateChangeConf := resource.StateChangeConf{ | ||
Pending: []string{ | ||
TgwAttachmentStateCreating, | ||
TgwAttachmentStatePendingAcceptance, | ||
TgwAttachmentStateAccepted, | ||
}, | ||
Target: []string{ | ||
TgwAttachmentStateActive, | ||
}, | ||
Refresh: tgwAttachmentRefreshState(ctx, client, tgwAttachmentID, hvnID, loc), | ||
Timeout: timeout, | ||
PollInterval: 5 * time.Second, | ||
} | ||
|
||
result, err := stateChangeConf.WaitForStateContext(ctx) | ||
if err != nil { | ||
return nil, fmt.Errorf("Error waiting for transit gateway attachment (%s) to become 'ACTIVE': %s", tgwAttachmentID, err) | ||
} | ||
|
||
return result.(*networkmodels.HashicorpCloudNetwork20200907TGWAttachment), nil | ||
} | ||
|
||
// WaitForTGWAttachmentToBePendingAcceptance will poll the GET TGW attachment | ||
// endpoint until the state is PENDING_ACCEPTANCE, ctx is canceled, or an error | ||
// occurs. | ||
func WaitForTGWAttachmentToBePendingAcceptance(ctx context.Context, client *Client, tgwAttachmentID string, hvnID string, loc *sharedmodels.HashicorpCloudLocationLocation, timeout time.Duration) (*networkmodels.HashicorpCloudNetwork20200907TGWAttachment, error) { | ||
stateChangeConf := resource.StateChangeConf{ | ||
Pending: []string{ | ||
TgwAttachmentStateCreating, | ||
}, | ||
Target: []string{ | ||
TgwAttachmentStatePendingAcceptance, | ||
}, | ||
Refresh: tgwAttachmentRefreshState(ctx, client, tgwAttachmentID, hvnID, loc), | ||
Timeout: timeout, | ||
PollInterval: 5 * time.Second, | ||
} | ||
|
||
result, err := stateChangeConf.WaitForStateContext(ctx) | ||
if err != nil { | ||
return nil, fmt.Errorf("Error waiting for transit gateway attachment (%s) to become 'PENDING_ACCEPTANCE': %s", tgwAttachmentID, err) | ||
} | ||
|
||
return result.(*networkmodels.HashicorpCloudNetwork20200907TGWAttachment), nil | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The
docs/*
files included here were generated withgo generate
, which pulls in the examples and resource/field descriptions.