Skip to content

Commit

Permalink
adding name property for secondary ip address
Browse files Browse the repository at this point in the history
  • Loading branch information
shikha372 committed Aug 7, 2024
1 parent 0b7a56f commit daa15c7
Show file tree
Hide file tree
Showing 40 changed files with 258 additions and 261 deletions.
3 changes: 2 additions & 1 deletion packages/@aws-cdk/aws-vpcv2-alpha/awslint.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
{
"exclude": [
"from-method:@aws-cdk/aws-vpcv2-alpha.VpcV2",
"attribute-tag:@aws-cdk/aws-vpcv2-alpha.RouteTable.routeTableId"
"attribute-tag:@aws-cdk/aws-vpcv2-alpha.RouteTable.routeTableId",
"from-method:@aws-cdk/aws-vpcv2-alpha.SubnetV2"
]
}
2 changes: 1 addition & 1 deletion packages/@aws-cdk/aws-vpcv2-alpha/jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ module.exports = {
coverageThreshold: {
global: {
statements: 75,
branches: 64,
branches: 63,
},
},
};;
18 changes: 15 additions & 3 deletions packages/@aws-cdk/aws-vpcv2-alpha/lib/subnet-v2.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,18 @@ export interface SubnetV2Props {

}

/**
* Interface with additional properties for SubnetV2
*/
export interface ISubnetV2 extends ISubnet {

/**
* The IPv6 CIDR block for this subnet
*/
readonly ipv6CidrBlock?: string;

}

