From cc2f9fff0bce3992c5b513a4870f00df0c65a6fd Mon Sep 17 00:00:00 2001 From: James Kwon <96548424+hongil0316@users.noreply.github.com> Date: Sat, 20 Jul 2024 19:38:30 -0400 Subject: [PATCH] =?UTF-8?q?extended=20vpc=20struct=20to=20support=20cidrbl?= =?UTF-8?q?ock,cidr=20associations=20and=20ipv6=20a=E2=80=A6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- modules/aws/vpc.go | 37 ++++++++++++++++++++++++++++++++----- modules/aws/vpc_test.go | 1 + 2 files changed, 33 insertions(+), 5 deletions(-) diff --git a/modules/aws/vpc.go b/modules/aws/vpc.go index 3101a227e..5ee142a3f 100644 --- a/modules/aws/vpc.go +++ b/modules/aws/vpc.go @@ -14,10 +14,13 @@ import ( // Vpc is an Amazon Virtual Private Cloud. type Vpc struct { - Id string // The ID of the VPC - Name string // The name of the VPC - Subnets []Subnet // A list of subnets in the VPC - Tags map[string]string // The tags associated with the VPC + Id string // The ID of the VPC + Name string // The name of the VPC + Subnets []Subnet // A list of subnets in the VPC + Tags map[string]string // The tags associated with the VPC + CidrBlock *string // The primary IPv4 CIDR block for the VPC. + CidrAssociations []*string // Information about the IPv4 CIDR blocks associated with the VPC. + Ipv6CidrAssociations []*string // Information about the IPv6 CIDR blocks associated with the VPC. } // Subnet is a subnet in an availability zone. @@ -105,7 +108,31 @@ func GetVpcsE(t testing.TestingT, filters []*ec2.Filter, region string) ([]*Vpc, return nil, err } - retVal[i] = &Vpc{Id: aws.StringValue(vpc.VpcId), Name: FindVpcName(vpc), Subnets: subnets, Tags: tags} + // cidr block associations + var cidrBlockAssociations = func() (list []*string) { + for _, cidr := range vpc.CidrBlockAssociationSet { + list = append(list, cidr.CidrBlock) + } + return + }() + + // ipv6 cidr block associations + var Ipv6CidrAssociations = func() (list []*string) { + for _, cidr := range vpc.Ipv6CidrBlockAssociationSet { + list = append(list, cidr.Ipv6CidrBlock) + } + return + }() + + retVal[i] = &Vpc{ + Id: aws.StringValue(vpc.VpcId), + Name: FindVpcName(vpc), + Subnets: subnets, + Tags: tags, + CidrBlock: vpc.CidrBlock, + CidrAssociations: cidrBlockAssociations, + Ipv6CidrAssociations: Ipv6CidrAssociations, + } } return retVal, nil diff --git a/modules/aws/vpc_test.go b/modules/aws/vpc_test.go index b5a345ce7..8a060efc8 100644 --- a/modules/aws/vpc_test.go +++ b/modules/aws/vpc_test.go @@ -30,6 +30,7 @@ func TestGetVpcById(t *testing.T) { vpcTest := GetVpcById(t, *vpc.VpcId, region) assert.Equal(t, *vpc.VpcId, vpcTest.Id) + assert.NotEmpty(t, vpcTest.CidrAssociations) } func TestGetVpcsE(t *testing.T) {