@aws-cdk/aws-ec2
Advanced tools
Comparing version 0.25.1 to 0.25.2
@@ -9,2 +9,3 @@ export * from './connections'; | ||
export * from './vpc-network-provider'; | ||
export * from './vpn'; | ||
export * from './ec2.generated'; |
@@ -14,4 +14,5 @@ "use strict"; | ||
__export(require("./vpc-network-provider")); | ||
__export(require("./vpn")); | ||
// AWS::EC2 CloudFormation Resources: | ||
__export(require("./ec2.generated")); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUE4QjtBQUM5QixzQ0FBaUM7QUFDakMscUNBQWdDO0FBQ2hDLHNDQUFpQztBQUNqQywyQ0FBc0M7QUFDdEMsMkJBQXNCO0FBQ3RCLCtCQUEwQjtBQUMxQiw0Q0FBdUM7QUFFdkMscUNBQXFDO0FBQ3JDLHFDQUFnQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29ubmVjdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnN0YW5jZS10eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL21hY2hpbmUtaW1hZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWN1cml0eS1ncm91cCc7XG5leHBvcnQgKiBmcm9tICcuL3NlY3VyaXR5LWdyb3VwLXJ1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi92cGMnO1xuZXhwb3J0ICogZnJvbSAnLi92cGMtcmVmJztcbmV4cG9ydCAqIGZyb20gJy4vdnBjLW5ldHdvcmstcHJvdmlkZXInO1xuXG4vLyBBV1M6OkVDMiBDbG91ZEZvcm1hdGlvbiBSZXNvdXJjZXM6XG5leHBvcnQgKiBmcm9tICcuL2VjMi5nZW5lcmF0ZWQnO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1DQUE4QjtBQUM5QixzQ0FBaUM7QUFDakMscUNBQWdDO0FBQ2hDLHNDQUFpQztBQUNqQywyQ0FBc0M7QUFDdEMsMkJBQXNCO0FBQ3RCLCtCQUEwQjtBQUMxQiw0Q0FBdUM7QUFDdkMsMkJBQXNCO0FBRXRCLHFDQUFxQztBQUNyQyxxQ0FBZ0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Nvbm5lY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vaW5zdGFuY2UtdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tYWNoaW5lLWltYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VjdXJpdHktZ3JvdXAnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWN1cml0eS1ncm91cC1ydWxlJztcbmV4cG9ydCAqIGZyb20gJy4vdnBjJztcbmV4cG9ydCAqIGZyb20gJy4vdnBjLXJlZic7XG5leHBvcnQgKiBmcm9tICcuL3ZwYy1uZXR3b3JrLXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdnBuJztcblxuLy8gQVdTOjpFQzIgQ2xvdWRGb3JtYXRpb24gUmVzb3VyY2VzOlxuZXhwb3J0ICogZnJvbSAnLi9lYzIuZ2VuZXJhdGVkJztcbiJdfQ== |
import { Construct, IConstruct, IDependable } from "@aws-cdk/cdk"; | ||
import { VpnConnection, VpnConnectionOptions } from './vpn'; | ||
export interface IVpcSubnet extends IConstruct { | ||
@@ -46,2 +47,6 @@ /** | ||
/** | ||
* Identifier for the VPN gateway | ||
*/ | ||
readonly vpnGatewayId?: string; | ||
/** | ||
* Return the subnets appropriate for the placement strategy | ||
@@ -59,2 +64,6 @@ */ | ||
/** | ||
* Adds a new VPN connection to this VPC | ||
*/ | ||
addVpnConnection(id: string, options: VpnConnectionOptions): VpnConnection; | ||
/** | ||
* Exports this VPC so it can be consumed by another stack. | ||
@@ -153,2 +162,6 @@ */ | ||
/** | ||
* Identifier for the VPN gateway | ||
*/ | ||
abstract readonly vpnGatewayId?: string; | ||
/** | ||
* Dependencies for internet connectivity | ||
@@ -166,2 +179,6 @@ */ | ||
/** | ||
* Adds a new VPN connection to this VPC | ||
*/ | ||
addVpnConnection(id: string, options: VpnConnectionOptions): VpnConnection; | ||
/** | ||
* Export this VPC from the stack | ||
@@ -231,2 +248,6 @@ */ | ||
isolatedSubnetNames?: string[]; | ||
/** | ||
* VPN gateway's identifier | ||
*/ | ||
vpnGatewayId?: string; | ||
} | ||
@@ -233,0 +254,0 @@ export interface VpcSubnetImportProps { |
@@ -5,2 +5,3 @@ "use strict"; | ||
const util_1 = require("./util"); | ||
const vpn_1 = require("./vpn"); | ||
/** | ||
@@ -85,2 +86,8 @@ * The type of Subnet | ||
/** | ||
* Adds a new VPN connection to this VPC | ||
*/ | ||
addVpnConnection(id, options) { | ||
return new vpn_1.VpnConnection(this, id, Object.assign({ vpc: this }, options)); | ||
} | ||
/** | ||
* Return whether the given subnet is one of this VPC's public subnets. | ||
@@ -103,2 +110,2 @@ * | ||
exports.VpcNetworkBase = VpcNetworkBase; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vpc-ref.js","sourceRoot":"","sources":["vpc-ref.ts"],"names":[],"mappings":";;AAAA,sCAAkE;AAClE,iCAAoC;AA2EpC;;GAEG;AACH,IAAY,UAkCX;AAlCD,WAAY,UAAU;IACpB;;;;;OAKG;IACH,mDAAY,CAAA;IAEZ;;;;;;;;;;;OAWG;IACH,iDAAW,CAAA;IAEX;;;;;;;;;OASG;IACH,+CAAU,CAAA;AACZ,CAAC,EAlCW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAkCrB;AAgCD;;GAEG;AACH,MAAsB,cAAe,SAAQ,eAAS;IAAtD;;QA2BE;;WAEG;QACa,yBAAoB,GAAG,IAAI,KAAK,EAAc,CAAC;QAE/D;;WAEG;QACa,oBAAe,GAAG,IAAI,KAAK,EAAc,CAAC;IAqD5D,CAAC;IAnDC;;OAEG;IACI,OAAO,CAAC,YAAkC,EAAE;QACjD,IAAI,SAAS,CAAC,YAAY,KAAK,SAAS,IAAI,SAAS,CAAC,UAAU,KAAK,SAAS,EAAE;YAC9E,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;SAC/E;QAED,iBAAiB;QACjB,IAAI,SAAS,CAAC,UAAU,KAAK,SAAS,EAAE;YACtC,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC/F,MAAM,eAAe,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,iBAAU,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,UAAU,CAAC,CAAC;YACvF,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;gBAChC,MAAM,IAAI,KAAK,CAAC,yBAAyB,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC;aAClE;YACD,OAAO,eAAe,CAAC;SACxB;QAED,iBAAiB;QACjB,IAAI,SAAS,CAAC,YAAY,KAAK,SAAS,EAAE;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC;SAAE;QAEzE,OAAO;YACL,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe;YAC3C,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,cAAc;YACzC,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,aAAa;SACxC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC5B,CAAC;IAOD;;;;;;OAMG;IACI,cAAc,CAAC,MAAkB;QACtC,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAChC,CAAC;CAEF;AAxFD,wCAwFC","sourcesContent":["import { Construct, IConstruct, IDependable } from \"@aws-cdk/cdk\";\nimport { subnetName } from './util';\n\nexport interface IVpcSubnet extends IConstruct {\n  /**\n   * The Availability Zone the subnet is located in\n   */\n  readonly availabilityZone: string;\n\n  /**\n   * The subnetId for this particular subnet\n   */\n  readonly subnetId: string;\n\n  /**\n   * Dependable that can be depended upon to force internet connectivity established on the VPC\n   */\n  readonly internetConnectivityEstablished: IDependable;\n\n  /**\n   * Exports this subnet to another stack.\n   */\n  export(): VpcSubnetImportProps;\n}\n\nexport interface IVpcNetwork extends IConstruct {\n  /**\n   * Identifier for this VPC\n   */\n  readonly vpcId: string;\n\n  /**\n   * List of public subnets in this VPC\n   */\n  readonly publicSubnets: IVpcSubnet[];\n\n  /**\n   * List of private subnets in this VPC\n   */\n  readonly privateSubnets: IVpcSubnet[];\n\n  /**\n   * List of isolated subnets in this VPC\n   */\n  readonly isolatedSubnets: IVpcSubnet[];\n\n  /**\n   * AZs for this VPC\n   */\n  readonly availabilityZones: string[];\n\n  /**\n   * Region where this VPC is located\n   */\n  readonly vpcRegion: string;\n\n  /**\n   * Return the subnets appropriate for the placement strategy\n   */\n  subnets(placement?: VpcPlacementStrategy): IVpcSubnet[];\n\n  /**\n   * Return whether the given subnet is one of this VPC's public subnets.\n   *\n   * The subnet must literally be one of the subnet object obtained from\n   * this VPC. A subnet that merely represents the same subnet will\n   * never return true.\n   */\n  isPublicSubnet(subnet: IVpcSubnet): boolean;\n\n  /**\n   * Exports this VPC so it can be consumed by another stack.\n   */\n  export(): VpcNetworkImportProps;\n}\n\n/**\n * The type of Subnet\n */\nexport enum SubnetType {\n  /**\n   * Isolated Subnets do not route Outbound traffic\n   *\n   * This can be good for subnets with RDS or\n   * Elasticache endpoints\n   */\n  Isolated = 1,\n\n  /**\n   * Subnet that routes to the internet, but not vice versa.\n   *\n   * Instances in a private subnet can connect to the Internet, but will not\n   * allow connections to be initiated from the Internet.\n   *\n   * Outbound traffic will be routed via a NAT Gateway. Preference being in\n   * the same AZ, but if not available will use another AZ (control by\n   * specifing `maxGateways` on VpcNetwork). This might be used for\n   * experimental cost conscious accounts or accounts where HA outbound\n   * traffic is not needed.\n   */\n  Private = 2,\n\n  /**\n   * Subnet connected to the Internet\n   *\n   * Instances in a Public subnet can connect to the Internet and can be\n   * connected to from the Internet as long as they are launched with public\n   * IPs (controlled on the AutoScalingGroup or other constructs that launch\n   * instances).\n   *\n   * Public subnets route outbound traffic via an Internet Gateway.\n   */\n  Public = 3\n}\n\n/**\n * Customize how instances are placed inside a VPC\n *\n * Constructs that allow customization of VPC placement use parameters of this\n * type to provide placement settings.\n *\n * By default, the instances are placed in the private subnets.\n */\nexport interface VpcPlacementStrategy {\n  /**\n   * Place the instances in the subnets of the given type\n   *\n   * At most one of `subnetsToUse` and `subnetName` can be supplied.\n   *\n   * @default SubnetType.Private\n   */\n  subnetsToUse?: SubnetType;\n\n  /**\n   * Place the instances in the subnets with the given name\n   *\n   * (This is the name supplied in subnetConfiguration).\n   *\n   * At most one of `subnetsToUse` and `subnetName` can be supplied.\n   *\n   * @default name\n   */\n  subnetName?: string;\n}\n\n/**\n * A new or imported VPC\n */\nexport abstract class VpcNetworkBase extends Construct implements IVpcNetwork {\n\n  /**\n   * Identifier for this VPC\n   */\n  public abstract readonly vpcId: string;\n\n  /**\n   * List of public subnets in this VPC\n   */\n  public abstract readonly publicSubnets: IVpcSubnet[];\n\n  /**\n   * List of private subnets in this VPC\n   */\n  public abstract readonly privateSubnets: IVpcSubnet[];\n\n  /**\n   * List of isolated subnets in this VPC\n   */\n  public abstract readonly isolatedSubnets: IVpcSubnet[];\n\n  /**\n   * AZs for this VPC\n   */\n  public abstract readonly availabilityZones: string[];\n\n  /**\n   * Dependencies for internet connectivity\n   */\n  public readonly internetDependencies = new Array<IConstruct>();\n\n  /**\n   * Dependencies for NAT connectivity\n   */\n  public readonly natDependencies = new Array<IConstruct>();\n\n  /**\n   * Return the subnets appropriate for the placement strategy\n   */\n  public subnets(placement: VpcPlacementStrategy = {}): IVpcSubnet[] {\n    if (placement.subnetsToUse !== undefined && placement.subnetName !== undefined) {\n      throw new Error('At most one of subnetsToUse and subnetName can be supplied');\n    }\n\n    // Select by name\n    if (placement.subnetName !== undefined) {\n      const allSubnets = this.privateSubnets.concat(this.publicSubnets).concat(this.isolatedSubnets);\n      const selectedSubnets = allSubnets.filter(s => subnetName(s) === placement.subnetName);\n      if (selectedSubnets.length === 0) {\n        throw new Error(`No subnets with name: ${placement.subnetName}`);\n      }\n      return selectedSubnets;\n    }\n\n    // Select by type\n    if (placement.subnetsToUse === undefined) { return this.privateSubnets; }\n\n    return {\n      [SubnetType.Isolated]: this.isolatedSubnets,\n      [SubnetType.Private]: this.privateSubnets,\n      [SubnetType.Public]: this.publicSubnets,\n    }[placement.subnetsToUse];\n  }\n\n  /**\n   * Export this VPC from the stack\n   */\n  public abstract export(): VpcNetworkImportProps;\n\n  /**\n   * Return whether the given subnet is one of this VPC's public subnets.\n   *\n   * The subnet must literally be one of the subnet object obtained from\n   * this VPC. A subnet that merely represents the same subnet will\n   * never return true.\n   */\n  public isPublicSubnet(subnet: IVpcSubnet) {\n    return this.publicSubnets.indexOf(subnet) > -1;\n  }\n\n  /**\n   * The region where this VPC is defined\n   */\n  public get vpcRegion(): string {\n    return this.node.stack.region;\n  }\n\n}\n\n/**\n * Properties that reference an external VpcNetwork\n */\nexport interface VpcNetworkImportProps {\n  /**\n   * VPC's identifier\n   */\n  vpcId: string;\n\n  /**\n   * List of availability zones for the subnets in this VPC.\n   */\n  availabilityZones: string[];\n\n  /**\n   * List of public subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  publicSubnetIds?: string[];\n\n  /**\n   * List of names for the public subnets\n   *\n   * Must be undefined or have a name for every public subnet group.\n   */\n  publicSubnetNames?: string[];\n\n  /**\n   * List of private subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  privateSubnetIds?: string[];\n\n  /**\n   * List of names for the private subnets\n   *\n   * Must be undefined or have a name for every private subnet group.\n   */\n  privateSubnetNames?: string[];\n\n  /**\n   * List of isolated subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  isolatedSubnetIds?: string[];\n\n  /**\n   * List of names for the isolated subnets\n   *\n   * Must be undefined or have a name for every isolated subnet group.\n   */\n  isolatedSubnetNames?: string[];\n}\n\nexport interface VpcSubnetImportProps {\n  /**\n   * The Availability Zone the subnet is located in\n   */\n  availabilityZone: string;\n\n  /**\n   * The subnetId for this particular subnet\n   */\n  subnetId: string;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vpc-ref.js","sourceRoot":"","sources":["vpc-ref.ts"],"names":[],"mappings":";;AAAA,sCAAkE;AAClE,iCAAoC;AACpC,+BAA4D;AAqF5D;;GAEG;AACH,IAAY,UAkCX;AAlCD,WAAY,UAAU;IACpB;;;;;OAKG;IACH,mDAAY,CAAA;IAEZ;;;;;;;;;;;OAWG;IACH,iDAAW,CAAA;IAEX;;;;;;;;;OASG;IACH,+CAAU,CAAA;AACZ,CAAC,EAlCW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAkCrB;AAgCD;;GAEG;AACH,MAAsB,cAAe,SAAQ,eAAS;IAAtD;;QAgCE;;WAEG;QACa,yBAAoB,GAAG,IAAI,KAAK,EAAc,CAAC;QAE/D;;WAEG;QACa,oBAAe,GAAG,IAAI,KAAK,EAAc,CAAC;IA+D5D,CAAC;IA7DC;;OAEG;IACI,OAAO,CAAC,YAAkC,EAAE;QACjD,IAAI,SAAS,CAAC,YAAY,KAAK,SAAS,IAAI,SAAS,CAAC,UAAU,KAAK,SAAS,EAAE;YAC9E,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;SAC/E;QAED,iBAAiB;QACjB,IAAI,SAAS,CAAC,UAAU,KAAK,SAAS,EAAE;YACtC,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC/F,MAAM,eAAe,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,iBAAU,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,UAAU,CAAC,CAAC;YACvF,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;gBAChC,MAAM,IAAI,KAAK,CAAC,yBAAyB,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC;aAClE;YACD,OAAO,eAAe,CAAC;SACxB;QAED,iBAAiB;QACjB,IAAI,SAAS,CAAC,YAAY,KAAK,SAAS,EAAE;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC;SAAE;QAEzE,OAAO;YACL,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,eAAe;YAC3C,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,cAAc;YACzC,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,aAAa;SACxC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,EAAU,EAAE,OAA6B;QAC/D,OAAO,IAAI,mBAAa,CAAC,IAAI,EAAE,EAAE,kBAC/B,GAAG,EAAE,IAAI,IACN,OAAO,EACV,CAAC;IACL,CAAC;IAOD;;;;;;OAMG;IACI,cAAc,CAAC,MAAkB;QACtC,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAChC,CAAC;CAEF;AAvGD,wCAuGC","sourcesContent":["import { Construct, IConstruct, IDependable } from \"@aws-cdk/cdk\";\nimport { subnetName } from './util';\nimport { VpnConnection, VpnConnectionOptions } from './vpn';\n\nexport interface IVpcSubnet extends IConstruct {\n  /**\n   * The Availability Zone the subnet is located in\n   */\n  readonly availabilityZone: string;\n\n  /**\n   * The subnetId for this particular subnet\n   */\n  readonly subnetId: string;\n\n  /**\n   * Dependable that can be depended upon to force internet connectivity established on the VPC\n   */\n  readonly internetConnectivityEstablished: IDependable;\n\n  /**\n   * Exports this subnet to another stack.\n   */\n  export(): VpcSubnetImportProps;\n}\n\nexport interface IVpcNetwork extends IConstruct {\n  /**\n   * Identifier for this VPC\n   */\n  readonly vpcId: string;\n\n  /**\n   * List of public subnets in this VPC\n   */\n  readonly publicSubnets: IVpcSubnet[];\n\n  /**\n   * List of private subnets in this VPC\n   */\n  readonly privateSubnets: IVpcSubnet[];\n\n  /**\n   * List of isolated subnets in this VPC\n   */\n  readonly isolatedSubnets: IVpcSubnet[];\n\n  /**\n   * AZs for this VPC\n   */\n  readonly availabilityZones: string[];\n\n  /**\n   * Region where this VPC is located\n   */\n  readonly vpcRegion: string;\n\n  /**\n   * Identifier for the VPN gateway\n   */\n  readonly vpnGatewayId?: string;\n\n  /**\n   * Return the subnets appropriate for the placement strategy\n   */\n  subnets(placement?: VpcPlacementStrategy): IVpcSubnet[];\n\n  /**\n   * Return whether the given subnet is one of this VPC's public subnets.\n   *\n   * The subnet must literally be one of the subnet object obtained from\n   * this VPC. A subnet that merely represents the same subnet will\n   * never return true.\n   */\n  isPublicSubnet(subnet: IVpcSubnet): boolean;\n\n  /**\n   * Adds a new VPN connection to this VPC\n   */\n  addVpnConnection(id: string, options: VpnConnectionOptions): VpnConnection;\n\n  /**\n   * Exports this VPC so it can be consumed by another stack.\n   */\n  export(): VpcNetworkImportProps;\n}\n\n/**\n * The type of Subnet\n */\nexport enum SubnetType {\n  /**\n   * Isolated Subnets do not route Outbound traffic\n   *\n   * This can be good for subnets with RDS or\n   * Elasticache endpoints\n   */\n  Isolated = 1,\n\n  /**\n   * Subnet that routes to the internet, but not vice versa.\n   *\n   * Instances in a private subnet can connect to the Internet, but will not\n   * allow connections to be initiated from the Internet.\n   *\n   * Outbound traffic will be routed via a NAT Gateway. Preference being in\n   * the same AZ, but if not available will use another AZ (control by\n   * specifing `maxGateways` on VpcNetwork). This might be used for\n   * experimental cost conscious accounts or accounts where HA outbound\n   * traffic is not needed.\n   */\n  Private = 2,\n\n  /**\n   * Subnet connected to the Internet\n   *\n   * Instances in a Public subnet can connect to the Internet and can be\n   * connected to from the Internet as long as they are launched with public\n   * IPs (controlled on the AutoScalingGroup or other constructs that launch\n   * instances).\n   *\n   * Public subnets route outbound traffic via an Internet Gateway.\n   */\n  Public = 3\n}\n\n/**\n * Customize how instances are placed inside a VPC\n *\n * Constructs that allow customization of VPC placement use parameters of this\n * type to provide placement settings.\n *\n * By default, the instances are placed in the private subnets.\n */\nexport interface VpcPlacementStrategy {\n  /**\n   * Place the instances in the subnets of the given type\n   *\n   * At most one of `subnetsToUse` and `subnetName` can be supplied.\n   *\n   * @default SubnetType.Private\n   */\n  subnetsToUse?: SubnetType;\n\n  /**\n   * Place the instances in the subnets with the given name\n   *\n   * (This is the name supplied in subnetConfiguration).\n   *\n   * At most one of `subnetsToUse` and `subnetName` can be supplied.\n   *\n   * @default name\n   */\n  subnetName?: string;\n}\n\n/**\n * A new or imported VPC\n */\nexport abstract class VpcNetworkBase extends Construct implements IVpcNetwork {\n\n  /**\n   * Identifier for this VPC\n   */\n  public abstract readonly vpcId: string;\n\n  /**\n   * List of public subnets in this VPC\n   */\n  public abstract readonly publicSubnets: IVpcSubnet[];\n\n  /**\n   * List of private subnets in this VPC\n   */\n  public abstract readonly privateSubnets: IVpcSubnet[];\n\n  /**\n   * List of isolated subnets in this VPC\n   */\n  public abstract readonly isolatedSubnets: IVpcSubnet[];\n\n  /**\n   * AZs for this VPC\n   */\n  public abstract readonly availabilityZones: string[];\n\n  /**\n   * Identifier for the VPN gateway\n   */\n  public abstract readonly vpnGatewayId?: string;\n\n  /**\n   * Dependencies for internet connectivity\n   */\n  public readonly internetDependencies = new Array<IConstruct>();\n\n  /**\n   * Dependencies for NAT connectivity\n   */\n  public readonly natDependencies = new Array<IConstruct>();\n\n  /**\n   * Return the subnets appropriate for the placement strategy\n   */\n  public subnets(placement: VpcPlacementStrategy = {}): IVpcSubnet[] {\n    if (placement.subnetsToUse !== undefined && placement.subnetName !== undefined) {\n      throw new Error('At most one of subnetsToUse and subnetName can be supplied');\n    }\n\n    // Select by name\n    if (placement.subnetName !== undefined) {\n      const allSubnets = this.privateSubnets.concat(this.publicSubnets).concat(this.isolatedSubnets);\n      const selectedSubnets = allSubnets.filter(s => subnetName(s) === placement.subnetName);\n      if (selectedSubnets.length === 0) {\n        throw new Error(`No subnets with name: ${placement.subnetName}`);\n      }\n      return selectedSubnets;\n    }\n\n    // Select by type\n    if (placement.subnetsToUse === undefined) { return this.privateSubnets; }\n\n    return {\n      [SubnetType.Isolated]: this.isolatedSubnets,\n      [SubnetType.Private]: this.privateSubnets,\n      [SubnetType.Public]: this.publicSubnets,\n    }[placement.subnetsToUse];\n  }\n\n  /**\n   * Adds a new VPN connection to this VPC\n   */\n  public addVpnConnection(id: string, options: VpnConnectionOptions): VpnConnection {\n    return new VpnConnection(this, id, {\n      vpc: this,\n      ...options\n    });\n  }\n\n  /**\n   * Export this VPC from the stack\n   */\n  public abstract export(): VpcNetworkImportProps;\n\n  /**\n   * Return whether the given subnet is one of this VPC's public subnets.\n   *\n   * The subnet must literally be one of the subnet object obtained from\n   * this VPC. A subnet that merely represents the same subnet will\n   * never return true.\n   */\n  public isPublicSubnet(subnet: IVpcSubnet) {\n    return this.publicSubnets.indexOf(subnet) > -1;\n  }\n\n  /**\n   * The region where this VPC is defined\n   */\n  public get vpcRegion(): string {\n    return this.node.stack.region;\n  }\n\n}\n\n/**\n * Properties that reference an external VpcNetwork\n */\nexport interface VpcNetworkImportProps {\n  /**\n   * VPC's identifier\n   */\n  vpcId: string;\n\n  /**\n   * List of availability zones for the subnets in this VPC.\n   */\n  availabilityZones: string[];\n\n  /**\n   * List of public subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  publicSubnetIds?: string[];\n\n  /**\n   * List of names for the public subnets\n   *\n   * Must be undefined or have a name for every public subnet group.\n   */\n  publicSubnetNames?: string[];\n\n  /**\n   * List of private subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  privateSubnetIds?: string[];\n\n  /**\n   * List of names for the private subnets\n   *\n   * Must be undefined or have a name for every private subnet group.\n   */\n  privateSubnetNames?: string[];\n\n  /**\n   * List of isolated subnet IDs\n   *\n   * Must be undefined or match the availability zones in length and order.\n   */\n  isolatedSubnetIds?: string[];\n\n  /**\n   * List of names for the isolated subnets\n   *\n   * Must be undefined or have a name for every isolated subnet group.\n   */\n  isolatedSubnetNames?: string[];\n\n  /**\n   * VPN gateway's identifier\n   */\n  vpnGatewayId?: string;\n}\n\nexport interface VpcSubnetImportProps {\n  /**\n   * The Availability Zone the subnet is located in\n   */\n  availabilityZone: string;\n\n  /**\n   * The subnetId for this particular subnet\n   */\n  subnetId: string;\n}\n"]} |
@@ -7,2 +7,3 @@ import cdk = require('@aws-cdk/cdk'); | ||
import { IVpcNetwork, IVpcSubnet, SubnetType, VpcNetworkBase, VpcNetworkImportProps, VpcPlacementStrategy, VpcSubnetImportProps } from './vpc-ref'; | ||
import { VpnConnectionOptions } from './vpn'; | ||
/** | ||
@@ -103,2 +104,28 @@ * VpcNetworkProps allows you to specify configuration options for a VPC | ||
subnetConfiguration?: SubnetConfiguration[]; | ||
/** | ||
* Indicates whether a VPN gateway should be created and attached to this VPC. | ||
* | ||
* @default true when vpnGatewayAsn or vpnConnections is specified. | ||
*/ | ||
vpnGateway?: boolean; | ||
/** | ||
* The private Autonomous System Number (ASN) for the VPN gateway. | ||
* | ||
* @default Amazon default ASN | ||
*/ | ||
vpnGatewayAsn?: number; | ||
/** | ||
* VPN connections to this VPC. | ||
* | ||
* @default no connections | ||
*/ | ||
vpnConnections?: { | ||
[id: string]: VpnConnectionOptions; | ||
}; | ||
/** | ||
* Where to propagate VPN routes. | ||
* | ||
* @default on the route tables associated with private subnets | ||
*/ | ||
vpnRoutePropagation?: SubnetType[]; | ||
} | ||
@@ -209,2 +236,6 @@ /** | ||
/** | ||
* Identifier for the VPN gateway | ||
*/ | ||
readonly vpnGatewayId?: string; | ||
/** | ||
* The VPC resource | ||
@@ -287,3 +318,3 @@ */ | ||
*/ | ||
private readonly routeTableId; | ||
readonly routeTableId: string; | ||
private readonly internetDependencies; | ||
@@ -290,0 +321,0 @@ constructor(scope: cdk.Construct, id: string, props: VpcSubnetProps); |
{ | ||
"name": "@aws-cdk/aws-ec2", | ||
"version": "0.25.1", | ||
"version": "0.25.2", | ||
"description": "CDK Constructs for AWS EC2", | ||
@@ -57,17 +57,17 @@ "main": "lib/index.js", | ||
"devDependencies": { | ||
"@aws-cdk/assert": "^0.25.1", | ||
"cdk-build-tools": "^0.25.1", | ||
"cdk-integ-tools": "^0.25.1", | ||
"cfn2ts": "^0.25.1", | ||
"pkglint": "^0.25.1" | ||
"@aws-cdk/assert": "^0.25.2", | ||
"cdk-build-tools": "^0.25.2", | ||
"cdk-integ-tools": "^0.25.2", | ||
"cfn2ts": "^0.25.2", | ||
"pkglint": "^0.25.2" | ||
}, | ||
"dependencies": { | ||
"@aws-cdk/aws-iam": "^0.25.1", | ||
"@aws-cdk/cdk": "^0.25.1", | ||
"@aws-cdk/cx-api": "^0.25.1" | ||
"@aws-cdk/aws-iam": "^0.25.2", | ||
"@aws-cdk/cdk": "^0.25.2", | ||
"@aws-cdk/cx-api": "^0.25.2" | ||
}, | ||
"homepage": "https://github.com/awslabs/aws-cdk", | ||
"peerDependencies": { | ||
"@aws-cdk/cdk": "^0.25.1", | ||
"@aws-cdk/cx-api": "^0.25.1" | ||
"@aws-cdk/cdk": "^0.25.2", | ||
"@aws-cdk/cx-api": "^0.25.2" | ||
}, | ||
@@ -74,0 +74,0 @@ "engines": { |
@@ -306,1 +306,39 @@ ## AWS Compute and Networking Construct Library | ||
> We will add command-line options to make this step easier in the future. | ||
### VPN connections to a VPC | ||
Create your VPC with VPN connections by specifying the `vpnConnections` props (keys are construct `id`s): | ||
```ts | ||
const vpc = new ec2.VpcNetwork(stack, 'MyVpc', { | ||
vpnConnections: { | ||
dynamic: { // Dynamic routing (BGP) | ||
ip: '1.2.3.4' | ||
}, | ||
static: { // Static routing | ||
ip: '4.5.6.7', | ||
staticRoutes: [ | ||
'192.168.10.0/24', | ||
'192.168.20.0/24' | ||
] | ||
} | ||
} | ||
}); | ||
``` | ||
To create a VPC that can accept VPN connections, set `vpnGateway` to `true`: | ||
```ts | ||
const vpc = new ec2.VpcNetwork(stack, 'MyVpc', { | ||
vpnGateway: true | ||
}); | ||
``` | ||
VPN connections can then be added: | ||
```ts | ||
vpc.addVpnConnection('Dynamic', { | ||
ip: '1.2.3.4' | ||
}); | ||
``` | ||
Routes will be propagated on the route tables associated with the private subnets. |
@@ -23,2 +23,7 @@ import { Test } from 'nodeunit'; | ||
'with mis-matched nat and subnet configs it throws'(test: Test): void; | ||
'with a vpn gateway'(test: Test): void; | ||
'with a vpn gateway and route propagation on isolated subnets'(test: Test): void; | ||
'with a vpn gateway and route propagation on private and isolated subnets'(test: Test): void; | ||
'fails when specifying vpnConnections with vpnGateway set to false'(test: Test): void; | ||
'fails when specifying vpnGatewayAsn with vpnGateway set to false'(test: Test): void; | ||
}; | ||
@@ -25,0 +30,0 @@ "When creating a VPC with a custom CIDR range": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Network access
Supply chain riskThis module accesses the network.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
2756940
58
18628
344
1
Updated@aws-cdk/aws-iam@^0.25.2
Updated@aws-cdk/cdk@^0.25.2
Updated@aws-cdk/cx-api@^0.25.2