/**
* The SubnetV2 class represents a subnet within a VPC (Virtual Private Cloud) in AWS.
* It extends the Resource class and implements the ISubnet interface.
Expand All @@ -96,7 +108,7 @@ export interface SubnetV2Props {
* @resource AWS::EC2::Subnet
*
*/
export class SubnetV2 extends Resource implements ISubnet {
export class SubnetV2 extends Resource implements ISubnetV2 {

/**
* The Availability Zone the subnet is located in
Expand Down Expand Up @@ -334,7 +346,7 @@ function checkCidrRanges(vpc: IVpcV2, cidrRange: string) {

function validateOverlappingCidrRanges(vpc: IVpcV2, ipv4CidrBlock: string): boolean {

let allSubnets: ISubnet[];
let allSubnets: ISubnetV2[];
try {
allSubnets = vpc.selectSubnets().subnets;
} catch (e) {
Expand Down Expand Up @@ -373,7 +385,7 @@ function validateOverlappingCidrRanges(vpc: IVpcV2, ipv4CidrBlock: string): bool
*/
function validateOverlappingCidrRangesipv6(vpc: IVpcV2, ipv6CidrBlock: string): boolean {

let allSubnets: ISubnet[];
let allSubnets: ISubnetV2[];
try {
allSubnets = vpc.selectSubnets().subnets;
} catch (e) {
Expand Down
69 changes: 29 additions & 40 deletions packages/@aws-cdk/aws-vpcv2-alpha/lib/vpc-v2.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { Arn, CfnResource, Lazy, Names } from 'aws-cdk-lib/core';
import { Construct, DependencyGroup, IDependable } from 'constructs';
import { IpamOptions, IIpamPool } from './ipam';
import { VpcV2Base } from './vpc-v2-base';
import { md5hash } from 'aws-cdk-lib/core/lib/helpers-internal';

/**
* IpAddress options to define VPC V2
*/
Expand All @@ -12,29 +12,29 @@ export class IpAddresses {
/**
* An IPv4 CIDR Range
*/
public static ipv4(ipv4Cidr: string): IIpAddresses {
return new ipv4CidrAllocation(ipv4Cidr);
public static ipv4(ipv4Cidr: string, cidrBlockName?: string): IIpAddresses {
return new ipv4CidrAllocation(ipv4Cidr, cidrBlockName);
}

/**
* An Ipv4 Ipam Pool
*/
public static ipv4Ipam(ipv4IpamOptions: IpamOptions): IIpAddresses {
return new IpamIpv4(ipv4IpamOptions);
public static ipv4Ipam(ipv4IpamOptions: IpamOptions, cidrBlockName?: string): IIpAddresses {
return new IpamIpv4(ipv4IpamOptions, cidrBlockName);
}

/**
* An Ipv6 Ipam Pool
*/
public static ipv6Ipam(ipv6IpamOptions: IpamOptions): IIpAddresses {
return new IpamIpv6(ipv6IpamOptions);
public static ipv6Ipam(ipv6IpamOptions: IpamOptions, cidrBlockName: string): IIpAddresses {
return new IpamIpv6(ipv6IpamOptions, cidrBlockName);
}

/**
* Amazon Provided Ipv6 range
*/
public static amazonProvidedIpv6() : IIpAddresses {
return new AmazonProvided();
public static amazonProvidedIpv6(cidrBlockName: string) : IIpAddresses {
return new AmazonProvided(cidrBlockName);
}
}

Expand Down Expand Up @@ -95,6 +95,13 @@ export interface VpcCidrOptions {
* @default - No dependency
*/
readonly dependencies?: CfnResource[];

/**
* Required to set Secondary cidr block resource name
* in order to generate unique logical id for the resource.
* @default : no name for primary addresses
*/
readonly cidrBlockName?: string;
}

/**
Expand Down Expand Up @@ -289,13 +296,12 @@ export class VpcV2 extends VpcV2Base {
if (props.secondaryAddressBlocks) {
const secondaryAddressBlocks: IIpAddresses[] = props.secondaryAddressBlocks;

let ipCount = 0;
for (const secondaryAddressBlock of secondaryAddressBlocks) {
//Counter to generate a random string for input to hash function
ipCount+=1;
const hash = pathHash('Secondary'+ipCount);

const secondaryVpcOptions: VpcCidrOptions = secondaryAddressBlock.allocateVpcCidr();
if (!secondaryVpcOptions.cidrBlockName) {
throw new Error('Cidr Block Name is required to create secondary IP address');
}

if (secondaryVpcOptions.amazonProvided || secondaryVpcOptions.ipv6IpamPool) {
this.useIpv6 = true;
Expand All @@ -307,7 +313,7 @@ export class VpcV2 extends VpcV2Base {
throw new Error('CIDR block should be in the same RFC 1918 range in the VPC');
}
}
const cfnVpcCidrBlock = new CfnVPCCidrBlock(this, `SecondaryIp${hash}`, {
const cfnVpcCidrBlock = new CfnVPCCidrBlock(this, secondaryVpcOptions.cidrBlockName, {
vpcId: this.vpcId,
cidrBlock: secondaryVpcOptions.ipv4CidrBlock,
ipv4IpamPoolId: secondaryVpcOptions.ipv4IpamPool?.ipamPoolId,
Expand Down Expand Up @@ -353,8 +359,7 @@ export class VpcV2 extends VpcV2Base {
*/
class ipv4CidrAllocation implements IIpAddresses {

constructor(private readonly cidrBlock: string) {

constructor(private readonly cidrBlock: string, private readonly cidrBlockName?: string) {
}

/**
Expand All @@ -363,6 +368,7 @@ class ipv4CidrAllocation implements IIpAddresses {
allocateVpcCidr(): VpcCidrOptions {
return {
ipv4CidrBlock: this.cidrBlock,
cidrBlockName: this.cidrBlockName,
};
}
}
Expand All @@ -379,11 +385,12 @@ class AmazonProvided implements IIpAddresses {
* Amazon will automatically assign an IPv6 CIDR range from its pool of available addresses.
*/

constructor() {};
constructor(private readonly cidrBlockName?: string) {};

allocateVpcCidr(): VpcCidrOptions {
return {
amazonProvided: true,
cidrBlockName: this.cidrBlockName,
};
}

Expand All @@ -395,14 +402,15 @@ class AmazonProvided implements IIpAddresses {
*/
class IpamIpv6 implements IIpAddresses {

constructor(private readonly props: IpamOptions) {
constructor(private readonly props: IpamOptions, private readonly cidrBlockName?: string) {
}

allocateVpcCidr(): VpcCidrOptions {
return {
ipv6NetmaskLength: this.props.netmaskLength,
ipv6IpamPool: this.props.ipamPool,
dependencies: this.props.ipamPool?.ipamCidrs.map(c => c as CfnResource),
cidrBlockName: this.cidrBlockName,
};
}
}
Expand All @@ -413,13 +421,14 @@ class IpamIpv6 implements IIpAddresses {
*/
class IpamIpv4 implements IIpAddresses {

constructor(private readonly props: IpamOptions) {
constructor(private readonly props: IpamOptions, private readonly cidrBlockName?: string) {
}
allocateVpcCidr(): VpcCidrOptions {

return {
ipv4NetmaskLength: this.props.netmaskLength,
ipv4IpamPool: this.props.ipamPool,
cidrBlockName: this.cidrBlockName,
};
}
}
Expand Down Expand Up @@ -464,24 +473,4 @@ function validateIpv4address(cidr1?: string, cidr2?: string): boolean {
return (ip1.octet1 === 10 && ip2.octet1 === 10) ||
(ip1.octet1 === 192 && ip1.octet2 === 168 && ip2.octet1 === 192 && ip2.octet2 === 168) ||
(ip1.octet1 === 172 && ip1.octet2 === 16 && ip2.octet1 === 172 && ip2.octet2 === 16); // CIDR ranges belong to same private IP address ranges
}

/**
* Take a hash of the given path.
*
* The hash is limited in size.
*/
function pathHash(path: string): string {
const md5 = md5hash(path);
return md5.slice(0, 4).toUpperCase();
}

// function generateRandomString(length: number): string {
// const pattern = /[a-zA-Z0-9]/;
// const characters = pattern.source.replace(/\\/g, '');;
// let result = '';
// for (let i = 0; i < length; i++) {
// result += characters.charAt(Math.floor(Math.random() * characters.length));
// }
// return result;
// }
}

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"InstanceTenancy": "default"
}
},
"defaultSecondaryIp47C3A8F96659": {
"defaultAmazonIpv6C7A4D665": {
"Type": "AWS::EC2::VPCCidrBlock",
"Properties": {
"AmazonProvidedIpv6CidrBlock": true,
Expand Down Expand Up @@ -57,7 +57,7 @@
}
},
"DependsOn": [
"defaultSecondaryIp47C3A8F96659"
"defaultAmazonIpv6C7A4D665"
]
},
"defaultSubnetRouteTableAssociationF1D85D29": {
Expand All @@ -74,7 +74,7 @@
}
},
"DependsOn": [
"defaultSecondaryIp47C3A8F96659"
"defaultAmazonIpv6C7A4D665"
]
}
},
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"InstanceTenancy": "default"
}
},
"dynamodbSecondaryIp47C3D307DC85": {
"dynamodbAmazonIpv6698EF571": {
"Type": "AWS::EC2::VPCCidrBlock",
"Properties": {
"AmazonProvidedIpv6CidrBlock": true,
Expand Down Expand Up @@ -57,7 +57,7 @@
}
},
"DependsOn": [
"dynamodbSecondaryIp47C3D307DC85"
"dynamodbAmazonIpv6698EF571"
]
},
"dynamodbSubnetRouteTableAssociationC38B30F3": {
Expand All @@ -74,7 +74,7 @@
}
},
"DependsOn": [
"dynamodbSecondaryIp47C3D307DC85"
"dynamodbAmazonIpv6698EF571"
]
},
"testDynamoEndpoint03D5BDE5": {
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"InstanceTenancy": "default"
}
},
"eigwSecondaryIp47C35F6F8767": {
"eigwAmazonIpv69E78211F": {
"Type": "AWS::EC2::VPCCidrBlock",
"Properties": {
"AmazonProvidedIpv6CidrBlock": true,
Expand Down Expand Up @@ -46,7 +46,7 @@
}
},
"DependsOn": [
"eigwSecondaryIp47C35F6F8767"
"eigwAmazonIpv69E78211F"
]
},
"eigwSubnetRouteTableAssociation887F4A97": {
Expand All @@ -63,7 +63,7 @@
}
},
"DependsOn": [
"eigwSecondaryIp47C35F6F8767"
"eigwAmazonIpv69E78211F"
]
},
"testEOIGWEIGW54CCAD37": {
Expand Down

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit daa15c7

Please sign in to comment.