Skip to content

Commit

Permalink
Merge pull request hashicorp#17291 from ewbankkit/f-r/aws_route-manag…
Browse files Browse the repository at this point in the history
…ed_prefix_list-destination

r/aws_route: 'destination_prefix_list_id' attribute can be specified for managed prefix list destinations
  • Loading branch information
YakDriver authored Mar 29, 2021
2 parents d0fb8dd + 8f4e1be commit 19b8055
Show file tree
Hide file tree
Showing 5 changed files with 1,715 additions and 604 deletions.
3 changes: 3 additions & 0 deletions .changelog/17291.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
resource/aws_route: `destination_prefix_list_id` attribute can be specified for managed prefix list destinations
```
17 changes: 17 additions & 0 deletions aws/internal/service/ec2/finder/finder.go
Original file line number Diff line number Diff line change
Expand Up @@ -254,6 +254,23 @@ func RouteByIPv6Destination(conn *ec2.EC2, routeTableID, destinationIpv6Cidr str
return nil, &resource.NotFoundError{}
}

// RouteByPrefixListIDDestination returns the route corresponding to the specified prefix list destination.
// Returns NotFoundError if no route is found.
func RouteByPrefixListIDDestination(conn *ec2.EC2, routeTableID, prefixListID string) (*ec2.Route, error) {
routeTable, err := RouteTableByID(conn, routeTableID)
if err != nil {
return nil, err
}

for _, route := range routeTable.Routes {
if aws.StringValue(route.DestinationPrefixListId) == prefixListID {
return route, nil
}
}

return nil, &resource.NotFoundError{}
}

// SecurityGroupByID looks up a security group by ID. When not found, returns nil and potentially an API error.
func SecurityGroupByID(conn *ec2.EC2, id string) (*ec2.SecurityGroup, error) {
req := &ec2.DescribeSecurityGroupsInput{
Expand Down
45 changes: 24 additions & 21 deletions aws/resource_aws_route.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import (
var routeValidDestinations = []string{
"destination_cidr_block",
"destination_ipv6_cidr_block",
"destination_prefix_list_id",
}

var routeValidTargets = []string{
Expand Down Expand Up @@ -69,7 +70,6 @@ func resourceAwsRoute() *schema.Resource {
validateIpv4CIDRNetworkAddress,
),
},

"destination_ipv6_cidr_block": {
Type: schema.TypeString,
Optional: true,
Expand All @@ -80,11 +80,10 @@ func resourceAwsRoute() *schema.Resource {
),
DiffSuppressFunc: suppressEqualCIDRBlockDiffs,
},

// TODO This is a target once we have Managed Prefix List support.
"destination_prefix_list_id": {
Type: schema.TypeString,
Computed: true,
Optional: true,
ForceNew: true,
},

//
Expand All @@ -96,60 +95,54 @@ func resourceAwsRoute() *schema.Resource {
ExactlyOneOf: routeValidTargets,
ConflictsWith: []string{"destination_ipv6_cidr_block"}, // IPv4 destinations only.
},

"egress_only_gateway_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
ConflictsWith: []string{"destination_cidr_block"}, // IPv6 destinations only.
},

"gateway_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
},

"instance_id": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ExactlyOneOf: routeValidTargets,
},

"local_gateway_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
},

"nat_gateway_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
ConflictsWith: []string{"destination_ipv6_cidr_block"}, // IPv4 destinations only.
},

"network_interface_id": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ExactlyOneOf: routeValidTargets,
},

"transit_gateway_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
},

"vpc_endpoint_id": {
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
ConflictsWith: []string{"destination_ipv6_cidr_block"}, // IPv4 destinations only.
Type: schema.TypeString,
Optional: true,
ExactlyOneOf: routeValidTargets,
ConflictsWith: []string{
"destination_ipv6_cidr_block", // IPv4 destinations only.
"destination_prefix_list_id", // "Cannot create or replace a prefix list route targeting a VPC Endpoint."
},
},

"vpc_peering_connection_id": {
Type: schema.TypeString,
Optional: true,
Expand All @@ -163,12 +156,10 @@ func resourceAwsRoute() *schema.Resource {
Type: schema.TypeString,
Computed: true,
},

"origin": {
Type: schema.TypeString,
Computed: true,
},

"state": {
Type: schema.TypeString,
Computed: true,
Expand Down Expand Up @@ -206,6 +197,9 @@ func resourceAwsRouteCreate(d *schema.ResourceData, meta interface{}) error {
case "destination_ipv6_cidr_block":
input.DestinationIpv6CidrBlock = destination
routeFinder = finder.RouteByIPv6Destination
case "destination_prefix_list_id":
input.DestinationPrefixListId = destination
routeFinder = finder.RouteByPrefixListIDDestination
default:
return fmt.Errorf("error creating Route: unexpected route destination attribute: %q", destinationAttributeKey)
}
Expand Down Expand Up @@ -285,7 +279,7 @@ func resourceAwsRouteCreate(d *schema.ResourceData, meta interface{}) error {
}

if tfresource.NotFound(err) {
return fmt.Errorf("Route in Route Table (%s) with destination (%s) not found", routeTableID, destination)
return fmt.Errorf("route in Route Table (%s) with destination (%s) not found", routeTableID, destination)
}

d.SetId(tfec2.RouteCreateID(routeTableID, destination))
Expand All @@ -309,6 +303,8 @@ func resourceAwsRouteRead(d *schema.ResourceData, meta interface{}) error {
routeFinder = finder.RouteByIPv4Destination
case "destination_ipv6_cidr_block":
routeFinder = finder.RouteByIPv6Destination
case "destination_prefix_list_id":
routeFinder = finder.RouteByPrefixListIDDestination
default:
return fmt.Errorf("error reading Route: unexpected route destination attribute: %q", destinationAttributeKey)
}
Expand Down Expand Up @@ -378,6 +374,8 @@ func resourceAwsRouteUpdate(d *schema.ResourceData, meta interface{}) error {
input.DestinationCidrBlock = destination
case "destination_ipv6_cidr_block":
input.DestinationIpv6CidrBlock = destination
case "destination_prefix_list_id":
input.DestinationPrefixListId = destination
default:
return fmt.Errorf("error updating Route: unexpected route destination attribute: %q", destinationAttributeKey)
}
Expand Down Expand Up @@ -436,6 +434,8 @@ func resourceAwsRouteDelete(d *schema.ResourceData, meta interface{}) error {
input.DestinationCidrBlock = destination
case "destination_ipv6_cidr_block":
input.DestinationIpv6CidrBlock = destination
case "destination_prefix_list_id":
input.DestinationPrefixListId = destination
default:
return fmt.Errorf("error deleting Route: unexpected route destination attribute: %q", destinationAttributeKey)
}
Expand Down Expand Up @@ -490,9 +490,12 @@ func resourceAwsRouteImport(d *schema.ResourceData, meta interface{}) ([]*schema
d.Set("route_table_id", routeTableID)
if strings.Contains(destination, ":") {
d.Set("destination_ipv6_cidr_block", destination)
} else {
} else if strings.Contains(destination, ".") {
d.Set("destination_cidr_block", destination)
} else {
d.Set("destination_prefix_list_id", destination)
}

d.SetId(tfec2.RouteCreateID(routeTableID, destination))

return []*schema.ResourceData{d}, nil
Expand Down
Loading

0 comments on commit 19b8055

Please sign in to comment.